mirror of
https://git.suckless.org/dwm
synced 2025-01-13 20:37:27 -08:00
added dev.c instead of kb.c
This commit is contained in:
parent
3f942f9e79
commit
44f2e8b952
5 changed files with 57 additions and 66 deletions
2
Makefile
2
Makefile
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
include config.mk
|
include config.mk
|
||||||
|
|
||||||
SRC = client.c draw.c event.c kb.c mouse.c util.c wm.c
|
SRC = client.c dev.c draw.c event.c util.c wm.c
|
||||||
OBJ = ${SRC:.c=.o}
|
OBJ = ${SRC:.c=.o}
|
||||||
MAN1 = dwm.1
|
MAN1 = dwm.1
|
||||||
BIN = dwm
|
BIN = dwm
|
||||||
|
|
2
README
2
README
|
@ -37,4 +37,4 @@ This will start dwm on display :1 of the host foo.bar.
|
||||||
Configuration
|
Configuration
|
||||||
-------------
|
-------------
|
||||||
The configuration of dwm is done by customizing the wm.h source file. To
|
The configuration of dwm is done by customizing the wm.h source file. To
|
||||||
customize the key bindings edit kb.c.
|
customize the key bindings edit dev.c.
|
||||||
|
|
|
@ -3,11 +3,64 @@
|
||||||
* See LICENSE file for license details.
|
* See LICENSE file for license details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "wm.h"
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <X11/keysym.h>
|
||||||
|
|
||||||
#include "wm.h"
|
/********** CUSTOMIZE **********/
|
||||||
|
|
||||||
|
const char *term[] = {
|
||||||
|
"aterm", "-tr", "+sb", "-bg", "black", "-fg", "white", "-fn",
|
||||||
|
"-*-terminus-medium-*-*-*-13-*-*-*-*-*-iso10646-*",NULL
|
||||||
|
};
|
||||||
|
const char *browse[] = { "firefox", NULL };
|
||||||
|
|
||||||
|
static Key key[] = {
|
||||||
|
{ Mod1Mask, XK_Return, (void (*)(void *))spawn, term },
|
||||||
|
{ Mod1Mask, XK_w, (void (*)(void *))spawn, browse },
|
||||||
|
{ Mod1Mask, XK_k, sel, "prev" },
|
||||||
|
{ Mod1Mask, XK_j, sel, "next" },
|
||||||
|
{ Mod1Mask, XK_space, toggle, NULL },
|
||||||
|
{ Mod1Mask, XK_m, max, NULL },
|
||||||
|
{ Mod1Mask | ShiftMask, XK_c, ckill, NULL },
|
||||||
|
{ Mod1Mask | ShiftMask, XK_q, quit, NULL },
|
||||||
|
};
|
||||||
|
|
||||||
|
/********** CUSTOMIZE **********/
|
||||||
|
|
||||||
|
void
|
||||||
|
update_keys(void)
|
||||||
|
{
|
||||||
|
unsigned int i, len;
|
||||||
|
KeyCode code;
|
||||||
|
|
||||||
|
len = sizeof(key) / sizeof(key[0]);
|
||||||
|
for(i = 0; i < len; i++) {
|
||||||
|
code = XKeysymToKeycode(dpy, key[i].keysym);
|
||||||
|
XUngrabKey(dpy, code, key[i].mod, root);
|
||||||
|
XGrabKey(dpy, code, key[i].mod, root, True, GrabModeAsync, GrabModeAsync);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
keypress(XEvent *e)
|
||||||
|
{
|
||||||
|
XKeyEvent *ev = &e->xkey;
|
||||||
|
unsigned int i, len;
|
||||||
|
KeySym keysym;
|
||||||
|
|
||||||
|
keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0);
|
||||||
|
len = sizeof(key) / sizeof(key[0]);
|
||||||
|
for(i = 0; i < len; i++)
|
||||||
|
if((keysym == key[i].keysym) && (key[i].mod == ev->state)) {
|
||||||
|
if(key[i].func)
|
||||||
|
key[i].func(key[i].aux);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#define ButtonMask (ButtonPressMask | ButtonReleaseMask)
|
#define ButtonMask (ButtonPressMask | ButtonReleaseMask)
|
||||||
#define MouseMask (ButtonMask | PointerMotionMask)
|
#define MouseMask (ButtonMask | PointerMotionMask)
|
60
kb.c
60
kb.c
|
@ -1,60 +0,0 @@
|
||||||
/*
|
|
||||||
* (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
|
|
||||||
* See LICENSE file for license details.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "wm.h"
|
|
||||||
|
|
||||||
#include <X11/keysym.h>
|
|
||||||
|
|
||||||
/********** CUSTOMIZE **********/
|
|
||||||
|
|
||||||
const char *term[] = {
|
|
||||||
"aterm", "-tr", "+sb", "-bg", "black", "-fg", "white", "-fn",
|
|
||||||
"-*-terminus-medium-*-*-*-13-*-*-*-*-*-iso10646-*",NULL
|
|
||||||
};
|
|
||||||
const char *browse[] = { "firefox", NULL };
|
|
||||||
|
|
||||||
static Key key[] = {
|
|
||||||
{ Mod1Mask, XK_Return, (void (*)(void *))spawn, term },
|
|
||||||
{ Mod1Mask, XK_w, (void (*)(void *))spawn, browse },
|
|
||||||
{ Mod1Mask, XK_k, sel, "prev" },
|
|
||||||
{ Mod1Mask, XK_j, sel, "next" },
|
|
||||||
{ Mod1Mask, XK_space, toggle, NULL },
|
|
||||||
{ Mod1Mask, XK_m, max, NULL },
|
|
||||||
{ Mod1Mask | ShiftMask, XK_c, ckill, NULL },
|
|
||||||
{ Mod1Mask | ShiftMask, XK_q, quit, NULL },
|
|
||||||
};
|
|
||||||
|
|
||||||
/********** CUSTOMIZE **********/
|
|
||||||
|
|
||||||
void
|
|
||||||
update_keys(void)
|
|
||||||
{
|
|
||||||
unsigned int i, len;
|
|
||||||
KeyCode code;
|
|
||||||
|
|
||||||
len = sizeof(key) / sizeof(key[0]);
|
|
||||||
for(i = 0; i < len; i++) {
|
|
||||||
code = XKeysymToKeycode(dpy, key[i].keysym);
|
|
||||||
XUngrabKey(dpy, code, key[i].mod, root);
|
|
||||||
XGrabKey(dpy, code, key[i].mod, root, True, GrabModeAsync, GrabModeAsync);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
keypress(XEvent *e)
|
|
||||||
{
|
|
||||||
XKeyEvent *ev = &e->xkey;
|
|
||||||
unsigned int i, len;
|
|
||||||
KeySym keysym;
|
|
||||||
|
|
||||||
keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0);
|
|
||||||
len = sizeof(key) / sizeof(key[0]);
|
|
||||||
for(i = 0; i < len; i++)
|
|
||||||
if((keysym == key[i].keysym) && (key[i].mod == ev->state)) {
|
|
||||||
if(key[i].func)
|
|
||||||
key[i].func(key[i].aux);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
4
wm.h
4
wm.h
|
@ -115,11 +115,9 @@ extern unsigned int texth(Fnt *font);
|
||||||
/* event.c */
|
/* event.c */
|
||||||
extern void discard_events(long even_mask);
|
extern void discard_events(long even_mask);
|
||||||
|
|
||||||
/* kb.c */
|
/* dev.c */
|
||||||
extern void update_keys(void);
|
extern void update_keys(void);
|
||||||
extern void keypress(XEvent *e);
|
extern void keypress(XEvent *e);
|
||||||
|
|
||||||
/* mouse.c */
|
|
||||||
extern void mresize(Client *c);
|
extern void mresize(Client *c);
|
||||||
extern void mmove(Client *c);
|
extern void mmove(Client *c);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue