X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/2c34878904d76d323b4698fe705c5f9d002e65f8..2d504956e1c3612ed62f16a05fd504b5998e6759:/disobedience/menu.c diff --git a/disobedience/menu.c b/disobedience/menu.c index ad79a92..fcf9e9f 100644 --- a/disobedience/menu.c +++ b/disobedience/menu.c @@ -1,6 +1,6 @@ /* * This file is part of DisOrder. - * Copyright (C) 2006 Richard Kettlewell + * Copyright (C) 2006, 2007 Richard Kettlewell * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -26,6 +26,9 @@ static GtkWidget *selectall_widget; static GtkWidget *properties_widget; +/** @brief Main menu widgets */ +GtkItemFactory *mainmenufactory; + static void about_popup_got_version(void *v, const char *value); /** @brief Called when the quit option is activated @@ -69,6 +72,13 @@ static void properties_item(gpointer attribute((unused)) callback_data, t->properties_activate(tab); } +/** @brief Called when the login option is activated */ +static void login(gpointer attribute((unused)) callback_data, + guint attribute((unused)) callback_action, + GtkWidget attribute((unused)) *menu_item) { + login_box(); +} + /** @brief Update menu state * * Determines option sensitivity according to the current tab and adjusts the @@ -129,38 +139,117 @@ static void about_popup_got_version(void attribute((unused)) *v, /** @brief Create the menu bar widget */ GtkWidget *menubar(GtkWidget *w) { static const GtkItemFactoryEntry entries[] = { - { (char *)"/File", 0, 0, 0, (char *)"", 0 }, - { (char *)"/File/Quit Disobedience", (char *)"Q", quit_program, 0, - (char *)"", GTK_STOCK_QUIT }, - { (char *)"/Edit", 0, 0, 0, (char *)"", 0 }, - { (char *)"/Edit/Select all tracks", (char *)"A", select_all, 0, - 0, 0 }, - { (char *)"/Edit/Track properties", 0, properties_item, 0, - 0, 0 }, - { (char *)"/Help", 0, 0, 0, (char *)"", 0 }, - { (char *)"/Help/About DisOrder", 0, about_popup, 0, - (char *)"", GTK_STOCK_ABOUT }, + { + (char *)"/File", /* path */ + 0, /* accelerator */ + 0, /* callback */ + 0, /* callback_action */ + (char *)"", /* item_type */ + 0 /* extra_data */ + }, + { + (char *)"/File/Login", /* path */ + (char *)"L", /* accelerator */ + login, /* callback */ + 0, /* callback_action */ + 0, /* item_type */ + 0 /* extra_data */ + }, + { + (char *)"/File/Quit Disobedience", /* path */ + (char *)"Q", /* accelerator */ + quit_program, /* callback */ + 0, /* callback_action */ + (char *)"", /* item_type */ + GTK_STOCK_QUIT /* extra_data */ + }, + + { + (char *)"/Edit", /* path */ + 0, /* accelerator */ + 0, /* callback */ + 0, /* callback_action */ + (char *)"", /* item_type */ + 0 /* extra_data */ + }, + { + (char *)"/Edit/Select all tracks", /* path */ + (char *)"A", /* accelerator */ + select_all, /* callback */ + 0, /* callback_action */ + 0, /* item_type */ + 0 /* extra_data */ + }, + { + (char *)"/Edit/Track properties", /* path */ + 0, /* accelerator */ + properties_item, /* callback */ + 0, /* callback_action */ + 0, /* item_type */ + 0 /* extra_data */ + }, + + { + (char *)"/Control", /* path */ + 0, /* accelerator */ + 0, /* callback */ + 0, /* callback_action */ + (char *)"", /* item_type */ + 0 /* extra_data */ + }, + { + (char *)"/Control/Scratch", /* path */ + (char *)"S", /* accelerator */ + 0, /* callback */ + 0, /* callback_action */ + 0, /* item_type */ + 0 /* extra_data */ + }, + { + (char *)"/Control/Random play", /* path */ + (char *)"R", /* accelerator */ + 0, /* callback */ + 0, /* callback_action */ + (char *)"", /* item_type */ + 0 /* extra_data */ + }, + + { + (char *)"/Help", /* path */ + 0, /* accelerator */ + 0, /* callback */ + 0, /* callback_action */ + (char *)"", /* item_type */ + 0 /* extra_data */ + }, + { + (char *)"/Help/About DisOrder", /* path */ + 0, /* accelerator */ + about_popup, /* callback */ + 0, /* callback_action */ + (char *)"", /* item_type */ + GTK_STOCK_ABOUT /* extra_data */ + }, }; - GtkItemFactory *itemfactory; GtkAccelGroup *accel = gtk_accel_group_new(); D(("add_menubar")); /* TODO: item factories are deprecated in favour of some XML thing */ - itemfactory = gtk_item_factory_new(GTK_TYPE_MENU_BAR, "", - accel); - gtk_item_factory_create_items(itemfactory, + mainmenufactory = gtk_item_factory_new(GTK_TYPE_MENU_BAR, "", + accel); + gtk_item_factory_create_items(mainmenufactory, sizeof entries / sizeof *entries, (GtkItemFactoryEntry *)entries, 0); gtk_window_add_accel_group(GTK_WINDOW(w), accel); - selectall_widget = gtk_item_factory_get_widget(itemfactory, + selectall_widget = gtk_item_factory_get_widget(mainmenufactory, "/Edit/Select all tracks"); - properties_widget = gtk_item_factory_get_widget(itemfactory, + properties_widget = gtk_item_factory_get_widget(mainmenufactory, "/Edit/Track properties"); assert(selectall_widget != 0); assert(properties_widget != 0); - return gtk_item_factory_get_widget(itemfactory, + return gtk_item_factory_get_widget(mainmenufactory, ""); /* menu bar had better not expand vertically if the window is too big */ }