summaryrefslogtreecommitdiff
path: root/openbox/prompt.c
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2008-02-22 12:31:26 -0500
committerDana Jansens <danakj@orodu.net>2008-02-22 12:31:26 -0500
commit97de73776708d7c75b42c8fcf33342541d721c83 (patch)
treeffeaae16ca8c9e248062cb04a3266964735c4488 /openbox/prompt.c
parent198d98986bdf224ed29361541d19841339953088 (diff)
parentd9e6aa5643e74ab84fde0ddb1fcb8418ff212281 (diff)
Merge branch 'backport' into work
Conflicts: openbox/menuframe.c openbox/prompt.c openbox/prop.c openbox/prop.h
Diffstat (limited to 'openbox/prompt.c')
-rw-r--r--openbox/prompt.c33
1 files changed, 30 insertions, 3 deletions
diff --git a/openbox/prompt.c b/openbox/prompt.c
index df36c8c3..9e91d249 100644
--- a/openbox/prompt.c
+++ b/openbox/prompt.c
@@ -20,6 +20,7 @@
#include "openbox.h"
#include "screen.h"
#include "client.h"
+#include "group.h"
#include "event.h"
#include "obt/display.h"
#include "obt/keyboard.h"
@@ -433,7 +434,7 @@ static void render_all(ObPrompt *self)
render_button(self, &self->button[i]);
}
-void prompt_show(ObPrompt *self, ObClient *parent)
+void prompt_show(ObPrompt *self, ObClient *parent, gboolean modal)
{
gint i;
@@ -455,8 +456,34 @@ void prompt_show(ObPrompt *self, ObClient *parent)
break;
}
- XSetTransientForHint(obt_display, self->super.window,
- (parent ? parent->window : 0));
+ if (parent) {
+ Atom states[1];
+ gint nstates;
+ Window p;
+ XWMHints h;
+
+ if (parent->group) {
+ /* make it transient for the window's group */
+ h.flags = WindowGroupHint;
+ h.window_group = parent->group->leader;
+ p = obt_root(ob_screen);
+ }
+ else {
+ /* make it transient for the window directly */
+ h.flags = 0;
+ p = parent->window;
+ }
+
+ XSetWMHints(obt_display, self->super.window, &h);
+ OBT_PROP_SET32(self->super.window, WM_TRANSIENT_FOR, WINDOW, p);
+
+ states[0] = OBT_PROP_ATOM(NET_WM_STATE_MODAL);
+ nstates = (modal ? 1 : 0);
+ OBT_PROP_SETA32(self->super.window, NET_WM_STATE, ATOM,
+ states, nstates);
+ }
+ else
+ OBT_PROP_ERASE(self->super.window, WM_TRANSIENT_FOR);
/* set up the dialog and render it */
prompt_layout(self);