Code

screen_interface: add method mouse(), replacing CMD_MOUSE_EVENT
[ncmpc.git] / src / screen.h
index c546e281b1b91183b3dde806a11e49e7bec6eafc..3d7bc3922f0e8ac2d45565d65f5eceb3bb933fa1 100644 (file)
@@ -32,6 +32,8 @@
 
 #include <glib.h>
 
+#include <stdbool.h>
+
 struct mpdclient;
 struct screen_functions;
 
@@ -41,6 +43,8 @@ struct screen {
        struct progress_bar progress_bar;
        struct status_bar status_bar;
 
+       const struct screen_functions *current_page;
+
        char *buf;
        size_t buf_size;
 
@@ -62,21 +66,29 @@ void screen_init(struct mpdclient *c);
 void screen_exit(void);
 void screen_resize(struct mpdclient *c);
 
+void
+paint_top_window(const struct mpdclient *c);
+
 void
 screen_paint(struct mpdclient *c, bool main_dirty);
 
 void screen_update(struct mpdclient *c);
 void screen_cmd(struct mpdclient *c, command_t cmd);
 
+#ifdef HAVE_GETMOUSE
+bool
+screen_mouse(struct mpdclient *c, int x, int y, mmask_t bstate);
+#endif
+
 void
 screen_switch(const struct screen_functions *sf, struct mpdclient *c);
 void 
 screen_swap(struct mpdclient *c, const struct mpd_song *song);
 
-gboolean
-screen_is_visible(const struct screen_functions *sf);
-
-int
-screen_get_mouse_event(struct mpdclient *c, unsigned long *bstate, int *row);
+static inline bool
+screen_is_visible(const struct screen_functions *sf)
+{
+       return sf == screen.current_page;
+}
 
 #endif