summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorPatrick McDermott <pj@pehjota.net>2017-11-19 17:35:50 (EST)
committer Patrick McDermott <pj@pehjota.net>2017-11-19 17:35:50 (EST)
commit28543f6771463a696d9350b5bab22d817178488d (patch)
tree3fd2d7ee1bd966fc60c4c549d9cdd0ed5996046c /src
parent029793d469165fca28a85068ad043bd93a445905 (diff)
downloadmarquee-28543f6771463a696d9350b5bab22d817178488d.zip
marquee-28543f6771463a696d9350b5bab22d817178488d.tar.gz
marquee-28543f6771463a696d9350b5bab22d817178488d.tar.bz2
MqMainMenu: Define and use BTN() macro for main button grid
Diffstat (limited to 'src')
-rw-r--r--src/toolbars/navigation/main-menu.c33
1 files changed, 15 insertions, 18 deletions
diff --git a/src/toolbars/navigation/main-menu.c b/src/toolbars/navigation/main-menu.c
index bfbfa23..c75caf6 100644
--- a/src/toolbars/navigation/main-menu.c
+++ b/src/toolbars/navigation/main-menu.c
@@ -293,24 +293,20 @@ create_zoom_buttons(MqMainMenu *main_menu)
#define BUTTON_ROWS 3
#define BUTTON_COLS 3
+#define BTN(Y, X) buttons[Y * BUTTON_COLS + X]
#define NEW_BTN(Y, X, ID, ICON, TOOLTIP) \
G_STMT_START { \
- buttons[Y * BUTTON_COLS + X] = gtk_button_new_from_icon_name(\
- ICON, GTK_ICON_SIZE_BUTTON); \
- gtk_button_set_relief(GTK_BUTTON(buttons[Y * BUTTON_COLS + X]),\
- GTK_RELIEF_NONE); \
- gtk_button_set_label(GTK_BUTTON(buttons[Y * BUTTON_COLS + X]), \
- TOOLTIP); \
- gtk_button_set_image_position(\
- GTK_BUTTON(buttons[Y * BUTTON_COLS + X]), GTK_POS_TOP);\
- gtk_button_set_always_show_image(\
- GTK_BUTTON(buttons[Y * BUTTON_COLS + X]), TRUE); \
- gtk_widget_set_tooltip_text(buttons[Y * BUTTON_COLS + X], \
- TOOLTIP); \
- g_signal_connect(buttons[Y * BUTTON_COLS + X], "clicked", \
+ BTN(Y, X) = gtk_button_new_from_icon_name(ICON, \
+ GTK_ICON_SIZE_BUTTON); \
+ gtk_button_set_relief(GTK_BUTTON(BTN(Y, X)), GTK_RELIEF_NONE); \
+ gtk_button_set_label(GTK_BUTTON(BTN(Y, X)), TOOLTIP); \
+ gtk_button_set_image_position(GTK_BUTTON(BTN(Y, X)), \
+ GTK_POS_TOP); \
+ gtk_button_set_always_show_image(GTK_BUTTON(BTN(Y, X)), TRUE); \
+ gtk_widget_set_tooltip_text(BTN(Y, X), TOOLTIP); \
+ g_signal_connect(BTN(Y, X), "clicked", \
G_CALLBACK(ID ## _clicked_cb), main_menu); \
- gtk_grid_attach(GTK_GRID(grid), buttons[Y * BUTTON_COLS + X], \
- X, Y, 1, 1); \
+ gtk_grid_attach(GTK_GRID(grid), BTN(Y, X), X, Y, 1, 1); \
} G_STMT_END
static GtkWidget *
@@ -339,16 +335,17 @@ create_main_grid(MqMainMenu *main_menu)
NEW_BTN(2, 1, print, "document-print", "Print");
NEW_BTN(2, 2, inspector, "preferences-system", "Inspector");
- gtk_widget_set_sensitive(buttons[1 * BUTTON_COLS + 2], FALSE);
+ gtk_widget_set_sensitive(BTN(1, 2), FALSE);
- gtk_widget_set_sensitive(buttons[2 * BUTTON_COLS + 0], FALSE);
- gtk_widget_set_sensitive(buttons[2 * BUTTON_COLS + 1], FALSE);
+ gtk_widget_set_sensitive(BTN(2, 0), FALSE);
+ gtk_widget_set_sensitive(BTN(2, 1), FALSE);
return grid;
}
#undef BUTTON_ROWS
#undef BUTTON_COLS
+#undef BTN
#undef NEW_BTN
#define NEW_BUTTON(ID, ICON, LABEL, TOOLTIP) \