X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=wm.h;h=852b62f8cba467aa5a8b6be957f0291054c3bd2a;hb=d28df0d848dc7e30f2df67518a251b52981a1093;hp=4b1d834a36907fed08c08dd0aaacc5219a71af8a;hpb=c00388973ecb2af94cc7b74ef762f0b8d10741e6;p=wmpus diff --git a/wm.h b/wm.h index 4b1d834..852b62f 100644 --- a/wm.h +++ b/wm.h @@ -1,5 +1,46 @@ -void wm_init(win_t *root); +/* + * Copyright (c) 2011, Andy Spencer + * + * Permission to use, copy, modify, and/or distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + */ + +/* Window manager interface: + * + * The window manager receives input events from the system + * and responds by using the system to arrange the windows + * according to it's layout. + * + * The window provided to these function is generally the + * window with the keyboard or mouse focus. */ + +/* Refresh the window layout */ +void wm_update(void); + +/* Called for each watched key press. + * This is currently used for some other events such + * as focus-in and focus-out as well. */ +int wm_handle_key(win_t *win, Key_t key, mod_t mod, ptr_t ptr); -void wm_handle_key(win_t *win, Key_t key, mod_t mod, ptr_t ptr); +/* Called for each mouse movement */ +int wm_handle_ptr(win_t *win, ptr_t ptr); + +/* Begin managing a window, called for each new window */ +void wm_insert(win_t *win); + +/* Stop managing a window and free data */ +void wm_remove(win_t *win); + +/* First call, sets up key bindings, etc */ +void wm_init(win_t *root); -void wm_handle_ptr(win_t *win, ptr_t ptr); +/* First call, sets up key bindings, etc */ +void wm_free(win_t *root);