X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fdispatch.h;h=412e135e6a1df159601717de5fde82179881b01d;hb=ebab4adb85ed6cbe8f651e828791deb2a9f4154b;hp=a28386210ad3f95bcec472c6d93eab0d71b2155d;hpb=648c55b829e09c66222a9bbf08d10434622feae2;p=chaz%2Fopenbox diff --git a/openbox/dispatch.h b/openbox/dispatch.h index a2838621..412e135e 100644 --- a/openbox/dispatch.h +++ b/openbox/dispatch.h @@ -18,21 +18,24 @@ typedef enum { Event_X_Bell = 1 << 7, /* an XKB bell event */ Event_Client_New = 1 << 8, /* new window, before mapping */ - Event_Client_Mapped = 1 << 9, /* new window, after mapping */ + Event_Client_Mapped = 1 << 9, /* new window, after mapping + or uniconified */ Event_Client_Destroy = 1 << 10, /* unmanaged */ - Event_Client_Unmapped = 1 << 11, /* unmanaged, after unmapping */ + Event_Client_Unmapped = 1 << 11, /* unmanaged, after unmapping + or iconified */ Event_Client_Focus = 1 << 12, /* focused */ Event_Client_Unfocus = 1 << 13, /* unfocused */ Event_Client_Urgent = 1 << 14, /* entered/left urgent state */ Event_Client_Desktop = 1 << 15, /* moved to a new desktop */ + Event_Client_Moving = 1 << 16, /* being interactively moved */ - Event_Ob_Desktop = 1 << 16, /* changed desktops */ - Event_Ob_NumDesktops = 1 << 17, /* changed the number of desktops */ - Event_Ob_ShowDesktop = 1 << 18, /* entered/left show-the-desktop mode */ + Event_Ob_Desktop = 1 << 17, /* changed desktops */ + Event_Ob_NumDesktops = 1 << 18, /* changed the number of desktops */ + Event_Ob_ShowDesktop = 1 << 19, /* entered/left show-the-desktop mode */ - Event_Signal = 1 << 19, /* a signal from the OS */ + Event_Signal = 1 << 20, /* a signal from the OS */ - EVENT_RANGE = 1 << 20 + EVENT_RANGE = 1 << 21 } EventType; typedef struct { @@ -45,6 +48,9 @@ typedef struct { int num[2]; /* Event_Client_Desktop: num[0] = new number, num[1] = old number Event_Client_Urgent: num[0] = urgent state + Event_Client_Moving: num[0] = dest x coord, num[1] = dest y coord -- + change these in the handler to adjust where the + window will be placed */ } EventData_Client; @@ -82,5 +88,8 @@ void dispatch_x(XEvent *e, Client *c); void dispatch_client(EventType e, Client *c, int num0, int num1); void dispatch_ob(EventType e, int num0, int num1); void dispatch_signal(int signal); +/* *x and *y should be set with the destination of the window, they may be + changed by the event handlers */ +void dispatch_move(Client *c, int *x, int *y); #endif