aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorLibravatar Brian Ashworth <bosrsf04@gmail.com>2019-01-15 21:25:28 -0500
committerLibravatar emersion <contact@emersion.fr>2019-01-16 11:12:45 +0100
commit02bbefda20b9a4f86e740d33bbaa21c661bb2fac (patch)
tree1b753e414749374be1e144a326a744c4b6812480 /include
parentlayer_shell: do not SIGABRT sway on zero outputs (diff)
downloadsway-02bbefda20b9a4f86e740d33bbaa21c661bb2fac.tar.gz
sway-02bbefda20b9a4f86e740d33bbaa21c661bb2fac.tar.zst
sway-02bbefda20b9a4f86e740d33bbaa21c661bb2fac.zip
bar_cmd_tray_bind: Use mouse button helpers
This modifies `bar_cmd_tray_bindsym` to use `get_mouse_bindsym` for parsing mouse buttons. This also introduces `bar_cmd_tray_bindcode`, which will use `get_mouse_bindcode` for parsing mouse buttons. Like with sway bindings, the two commands are encapsulated in a single file to maximize shared code. This also modifies tray bindings to work off of events codes rather than x11 buttons, which allows for any mouse buttons to be used. For `get_bar_config`, `event_code` has been added to the `tray_bindings` section and will include to event code for the button. If the event code can be mapped to a x11 button, `input_code` will still be the x11 button number. Otherwise, `input_code` will be `0`.
Diffstat (limited to 'include')
-rw-r--r--include/sway/commands.h1
-rw-r--r--include/sway/config.h10
-rw-r--r--include/sway/input/cursor.h2
-rw-r--r--include/swaybar/config.h10
-rw-r--r--include/swaybar/input.h15
5 files changed, 23 insertions, 15 deletions
diff --git a/include/sway/commands.h b/include/sway/commands.h
index 68487879..7672a3fd 100644
--- a/include/sway/commands.h
+++ b/include/sway/commands.h
@@ -207,6 +207,7 @@ sway_cmd bar_cmd_pango_markup;
207sway_cmd bar_cmd_strip_workspace_numbers; 207sway_cmd bar_cmd_strip_workspace_numbers;
208sway_cmd bar_cmd_strip_workspace_name; 208sway_cmd bar_cmd_strip_workspace_name;
209sway_cmd bar_cmd_swaybar_command; 209sway_cmd bar_cmd_swaybar_command;
210sway_cmd bar_cmd_tray_bindcode;
210sway_cmd bar_cmd_tray_bindsym; 211sway_cmd bar_cmd_tray_bindsym;
211sway_cmd bar_cmd_tray_output; 212sway_cmd bar_cmd_tray_output;
212sway_cmd bar_cmd_tray_padding; 213sway_cmd bar_cmd_tray_padding;
diff --git a/include/sway/config.h b/include/sway/config.h
index 96fe899b..978606a6 100644
--- a/include/sway/config.h
+++ b/include/sway/config.h
@@ -260,7 +260,7 @@ struct bar_config {
260 260
261#if HAVE_TRAY 261#if HAVE_TRAY
262 char *icon_theme; 262 char *icon_theme;
263 const char *tray_bindings[10]; // mouse buttons 0-9 263 struct wl_list tray_bindings; // struct tray_binding::link
264 list_t *tray_outputs; // char * 264 list_t *tray_outputs; // char *
265 int tray_padding; 265 int tray_padding;
266#endif 266#endif
@@ -272,6 +272,14 @@ struct bar_binding {
272 char *command; 272 char *command;
273}; 273};
274 274
275#if HAVE_TRAY
276struct tray_binding {
277 uint32_t button;
278 const char *command;
279 struct wl_list link; // struct tray_binding::link
280};
281#endif
282
275struct border_colors { 283struct border_colors {
276 float border[4]; 284 float border[4];
277 float background[4]; 285 float background[4];
diff --git a/include/sway/input/cursor.h b/include/sway/input/cursor.h
index 77aa0ea1..abd72783 100644
--- a/include/sway/input/cursor.h
+++ b/include/sway/input/cursor.h
@@ -103,4 +103,6 @@ uint32_t get_mouse_bindcode(const char *name, char **error);
103// Considers both bindsym and bindcode 103// Considers both bindsym and bindcode
104uint32_t get_mouse_button(const char *name, char **error); 104uint32_t get_mouse_button(const char *name, char **error);
105 105
106const char *get_mouse_button_name(uint32_t button);
107
106#endif 108#endif
diff --git a/include/swaybar/config.h b/include/swaybar/config.h
index add0a1cf..ec042e51 100644
--- a/include/swaybar/config.h
+++ b/include/swaybar/config.h
@@ -70,13 +70,21 @@ struct swaybar_config {
70 70
71#if HAVE_TRAY 71#if HAVE_TRAY
72 char *icon_theme; 72 char *icon_theme;
73 char *tray_bindings[10]; // mouse buttons 0-9 73 struct wl_list tray_bindings; // struct tray_binding::link
74 bool tray_hidden; 74 bool tray_hidden;
75 list_t *tray_outputs; // char * 75 list_t *tray_outputs; // char *
76 int tray_padding; 76 int tray_padding;
77#endif 77#endif
78}; 78};
79 79
80#if HAVE_TRAY
81struct tray_binding {
82 uint32_t button;
83 char *command;
84 struct wl_list link; // struct tray_binding::link
85};
86#endif
87
80struct swaybar_config *init_config(void); 88struct swaybar_config *init_config(void);
81void free_config(struct swaybar_config *config); 89void free_config(struct swaybar_config *config);
82uint32_t parse_position(const char *position); 90uint32_t parse_position(const char *position);
diff --git a/include/swaybar/input.h b/include/swaybar/input.h
index 4b46b0de..d76cd551 100644
--- a/include/swaybar/input.h
+++ b/include/swaybar/input.h
@@ -22,19 +22,6 @@ struct swaybar_pointer {
22 uint32_t serial; 22 uint32_t serial;
23}; 23};
24 24
25enum x11_button {
26 NONE,
27 LEFT,
28 MIDDLE,
29 RIGHT,
30 SCROLL_UP,
31 SCROLL_DOWN,
32 SCROLL_LEFT,
33 SCROLL_RIGHT,
34 BACK,
35 FORWARD,
36};
37
38enum hotspot_event_handling { 25enum hotspot_event_handling {
39 HOTSPOT_IGNORE, 26 HOTSPOT_IGNORE,
40 HOTSPOT_PROCESS, 27 HOTSPOT_PROCESS,
@@ -54,6 +41,8 @@ extern const struct wl_seat_listener seat_listener;
54 41
55void update_cursor(struct swaybar *bar); 42void update_cursor(struct swaybar *bar);
56 43
44uint32_t event_to_x11_button(uint32_t event);
45
57void free_hotspots(struct wl_list *list); 46void free_hotspots(struct wl_list *list);
58 47
59#endif 48#endif