X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fwindow.h;h=ccd8def211bca0b148f3e66706937ecb3dac7b22;hb=29637976e6aecf45bae84ba9ce3ecb26635012f7;hp=a172cfce62f10664bcb708e8deb0d9b4464ff3b8;hpb=ea481338b5f16fd81a7b33e036ead39b918a51af;p=chaz%2Fopenbox diff --git a/openbox/window.h b/openbox/window.h index a172cfce..ccd8def2 100644 --- a/openbox/window.h +++ b/openbox/window.h @@ -28,55 +28,56 @@ typedef struct _ObWindow ObWindow; typedef struct _ObInternalWindow ObInternalWindow; typedef enum { - Window_Menu, - Window_Dock, - Window_DockApp, /* used for events but not stacking */ - Window_Client, - Window_Internal /* used for stacking but not events (except to filter - events on the root window) */ + OB_WINDOW_CLASS_MENUFRAME, + OB_WINDOW_CLASS_DOCK, + OB_WINDOW_CLASS_CLIENT, + OB_WINDOW_CLASS_INTERNALWINDOW } Window_InternalType; -struct _ObWindow -{ +/* In order to be an ObWindow, you need to make this struct the top of your + struct */ +struct _ObWindow { Window_InternalType type; }; -/* Wrapper for internal stuff. If its struct matches this then it can be used - as an ObWindow */ -typedef struct InternalWindow { - ObWindow obwin; - Window win; -} InternalWindow; - -#define WINDOW_IS_MENU(win) (((ObWindow*)win)->type == Window_Menu) -#define WINDOW_IS_DOCK(win) (((ObWindow*)win)->type == Window_Dock) -#define WINDOW_IS_DOCKAPP(win) (((ObWindow*)win)->type == Window_DockApp) -#define WINDOW_IS_CLIENT(win) (((ObWindow*)win)->type == Window_Client) -#define WINDOW_IS_INTERNAL(win) (((ObWindow*)win)->type == Window_Internal) +#define WINDOW_IS_MENUFRAME(win) \ + (((ObWindow*)win)->type == OB_WINDOW_CLASS_MENUFRAME) +#define WINDOW_IS_DOCK(win) \ + (((ObWindow*)win)->type == OB_WINDOW_CLASS_DOCK) +#define WINDOW_IS_CLIENT(win) \ + (((ObWindow*)win)->type == OB_WINDOW_CLASS_CLIENT) +#define WINDOW_IS_INTERNALWINDOW(win) \ + (((ObWindow*)win)->type == OB_WINDOW_CLASS_INTERNALWINDOW) struct _ObMenu; struct _ObDock; struct _ObDockApp; struct _ObClient; -#define WINDOW_AS_MENU(win) ((struct _ObMenuFrame*)win) +#define WINDOW_AS_MENUFRAME(win) ((struct _ObMenuFrame*)win) #define WINDOW_AS_DOCK(win) ((struct _ObDock*)win) -#define WINDOW_AS_DOCKAPP(win) ((struct _ObDockApp*)win) #define WINDOW_AS_CLIENT(win) ((struct _ObClient*)win) -#define WINDOW_AS_INTERNAL(win) ((struct InternalWindow*)win) +#define WINDOW_AS_INTERNALWINDOW(win) ((struct _ObInternalWindow*)win) -#define MENU_AS_WINDOW(menu) ((ObWindow*)menu) +#define MENUFRAME_AS_WINDOW(menu) ((ObWindow*)menu) #define DOCK_AS_WINDOW(dock) ((ObWindow*)dock) -#define DOCKAPP_AS_WINDOW(dockapp) ((ObWindow*)dockapp) #define CLIENT_AS_WINDOW(client) ((ObWindow*)client) -#define INTERNAL_AS_WINDOW(intern) ((ObWindow*)intern) +#define INTERNALWINDOW_AS_WINDOW(intern) ((ObWindow*)intern) -extern GHashTable *window_map; - -void window_startup(gboolean reconfig); +void window_startup (gboolean reconfig); void window_shutdown(gboolean reconfig); -Window window_top(ObWindow *self); +Window window_top (ObWindow *self); ObStackingLayer window_layer(ObWindow *self); +ObWindow* window_find (Window xwin); +void window_add (Window *xwin, ObWindow *win); +void window_remove(Window xwin); + +/* Internal openbox-owned windows like the alt-tab popup */ +struct _ObInternalWindow { + ObWindow obwin; + Window window; +}; + #endif