diff options
author | Owain Ainsworth <oga@cvs.openbsd.org> | 2007-11-07 21:58:04 +0000 |
---|---|---|
committer | Owain Ainsworth <oga@cvs.openbsd.org> | 2007-11-07 21:58:04 +0000 |
commit | 379780af0474330adc114ff8f8a187ba946d4bb7 (patch) | |
tree | 011d96f1586cc43ee45b7c5df1a5e291720f40a0 /app | |
parent | 4d85406f294e338756cc783a988255193db34c89 (diff) |
Add support to cwm for resizing the windows using Control-Meta-[hjkl].
Please note that this remaps Control-Meta-L (label) to Control-Meta-N (name).
ok jasper@, todd@.
Diffstat (limited to 'app')
-rw-r--r-- | app/cwm/calmwm.h | 3 | ||||
-rw-r--r-- | app/cwm/conf.c | 30 | ||||
-rw-r--r-- | app/cwm/cwm.1 | 10 | ||||
-rw-r--r-- | app/cwm/kbfunc.c | 47 |
4 files changed, 82 insertions, 8 deletions
diff --git a/app/cwm/calmwm.h b/app/cwm/calmwm.h index 7d15b82c6..73828354c 100644 --- a/app/cwm/calmwm.h +++ b/app/cwm/calmwm.h @@ -4,7 +4,7 @@ * Copyright (c) 2004 Marius Aamodt Eriksen <marius@monkey.org> * All rights reserved. * - * $Id: calmwm.h,v 1.8 2007/06/27 13:28:22 todd Exp $ + * $Id: calmwm.h,v 1.9 2007/11/07 21:58:03 oga Exp $ */ #ifndef _CALMWM_H_ @@ -432,6 +432,7 @@ void kbfunc_client_nogroup(struct client_ctx *, void *); void kbfunc_client_maximize(struct client_ctx *, void *); void kbfunc_client_vmaximize(struct client_ctx *, void *); void kbfunc_client_move(struct client_ctx *, void *); +void kbfunc_client_resize(struct client_ctx *, void *); void kbfunc_menu_search(struct client_ctx *, void *); void kbfunc_exec(struct client_ctx *, void *); void kbfunc_ssh(struct client_ctx *, void *); diff --git a/app/cwm/conf.c b/app/cwm/conf.c index 05bc9d2f1..044d204f6 100644 --- a/app/cwm/conf.c +++ b/app/cwm/conf.c @@ -4,7 +4,7 @@ * Copyright (c) 2004 Marius Aamodt Eriksen <marius@monkey.org> * All rights reserved. * - * $Id: conf.c,v 1.8 2007/06/27 13:28:22 todd Exp $ + * $Id: conf.c,v 1.9 2007/11/07 21:58:03 oga Exp $ */ #include "headers.h" @@ -204,7 +204,7 @@ conf_setup(struct conf *c) XK_Tab, Mod1Mask, 0, 0); conf_bindkey(c, kbfunc_client_rcycle, XK_Tab, Mod1Mask|ShiftMask, 0, 0); - conf_bindkey(c, kbfunc_client_label, XK_l, + conf_bindkey(c, kbfunc_client_label, XK_n, ControlMask|Mod1Mask, KBFLAG_NEEDCLIENT, 0); conf_bindkey(c, kbfunc_client_delete, XK_x, ControlMask|Mod1Mask, KBFLAG_NEEDCLIENT, 0); @@ -258,7 +258,31 @@ conf_setup(struct conf *c) conf_bindkey(c, kbfunc_client_move, XK_H, Mod1Mask, KBFLAG_NEEDCLIENT, (void *)(CWM_LEFT|CWM_BIGMOVE)); - } + conf_bindkey(c, kbfunc_client_resize, + XK_k, ControlMask|Mod1Mask, + KBFLAG_NEEDCLIENT, (void *)CWM_UP); + conf_bindkey(c, kbfunc_client_resize, + XK_j, ControlMask|Mod1Mask, + KBFLAG_NEEDCLIENT, (void *)CWM_DOWN); + conf_bindkey(c, kbfunc_client_resize, + XK_l, ControlMask|Mod1Mask, + KBFLAG_NEEDCLIENT, (void *)CWM_RIGHT); + conf_bindkey(c, kbfunc_client_resize, + XK_h, ControlMask|Mod1Mask, + KBFLAG_NEEDCLIENT, (void *)CWM_LEFT); + conf_bindkey(c, kbfunc_client_resize, + XK_K, ControlMask|Mod1Mask, KBFLAG_NEEDCLIENT, + (void *)(CWM_UP|CWM_BIGMOVE)); + conf_bindkey(c, kbfunc_client_resize, + XK_J, ControlMask|Mod1Mask, KBFLAG_NEEDCLIENT, + (void *)(CWM_DOWN|CWM_BIGMOVE)); + conf_bindkey(c, kbfunc_client_resize, + XK_L, ControlMask|Mod1Mask, KBFLAG_NEEDCLIENT, + (void *)(CWM_RIGHT|CWM_BIGMOVE)); + conf_bindkey(c, kbfunc_client_resize, + XK_H, ControlMask|Mod1Mask, KBFLAG_NEEDCLIENT, + (void *)(CWM_LEFT|CWM_BIGMOVE)); + } snprintf(dir_settings, sizeof(dir_settings), "%s/.calmwm/.settings", home); diff --git a/app/cwm/cwm.1 b/app/cwm/cwm.1 index 82650a034..13baa7867 100644 --- a/app/cwm/cwm.1 +++ b/app/cwm/cwm.1 @@ -1,4 +1,4 @@ -.\" $OpenBSD: cwm.1,v 1.10 2007/10/07 16:56:21 ian Exp $ +.\" $OpenBSD: cwm.1,v 1.11 2007/11/07 21:58:03 oga Exp $ .\" .\" The following requests are required for all man pages. .Dd June 29, 2007 @@ -63,7 +63,7 @@ Raise current window. Search for windows. .It Ic C-/ Search for applications. -.It Ic C-M-l +.It Ic C-M-n Label current window. .It Ic M-Tab Cycle through currently visible windows. @@ -133,13 +133,17 @@ The default behavior for new windows is to not assign any group. This changes the default behavior to assigning the currrently selected group to any newly created windows. .El -.Sh WINDOW MOVEMENT +.Sh WINDOW MOVEMENT AND RESIZING .Nm windows can be moved with the use of the keyboard through Vi-like bindings. M-[hjkl] moves the current window a small amount, while M-shift-[hjkl] moves the current window a larger amount. For example, to move the current window to the left a small amount, press M-h. To move the current window down by a larger amount, press M-shift-j. +.Pp +Similarly, windows may be resized with the same keybindings with the addition +of the Control key. C-M-[hjkl] resizes the window a small amount and C-M-shift-[hjkl] +resizes by a larger increment. .Sh SEARCH .Nm features the ability to search for windows by their current title, diff --git a/app/cwm/kbfunc.c b/app/cwm/kbfunc.c index ca2e13ba5..f784c2614 100644 --- a/app/cwm/kbfunc.c +++ b/app/cwm/kbfunc.c @@ -4,7 +4,7 @@ * Copyright (c) 2004 Martin Murray <mmurray@monkey.org> * All rights reserved. * - * $Id: kbfunc.c,v 1.7 2007/09/06 06:01:14 jasper Exp $ + * $Id: kbfunc.c,v 1.8 2007/11/07 21:58:03 oga Exp $ */ #include <paths.h> @@ -67,6 +67,51 @@ kbfunc_client_move(struct client_ctx *cc, void *arg) cc->ptr.x = x + mx; client_ptrwarp(cc); } + +void +kbfunc_client_resize(struct client_ctx *cc, void *arg) +{ + int flags,mx,my; + u_int amt; + + mx = my = 0; + + flags = (int)arg; + amt = MOVE_AMOUNT; + + if (flags & CWM_BIGMOVE) { + flags -= CWM_BIGMOVE; + amt = amt*10; + } + + switch(flags) { + case CWM_UP: + my -= amt; + break; + case CWM_DOWN: + my += amt; + break; + case CWM_RIGHT: + mx += amt; + break; + case CWM_LEFT: + mx -= amt; + break; + } + + cc->geom.height += my; + cc->geom.width += mx; + client_resize(cc); + + /* + * Moving the cursor while resizing is problematic. Just place + * it in the middle of the window. + */ + cc->ptr.x = -1; + cc->ptr.y = -1; + client_ptrwarp(cc); +} + void kbfunc_client_search(struct client_ctx *scratch, void *arg) { |