Mercurial > pidgin
view console/libgnt/gntwm.h @ 14393:81932c1ec6cf
[gaim-migrate @ 17101]
This shouldn't be necessary, but I don't see how it's happening just yet
committer: Tailor Script <tailor@pidgin.im>
author | Ethan Blanton <elb@pidgin.im> |
---|---|
date | Thu, 31 Aug 2006 21:50:55 +0000 |
parents | d4a26ada1971 |
children | 553bbd68387e |
line wrap: on
line source
#ifdef HAVE_NCURSESW_INC #include <ncursesw/panel.h> #else #include <panel.h> #endif #include "gntwidget.h" /* XXX: It might be a good idea to move GntNode from gntmain.c to here. */ typedef struct _GntWM GntWM; struct _GntWM { /* This should return a PANEL for the win */ PANEL *(*new_window)(GntWidget *win); /* This is called when a window is being closed */ gboolean (*close_window)(GntWidget *win); /* The WM may want to confirm a size for a window first */ gboolean (*window_resize_confirm)(GntWidget *win, int *w, int *h); /* Can del_panel the old panel and return a new_panel. * Otherwise, this should at least do a replace_panel. */ PANEL *(*window_resized)(PANEL *pan, GntWidget *win); /* The WM may want to confirm the position of a window */ gboolean (*window_move_confirm)(GntWidget *win, int *x, int *y); void (*window_moved)(PANEL *pan, GntWidget *win); /* This gets called when: * - the title of the window changes * - the 'urgency' of the window changes */ void (*window_update)(PANEL *pan, GntWidget *win); /* This should usually return NULL if the keys were processed by the WM. * If not, the WM can simply return the original string, which will be * processed by the default WM. The custom WM can also return a different * static string for the default WM to process. */ const char *(*key_pressed)(const char *key); gboolean (*mouse_clicked)(GntMouseEvent event, int x, int y, GntWidget *widget); /* Whatever the WM wants to do when a window is given focus */ void (*give_focus)(GntWidget *widget); /* If something needs to be uninited */ void (*gntwm_uninit)(); /* List of windows. Although the WM can keep a list of its own for the windows, * it'd be better if there was a way to share between the 'core' and the WM. */ const GList *(*window_list)(); };