X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fwindow.c;h=c5e6a4ea9c81eb63e89e1806b1ea690c5dc2cbe6;hb=12ca673de556b341588a7f67fb2b9417c1e91d6b;hp=15cebcd746e430e3721e2f546af50d2a0aeed86d;hpb=2477a38d2f3063b697e44bf3690cf280fb26ca8a;p=chaz%2Fopenbox diff --git a/openbox/window.c b/openbox/window.c index 15cebcd7..c5e6a4ea 100644 --- a/openbox/window.c +++ b/openbox/window.c @@ -1,5 +1,23 @@ +/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*- + + window.c for the Openbox window manager + Copyright (c) 2003-2007 Dana Jansens + + 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 + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + See the COPYING file for a copy of the GNU General Public License. +*/ + #include "window.h" -#include "menu.h" +#include "menuframe.h" #include "config.h" #include "dock.h" #include "client.h" @@ -7,13 +25,21 @@ GHashTable *window_map; -void window_startup() +static guint window_hash(Window *w) { return *w; } +static gboolean window_comp(Window *w1, Window *w2) { return *w1 == *w2; } + +void window_startup(gboolean reconfig) { - window_map = g_hash_table_new(g_int_hash, g_int_equal); + if (reconfig) return; + + window_map = g_hash_table_new((GHashFunc)window_hash, + (GEqualFunc)window_comp); } -void window_shutdown() +void window_shutdown(gboolean reconfig) { + if (reconfig) return; + g_hash_table_destroy(window_map); } @@ -21,9 +47,9 @@ Window window_top(ObWindow *self) { switch (self->type) { case Window_Menu: - return ((Menu*)self)->frame; + return ((ObMenuFrame*)self)->window; case Window_Dock: - return ((Dock*)self)->frame; + return ((ObDock*)self)->frame; case Window_DockApp: /* not to be used for stacking */ g_assert_not_reached(); @@ -37,11 +63,11 @@ Window window_top(ObWindow *self) return None; } -Window window_layer(ObWindow *self) +ObStackingLayer window_layer(ObWindow *self) { switch (self->type) { case Window_Menu: - return Layer_Internal; + return OB_STACKING_LAYER_INTERNAL; case Window_Dock: return config_dock_layer; case Window_DockApp: @@ -51,7 +77,7 @@ Window window_layer(ObWindow *self) case Window_Client: return ((ObClient*)self)->layer; case Window_Internal: - return Layer_Internal; + return OB_STACKING_LAYER_INTERNAL; } g_assert_not_reached(); return None;