summaryrefslogtreecommitdiff
path: root/src/keybindings.c
diff options
context:
space:
mode:
authorDeepa Natarajan <deepa.natarajan@wipro.com>2002-08-21 06:47:16 +0000
committerDeepa Natarajan <deepa@src.gnome.org>2002-08-21 06:47:16 +0000
commitc39a03ad5992246e35a219a0c81254da9199c9ac (patch)
tree11faf7f96ea8cb347897720764c7b34808201a2e /src/keybindings.c
parent0ac034ad4c58b19e4fd28c82ec52b5d68d534ae6 (diff)
downloadmetacity-c39a03ad5992246e35a219a0c81254da9199c9ac.tar.gz
add maximize and unmaximize keybinding setting. Partly fixes bug# 78999.
2002-08-21 Deepa Natarajan <deepa.natarajan@wipro.com> * src/keybindings.c, src/metacity.schemas.in, src/prefs.[ch]: add maximize and unmaximize keybinding setting. Partly fixes bug# 78999.
Diffstat (limited to 'src/keybindings.c')
-rw-r--r--src/keybindings.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/keybindings.c b/src/keybindings.c
index 6eaaefdf..f46ec266 100644
--- a/src/keybindings.c
+++ b/src/keybindings.c
@@ -66,6 +66,14 @@ static void handle_toggle_maximize (MetaDisplay *display,
MetaWindow *window,
XEvent *event,
MetaKeyBinding *binding);
+static void handle_maximize (MetaDisplay *display,
+ MetaWindow *window,
+ XEvent *event,
+ MetaKeyBinding *binding);
+static void handle_unmaximize (MetaDisplay *display,
+ MetaWindow *window,
+ XEvent *event,
+ MetaKeyBinding *binding);
static void handle_toggle_shade (MetaDisplay *display,
MetaWindow *window,
XEvent *event,
@@ -233,6 +241,8 @@ static const MetaKeyHandler window_handlers[] = {
{ META_KEYBINDING_WINDOW_MENU, handle_activate_menu, NULL },
{ META_KEYBINDING_TOGGLE_FULLSCREEN, handle_toggle_fullscreen, NULL },
{ META_KEYBINDING_TOGGLE_MAXIMIZE, handle_toggle_maximize, NULL },
+ { META_KEYBINDING_MAXIMIZE, handle_maximize, NULL },
+ { META_KEYBINDING_UNMAXIMIZE, handle_unmaximize, NULL },
{ META_KEYBINDING_TOGGLE_SHADE, handle_toggle_shade, NULL },
{ META_KEYBINDING_CLOSE, handle_close_window, NULL },
{ META_KEYBINDING_MINIMIZE, handle_minimize_window, NULL },
@@ -2446,6 +2456,32 @@ handle_toggle_maximize (MetaDisplay *display,
}
static void
+handle_maximize (MetaDisplay *display,
+ MetaWindow *window,
+ XEvent *event,
+ MetaKeyBinding *binding)
+{
+ if (window)
+ {
+ if (window->has_maximize_func)
+ meta_window_maximize (window);
+ }
+}
+
+static void
+handle_unmaximize (MetaDisplay *display,
+ MetaWindow *window,
+ XEvent *event,
+ MetaKeyBinding *binding)
+{
+ if (window)
+ {
+ if (window->maximized)
+ meta_window_unmaximize (window);
+ }
+}
+
+static void
handle_toggle_shade (MetaDisplay *display,
MetaWindow *window,
XEvent *event,