This commit is contained in:
rhp 2001-06-10 18:46:46 +00:00
parent 2f29ba4f39
commit b46ab7cab3
3 changed files with 70 additions and 36 deletions

View File

@ -731,6 +731,11 @@ meta_spew_event (MetaDisplay *display,
char *winname; char *winname;
MetaScreen *screen; MetaScreen *screen;
/* filter overnumerous events */
if (event->type == Expose || event->type == MotionNotify ||
event->type == NoExpose)
return;
switch (event->type) switch (event->type)
{ {
case KeyPress: case KeyPress:

View File

@ -28,6 +28,7 @@
#include "frame.h" #include "frame.h"
#include "workspace.h" #include "workspace.h"
#include "keybindings.h" #include "keybindings.h"
#include "stack.h"
#include <X11/cursorfont.h> #include <X11/cursorfont.h>
#include <X11/Xatom.h> #include <X11/Xatom.h>
@ -181,6 +182,8 @@ meta_screen_new (MetaDisplay *display,
ui_slave_func, ui_slave_func,
screen); screen);
screen->stack = meta_stack_new (screen);
meta_verbose ("Added screen %d ('%s') root 0x%lx\n", meta_verbose ("Added screen %d ('%s') root 0x%lx\n",
screen->number, screen->screen_name, screen->xroot); screen->number, screen->screen_name, screen->xroot);
@ -194,6 +197,8 @@ meta_screen_free (MetaScreen *screen)
meta_ui_slave_free (screen->uislave); meta_ui_slave_free (screen->uislave);
meta_stack_free (screen->stack);
XFreeGC (screen->display->xdisplay, XFreeGC (screen->display->xdisplay,
screen->scratch_gc); screen->scratch_gc);

View File

@ -24,6 +24,7 @@
#include "frame.h" #include "frame.h"
#include "errors.h" #include "errors.h"
#include "workspace.h" #include "workspace.h"
#include "stack.h"
#include <X11/Xatom.h> #include <X11/Xatom.h>
@ -235,6 +236,9 @@ meta_window_new (MetaDisplay *display, Window xwindow)
window->size_hints.width, window->size_hints.width,
window->size_hints.height); window->size_hints.height);
meta_stack_add (window->screen->stack,
window);
meta_window_queue_calc_showing (window); meta_window_queue_calc_showing (window);
return window; return window;
@ -262,6 +266,8 @@ meta_window_free (MetaWindow *window)
g_assert (window->workspaces == NULL); g_assert (window->workspaces == NULL);
meta_stack_remove (window->screen->stack, window);
/* FIXME restore original size if window has maximized */ /* FIXME restore original size if window has maximized */
set_wm_state (window, WithdrawnState); set_wm_state (window, WithdrawnState);
@ -896,19 +902,7 @@ meta_window_raise (MetaWindow *window)
{ {
meta_verbose ("Raising window %s\n", window->desc); meta_verbose ("Raising window %s\n", window->desc);
if (window->frame == NULL) meta_stack_raise (window->screen->stack, window);
{
meta_error_trap_push (window->display);
XRaiseWindow (window->display->xdisplay, window->xwindow);
meta_error_trap_pop (window->display);
}
else
{
XRaiseWindow (window->display->xdisplay,
window->frame->xwindow);
}
} }
void void
@ -1889,6 +1883,10 @@ update_transient_for (MetaWindow *window)
/* may now be a dialog */ /* may now be a dialog */
recalc_window_type (window); recalc_window_type (window);
/* update stacking constraints */
meta_stack_update_transient (window->screen->stack, window);
meta_stack_update_layer (window->screen->stack, window);
return meta_error_trap_pop (window->display); return meta_error_trap_pop (window->display);
} }
@ -1999,6 +1997,9 @@ recalc_window_type (MetaWindow *window)
window->type = META_WINDOW_MODAL_DIALOG; window->type = META_WINDOW_MODAL_DIALOG;
meta_verbose ("Calculated type %d for %s\n", window->type, window->desc); meta_verbose ("Calculated type %d for %s\n", window->type, window->desc);
/* update stacking constraints */
meta_stack_update_layer (window->screen->stack, window);
} }
static void static void
@ -2119,12 +2120,16 @@ constrain_position (MetaWindow *window,
int *new_x, int *new_x,
int *new_y) int *new_y)
{ {
int nw_x, nw_y;
/* frame member variables should NEVER be used in here, only /* frame member variables should NEVER be used in here, only
* MetaFrameGeometry * MetaFrameGeometry
*/ */
if (window->type != META_WINDOW_DESKTOP &&
window->type != META_WINDOW_DOCK)
{
int nw_x, nw_y;
int se_x, se_y;
/* find furthest northwest corner */ /* find furthest northwest corner */
nw_x = window->screen->active_workspace->workarea.x; nw_x = window->screen->active_workspace->workarea.x;
nw_y = window->screen->active_workspace->workarea.y; nw_y = window->screen->active_workspace->workarea.y;
@ -2140,6 +2145,24 @@ constrain_position (MetaWindow *window,
if (y < nw_y) if (y < nw_y)
y = nw_y; y = nw_y;
/* keep titlebar on bottom right as well (but not entire window) */
se_x = window->screen->active_workspace->workarea.x +
window->screen->active_workspace->workarea.width;
se_y = window->screen->active_workspace->workarea.y +
window->screen->active_workspace->workarea.height;
if (window->frame)
{
#define TITLEBAR_LENGTH_ONSCREEN 10
se_x -= (fgeom->left_width + TITLEBAR_LENGTH_ONSCREEN);
se_y -= fgeom->top_height;
}
if (x > se_x)
x = se_x;
if (y > se_y)
y = se_y;
if (window->maximized) if (window->maximized)
{ {
if (x != nw_x) if (x != nw_x)
@ -2147,6 +2170,7 @@ constrain_position (MetaWindow *window,
if (y != nw_y) if (y != nw_y)
y = nw_y; y = nw_y;
} }
}
*new_x = x; *new_x = x;
*new_y = y; *new_y = y;