X-Git-Url: https://plomlompom.com/repos/?a=blobdiff_plain;f=windows.h;h=c194907b6c41046fc784b76d367829a506d7d3f8;hb=fb2c9683f4b3bd48226ea45222185f99812744ff;hp=3518c372ae4a7078171bb42cfde7fc933788faf6;hpb=1d8dbdee6e32a1e877a6e8884be066b993a5b651;p=plomrogue diff --git a/windows.h b/windows.h index 3518c37..c194907 100644 --- a/windows.h +++ b/windows.h @@ -1,29 +1,35 @@ +struct yx_uint16 { + uint16_t y; + uint16_t x; }; + +struct Frame { + WINDOW * curses_win; + struct yx_uint16 size; }; + struct WinMeta { WINDOW * screen; - WINDOW * pad; - uint16_t pad_offset; + uint16_t pad_offset; + struct Frame pad; struct Win * chain_start; struct Win * chain_end; - struct Win * active; - uint16_t width; - uint16_t height; }; + struct Win * active; }; struct Win { struct Win * prev; struct Win * next; - uint16_t width; - uint16_t height; - WINDOW * curses; + struct yx_uint16 start; + struct Frame frame; char * title; void (* draw) (struct Win *); void * data; }; -extern struct WinMeta init_win_meta (WINDOW *); -extern struct Win init_window (struct WinMeta *, char *, void *, void *); -extern void append_window (struct WinMeta *, struct Win *); -extern void suspend_window (struct WinMeta *, struct Win *); -extern void draw_all_windows (struct WinMeta *); -extern void resize_active_window (struct WinMeta *, uint16_t, uint16_t); -extern void cycle_active_window (struct WinMeta *, char); -extern void shift_active_window (struct WinMeta *, char); +extern struct WinMeta init_win_meta (WINDOW *); +extern struct Win init_win (struct WinMeta *, char *, void *, void *); +extern void append_win (struct WinMeta *, struct Win *); +extern void suspend_win (struct WinMeta *, struct Win *); +extern void draw_scroll_hint (struct Frame *, uint16_t, uint32_t, char); +extern void draw_all_wins (struct WinMeta *); +extern void resize_active_win (struct WinMeta *, uint16_t, uint16_t); +extern void cycle_active_win (struct WinMeta *, char); +extern void shift_active_win (struct WinMeta *, char); extern void reset_pad_offset (struct WinMeta *, uint16_t);