X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;ds=sidebyside;f=plugins%2Fmenu%2Fclient_menu.c;h=d4c94aad4674a106fe473bde610500abe345b63d;hb=4736c257a54409bf3b0ef0d803da650c71684dee;hp=230012d79a91ff7dcaffbb70f5eceda571b339df;hpb=f249e01616f6b18dc56a4367ecdf22698476bfbf;p=chaz%2Fopenbox diff --git a/plugins/menu/client_menu.c b/plugins/menu/client_menu.c index 230012d7..d4c94aad 100644 --- a/plugins/menu/client_menu.c +++ b/plugins/menu/client_menu.c @@ -9,52 +9,72 @@ #include "render/theme.h" +#if 0 static char *PLUGIN_NAME = "client_menu"; +#endif static Menu *send_to_menu; static Menu *layer_menu; typedef struct { - + gint foo; } Client_Menu_Data; #define CLIENT_MENU(m) ((Menu *)m) #define CLIENT_MENU_DATA(m) ((Client_Menu_Data *)((Menu *)m)->plugin_data) - void client_menu_clean_up(Menu *m) { } void client_send_to_update(Menu *self) { - guint i; + guint i = 0; + GList *it = self->entries; - for (i = 0; i < screen_num_desktops; ++i) { - MenuEntry *e; - Action *a = action_from_string("sendtodesktop"); - a->data.sendto.desk = i; - a->data.sendto.follow = FALSE; - e = menu_entry_new(screen_desktop_names[i], a); - menu_add_entry(self, e); + /* check if we have to update. lame */ + while (it != NULL) { + if (i >= screen_num_desktops) + break; + if (strcmp(screen_desktop_names[i], + ((MenuEntry *)it->data)->label) != 0) + break; + ++i; + it = it->next; } - menu_render_full(self); + if (it != NULL || i != screen_num_desktops) { + menu_clear(self); + g_message("update"); + for (i = 0; i < screen_num_desktops; ++i) { + MenuEntry *e; + Action *a = action_from_string("sendtodesktop"); + a->data.sendto.desk = i; + a->data.sendto.follow = FALSE; + e = menu_entry_new(screen_desktop_names[i], a); + menu_add_entry(self, e); + } + + menu_render_full(self); + } } +#if 0 void client_menu_show(Menu *self, int x, int y, Client *client) { int newy; g_assert(!self->invalid); g_assert(client); - newy = client->frame->area.y + client->frame->a_focused_title->area.height - + theme_bwidth; + newy = MAX(client->frame->area.y + client->frame->size.top, y); + newy -= ob_rr_theme->bwidth; + /* XXX do xinerama shit like in menu.c! im not coding it now because + this function isnt even being used right now... */ POINT_SET(self->location, MIN(x, screen_physical_size.width - self->size.width - - theme_bwidth * 2), + ob_rr_theme->bwidth * 2), MIN(newy, screen_physical_size.height - self->size.height - - theme_bwidth * 2)); + ob_rr_theme->bwidth * 2)); XMoveWindow(ob_display, self->frame, self->location.x, self->location.y); if (!self->shown) { @@ -65,6 +85,7 @@ void client_menu_show(Menu *self, int x, int y, Client *client) menu_hide(self->open_submenu); } } +#endif void plugin_setup_config() { } @@ -77,7 +98,7 @@ void plugin_destroy (Menu *m) void *plugin_create() /* TODO: need config */ { Menu *m = menu_new_full(NULL, "client-menu", NULL, - client_menu_show, NULL); + /*client_menu_show*/NULL, NULL); menu_add_entry(m, menu_entry_new_submenu("Send To Workspace", send_to_menu)); send_to_menu->parent = m; @@ -94,6 +115,8 @@ void *plugin_create() /* TODO: need config */ action_from_string("toggleshade"))); menu_add_entry(m, menu_entry_new("Omnipresent", action_from_string("toggleomnipresent"))); + menu_add_entry(m, menu_entry_new("Decorations", + action_from_string("toggledecorations"))); menu_add_entry(m, menu_entry_new_submenu("Layers", layer_menu)); layer_menu->parent = m;