diff options
| -rw-r--r-- | config.h | 8 | ||||
| -rw-r--r-- | dwl.c | 11 | 
2 files changed, 17 insertions, 2 deletions
| @@ -8,9 +8,13 @@ static const struct xkb_rule_names xkb_rules = {  #define MODKEY WLR_MODIFIER_ALT +/* commands */ +static const char *termcmd[]  = { "kitty", "-o", "linux_display_server=wayland", NULL }; +  static const Key keys[] = { -	{ MODKEY, XKB_KEY_Escape, quit,      {0} }, -	{ MODKEY, XKB_KEY_F1,     focusnext, {0} }, +	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_Return, spawn,     {.v = termcmd } }, +	{ MODKEY,                    XKB_KEY_Escape, quit,      {0} }, +	{ MODKEY,                    XKB_KEY_F1,     focusnext, {0} },  };  static const Button buttons[] = { @@ -125,6 +125,7 @@ static void focusnext(struct dwl_server *, const Arg *);  static void movemouse(struct dwl_server *, const Arg *);  static void quit(struct dwl_server *, const Arg *);  static void resizemouse(struct dwl_server *, const Arg *); +static void spawn(struct dwl_server *, const Arg *);  #include "config.h" @@ -187,6 +188,16 @@ static void quit(struct dwl_server *server, const Arg *unused) {  	wl_display_terminate(server->wl_display);  } +static void spawn(struct dwl_server *server, const Arg *arg) { +	if (fork() == 0) { +		setsid(); +		execvp(((char **)arg->v)[0], (char **)arg->v); +		fprintf(stderr, "dwl: execvp %s", ((char **)arg->v)[0]); +		perror(" failed"); +		exit(EXIT_FAILURE); +	} +} +  static void focusnext(struct dwl_server *server, const Arg *unused) {  	/* Cycle to the next view */  	if (wl_list_length(&server->views) < 2) { | 
