14 void process_message(char *msg, char *rsp)
16 char *cmd = strtok(msg, TOK_SEP);
21 if (strcmp(cmd, "get") == 0) {
22 char *name = strtok(NULL, TOK_SEP);
23 get_setting(name, rsp);
25 } else if (strcmp(cmd, "set") == 0) {
26 char *name = strtok(NULL, TOK_SEP);
27 char *value = strtok(NULL, TOK_SEP);
28 set_setting(name, value, rsp);
30 } else if (strcmp(cmd, "list") == 0) {
31 char *name = strtok(NULL, TOK_SEP);
33 desktop_location_t loc;
34 if (locate_desktop(name, &loc))
35 dump_tree(loc.desktop, loc.desktop->root, rsp, 0);
37 dump_tree(mon->desk, mon->desk->root, rsp, 0);
40 } else if (strcmp(cmd, "list_monitors") == 0) {
41 char *arg = strtok(NULL, TOK_SEP);
43 if (parse_list_option(arg, &opt))
44 list_monitors(opt, rsp);
46 } else if (strcmp(cmd, "list_desktops") == 0) {
47 char *arg = strtok(NULL, TOK_SEP);
49 if (parse_list_option(arg, &opt))
50 list_desktops(mon, opt, 0, rsp);
52 } else if (strcmp(cmd, "list_windows") == 0) {
55 } else if (strcmp(cmd, "close") == 0) {
56 window_close(mon->desk->focus);
58 } else if (strcmp(cmd, "kill") == 0) {
59 window_kill(mon->desk, mon->desk->focus);
60 } else if (strcmp(cmd, "rotate") == 0) {
61 char *deg = strtok(NULL, TOK_SEP);
64 if (parse_rotate(deg, &r)) {
65 rotate_tree(mon->desk->root, r);
68 } else if (strcmp(cmd, "layout") == 0) {
69 char *lyt = strtok(NULL, TOK_SEP);
72 if (parse_layout(lyt, &y)) {
73 char *name = strtok(NULL, TOK_SEP);
75 mon->desk->layout = y;
77 desktop_location_t loc;
79 if (locate_desktop(name, &loc))
80 loc.desktop->layout = y;
81 } while ((name = strtok(NULL, TOK_SEP)) != NULL);
86 } else if (strcmp(cmd, "cycle_layout") == 0) {
87 if (mon->desk->layout == LAYOUT_MONOCLE)
88 mon->desk->layout = LAYOUT_TILED;
90 mon->desk->layout = LAYOUT_MONOCLE;
92 } else if (strcmp(cmd, "shift") == 0) {
93 char *dir = strtok(NULL, TOK_SEP);
96 if (parse_direction(dir, &d)) {
97 swap_nodes(mon->desk->focus, find_neighbor(mon->desk->focus, d));
100 } else if (strcmp(cmd, "toggle_fullscreen") == 0) {
101 if (mon->desk->focus != NULL)
102 toggle_fullscreen(mon, mon->desk->focus->client);
103 } else if (strcmp(cmd, "toggle_floating") == 0) {
104 split_mode = MODE_AUTOMATIC;
105 toggle_floating(mon->desk->focus);
106 } else if (strcmp(cmd, "toggle_locked") == 0) {
107 if (mon->desk->focus != NULL)
108 toggle_locked(mon->desk->focus->client);
109 } else if (strcmp(cmd, "pad") == 0) {
110 char *name = strtok(NULL, TOK_SEP);
112 monitor_t *m = find_monitor(name);
114 char args[BUFSIZ] = {0}, *s;
115 while ((s = strtok(NULL, TOK_SEP)) != NULL) {
116 strncat(args, s, REMLEN(args));
117 strncat(args, TOK_SEP, REMLEN(args));
119 if (strlen(args) > 0) {
120 sscanf(args, "%i %i %i %i", &m->top_padding, &m->right_padding, &m->bottom_padding, &m->left_padding);
123 snprintf(rsp, BUFSIZ, "%i %i %i %i\n", m->top_padding, m->right_padding, m->bottom_padding, m->left_padding);
128 } else if (strcmp(cmd, "ratio") == 0) {
129 char *value = strtok(NULL, TOK_SEP);
130 if (value != NULL && mon->desk->focus != NULL)
131 sscanf(value, "%lf", &mon->desk->focus->split_ratio);
132 } else if (strcmp(cmd, "cancel") == 0) {
133 split_mode = MODE_AUTOMATIC;
134 window_draw_border(mon->desk->focus, true, true);
136 } else if (strcmp(cmd, "presel") == 0) {
137 if (mon->desk->focus == NULL || !is_tiled(mon->desk->focus->client) || mon->desk->layout != LAYOUT_TILED)
139 char *dir = strtok(NULL, TOK_SEP);
142 if (parse_direction(dir, &d)) {
143 split_mode = MODE_MANUAL;
145 window_draw_border(mon->desk->focus, true, true);
149 } else if (strcmp(cmd, "push") == 0 || strcmp(cmd, "pull") == 0) {
150 char *dir = strtok(NULL, TOK_SEP);
154 if (parse_fence_move(cmd, &m) && parse_direction(dir, &d)) {
155 move_fence(mon->desk->focus, d, m);
158 } else if (strcmp(cmd, "send_to_monitor") == 0) {
159 char *name = strtok(NULL, TOK_SEP);
161 monitor_t *m = find_monitor(name);
162 if (m != NULL && m != mon) {
163 transfer_node(mon, mon->desk, m, m->desk, mon->desk->focus);
167 } else if (strcmp(cmd, "send_to") == 0) {
168 char *name = strtok(NULL, TOK_SEP);
170 desktop_location_t loc;
171 if (locate_desktop(name, &loc)) {
172 transfer_node(mon, mon->desk, loc.monitor, loc.desktop, mon->desk->focus);
173 if (mon != loc.monitor && loc.monitor->desk == loc.desktop)
174 arrange(loc.monitor, loc.desktop);
177 } else if (strcmp(cmd, "rename_monitor") == 0) {
178 char *cur_name = strtok(NULL, TOK_SEP);
179 if (cur_name != NULL) {
180 monitor_t *m = find_monitor(cur_name);
182 char *new_name = strtok(NULL, TOK_SEP);
183 if (new_name != NULL) {
184 strncpy(m->name, new_name, sizeof(m->name));
189 } else if (strcmp(cmd, "rename") == 0) {
190 char *cur_name = strtok(NULL, TOK_SEP);
191 if (cur_name != NULL) {
192 desktop_location_t loc;
193 if (locate_desktop(cur_name, &loc)) {
194 char *new_name = strtok(NULL, TOK_SEP);
195 if (new_name != NULL) {
196 strncpy(loc.desktop->name, new_name, sizeof(loc.desktop->name));
197 ewmh_update_desktop_names();
202 } else if (strcmp(cmd, "use_monitor") == 0) {
203 char *name = strtok(NULL, TOK_SEP);
205 monitor_t *m = find_monitor(name);
209 } else if (strcmp(cmd, "use") == 0) {
210 char *name = strtok(NULL, TOK_SEP);
212 desktop_location_t loc;
213 if (locate_desktop(name, &loc)) {
214 select_monitor(loc.monitor);
215 select_desktop(loc.desktop);
218 } else if (strcmp(cmd, "cycle_monitor") == 0) {
219 char *dir = strtok(NULL, TOK_SEP);
222 if (parse_cycle_direction(dir, &d))
225 } else if (strcmp(cmd, "cycle_desktop") == 0) {
226 char *dir = strtok(NULL, TOK_SEP);
229 if (parse_cycle_direction(dir, &d)) {
231 char *skip = strtok(NULL, TOK_SEP);
232 if (parse_skip_desktop(skip, &k))
233 cycle_desktop(mon, mon->desk, d, k);
236 } else if (strcmp(cmd, "cycle") == 0) {
237 if (mon->desk->focus != NULL && mon->desk->focus->client->fullscreen)
239 char *dir = strtok(NULL, TOK_SEP);
242 if (parse_cycle_direction(dir, &d)) {
244 char *skip = strtok(NULL, TOK_SEP);
245 if (parse_skip_client(skip, &k))
246 cycle_leaf(mon, mon->desk, mon->desk->focus, d, k);
250 } else if (strcmp(cmd, "nearest") == 0) {
251 if (mon->desk->focus != NULL && mon->desk->focus->client->fullscreen)
253 char *arg = strtok(NULL, TOK_SEP);
256 if (parse_nearest_argument(arg, &a)) {
258 char *skip = strtok(NULL, TOK_SEP);
259 if (parse_skip_client(skip, &k))
260 nearest_leaf(mon, mon->desk, mon->desk->focus, a, k);
264 } else if (strcmp(cmd, "circulate") == 0) {
265 if (mon->desk->layout == LAYOUT_MONOCLE
266 || (mon->desk->focus != NULL && !is_tiled(mon->desk->focus->client)))
268 char *dir = strtok(NULL, TOK_SEP);
271 if (parse_circulate_direction(dir, &d))
272 circulate_leaves(mon, mon->desk, d);
274 } else if (strcmp(cmd, "rule") == 0) {
275 char *name = strtok(NULL, TOK_SEP);
277 rule_t *rule = make_rule();
278 strncpy(rule->cause.name, name, sizeof(rule->cause.name));
279 char *arg = strtok(NULL, TOK_SEP);
280 while (arg != NULL) {
281 if (strcmp(arg, "floating") == 0) {
282 rule->effect.floating = true;
284 desktop_location_t loc;
285 if (locate_desktop(arg, &loc)) {
286 rule->effect.monitor = loc.monitor;
287 rule->effect.desktop = loc.desktop;
290 arg = strtok(NULL, TOK_SEP);
292 rule->next = rule_head;
296 } else if (strcmp(cmd, "alternate") == 0) {
297 focus_node(mon, mon->desk, mon->desk->last_focus, true);
299 } else if (strcmp(cmd, "alternate_desktop") == 0) {
300 select_desktop(mon->last_desk);
301 } else if (strcmp(cmd, "alternate_monitor") == 0) {
302 select_monitor(last_mon);
303 } else if (strcmp(cmd, "add_in") == 0) {
304 char *name = strtok(NULL, TOK_SEP);
306 monitor_t *m = find_monitor(name);
308 for (name = strtok(NULL, TOK_SEP); name != NULL; name = strtok(NULL, TOK_SEP))
309 add_desktop(m, name);
312 } else if (strcmp(cmd, "add") == 0) {
313 for (char *name = strtok(NULL, TOK_SEP); name != NULL; name = strtok(NULL, TOK_SEP))
314 add_desktop(mon, name);
316 } else if (strcmp(cmd, "focus") == 0) {
317 if (mon->desk->focus != NULL && mon->desk->focus->client->fullscreen)
319 char *dir = strtok(NULL, TOK_SEP);
322 if (parse_direction(dir, &d)) {
323 node_t *n = find_neighbor(mon->desk->focus, d);
324 focus_node(mon, mon->desk, n, true);
327 if (mon->desk->layout == LAYOUT_TILED)
329 } else if (strcmp(cmd, "adopt_orphans") == 0) {
331 } else if (strcmp(cmd, "reload") == 0) {
334 } else if (strcmp(cmd, "reload_autostart") == 0) {
336 } else if (strcmp(cmd, "reload_settings") == 0) {
338 } else if (strcmp(cmd, "quit") == 0) {
342 snprintf(rsp, BUFSIZ, "unknown command: %s", cmd);
346 arrange(mon, mon->desk);
349 void set_setting(char *name, char *value, char *rsp)
351 if (name == NULL || value == NULL)
354 if (strcmp(name, "inner_border_width") == 0) {
355 sscanf(value, "%u", &inner_border_width);
356 border_width = inner_border_width + main_border_width + outer_border_width;
357 } else if (strcmp(name, "main_border_width") == 0) {
358 sscanf(value, "%u", &main_border_width);
359 border_width = inner_border_width + main_border_width + outer_border_width;
360 } else if (strcmp(name, "outer_border_width") == 0) {
361 sscanf(value, "%u", &outer_border_width);
362 border_width = inner_border_width + main_border_width + outer_border_width;
363 } else if (strcmp(name, "window_gap") == 0) {
364 sscanf(value, "%i", &window_gap);
365 } else if (strcmp(name, "left_padding") == 0) {
366 sscanf(value, "%i", &mon->left_padding);
367 } else if (strcmp(name, "right_padding") == 0) {
368 sscanf(value, "%i", &mon->right_padding);
369 } else if (strcmp(name, "top_padding") == 0) {
370 sscanf(value, "%i", &mon->top_padding);
371 } else if (strcmp(name, "bottom_padding") == 0) {
372 sscanf(value, "%i", &mon->bottom_padding);
373 } else if (strcmp(name, "focused_border_color") == 0) {
374 strncpy(focused_border_color, value, sizeof(focused_border_color));
375 focused_border_color_pxl = get_color(focused_border_color);
376 } else if (strcmp(name, "active_border_color") == 0) {
377 strncpy(active_border_color, value, sizeof(active_border_color));
378 active_border_color_pxl = get_color(active_border_color);
379 } else if (strcmp(name, "normal_border_color") == 0) {
380 strncpy(normal_border_color, value, sizeof(normal_border_color));
381 normal_border_color_pxl = get_color(normal_border_color);
382 } else if (strcmp(name, "inner_border_color") == 0) {
383 strncpy(inner_border_color, value, sizeof(inner_border_color));
384 inner_border_color_pxl = get_color(inner_border_color);
385 } else if (strcmp(name, "outer_border_color") == 0) {
386 strncpy(outer_border_color, value, sizeof(outer_border_color));
387 outer_border_color_pxl = get_color(outer_border_color);
388 } else if (strcmp(name, "presel_border_color") == 0) {
389 strncpy(presel_border_color, value, sizeof(presel_border_color));
390 presel_border_color_pxl = get_color(presel_border_color);
391 } else if (strcmp(name, "focused_locked_border_color") == 0) {
392 strncpy(focused_locked_border_color, value, sizeof(focused_locked_border_color));
393 focused_locked_border_color_pxl = get_color(focused_locked_border_color);
394 } else if (strcmp(name, "active_locked_border_color") == 0) {
395 strncpy(active_locked_border_color, value, sizeof(active_locked_border_color));
396 active_locked_border_color_pxl = get_color(active_locked_border_color);
397 } else if (strcmp(name, "normal_locked_border_color") == 0) {
398 strncpy(normal_locked_border_color, value, sizeof(normal_locked_border_color));
399 normal_locked_border_color_pxl = get_color(normal_locked_border_color);
400 } else if (strcmp(name, "urgent_border_color") == 0) {
401 strncpy(urgent_border_color, value, sizeof(urgent_border_color));
402 urgent_border_color_pxl = get_color(urgent_border_color);
403 } else if (strcmp(name, "borderless_monocle") == 0) {
405 if (parse_bool(value, &b))
406 borderless_monocle = b;
407 } else if (strcmp(name, "gapless_monocle") == 0) {
409 if (parse_bool(value, &b))
411 } else if (strcmp(name, "focus_follows_mouse") == 0) {
413 if (parse_bool(value, &b))
414 focus_follows_mouse = b;
415 } else if (strcmp(name, "adaptative_raise") == 0) {
417 if (parse_bool(value, &b))
418 adaptative_raise = b;
419 } else if (strcmp(name, "status_stdout") == 0) {
421 if (parse_bool(value, &b))
423 } else if (strcmp(name, "wm_name") == 0) {
424 strncpy(wm_name, value, sizeof(wm_name));
425 ewmh_update_wm_name();
427 } else if (strcmp(name, "button_modifier") == 0) {
429 if (parse_modifier_mask(value, &m)) {
435 } else if (strcmp(name, "numlock_modifier") == 0) {
437 if (parse_modifier_mask(value, &m)) {
439 numlock_modifier = m;
443 } else if (strcmp(name, "capslock_modifier") == 0) {
445 if (parse_modifier_mask(value, &m)) {
447 capslock_modifier = m;
452 snprintf(rsp, BUFSIZ, "unknown setting: %s", name);
456 arrange(mon, mon->desk);
459 void get_setting(char *name, char* rsp)
464 if (strcmp(name, "inner_border_width") == 0)
465 snprintf(rsp, BUFSIZ, "%u", inner_border_width);
466 else if (strcmp(name, "main_border_width") == 0)
467 snprintf(rsp, BUFSIZ, "%u", main_border_width);
468 else if (strcmp(name, "outer_border_width") == 0)
469 snprintf(rsp, BUFSIZ, "%u", outer_border_width);
470 else if (strcmp(name, "border_width") == 0)
471 snprintf(rsp, BUFSIZ, "%u", border_width);
472 else if (strcmp(name, "window_gap") == 0)
473 snprintf(rsp, BUFSIZ, "%i", window_gap);
474 else if (strcmp(name, "left_padding") == 0)
475 snprintf(rsp, BUFSIZ, "%i", mon->left_padding);
476 else if (strcmp(name, "right_padding") == 0)
477 snprintf(rsp, BUFSIZ, "%i", mon->right_padding);
478 else if (strcmp(name, "top_padding") == 0)
479 snprintf(rsp, BUFSIZ, "%i", mon->top_padding);
480 else if (strcmp(name, "bottom_padding") == 0)
481 snprintf(rsp, BUFSIZ, "%i", mon->bottom_padding);
482 else if (strcmp(name, "focused_border_color") == 0)
483 snprintf(rsp, BUFSIZ, "%s (%06X)", focused_border_color, focused_border_color_pxl);
484 else if (strcmp(name, "active_border_color") == 0)
485 snprintf(rsp, BUFSIZ, "%s (%06X)", active_border_color, active_border_color_pxl);
486 else if (strcmp(name, "normal_border_color") == 0)
487 snprintf(rsp, BUFSIZ, "%s (%06X)", normal_border_color, normal_border_color_pxl);
488 else if (strcmp(name, "inner_border_color") == 0)
489 snprintf(rsp, BUFSIZ, "%s (%06X)", inner_border_color, inner_border_color_pxl);
490 else if (strcmp(name, "outer_border_color") == 0)
491 snprintf(rsp, BUFSIZ, "%s (%06X)", outer_border_color, outer_border_color_pxl);
492 else if (strcmp(name, "presel_border_color") == 0)
493 snprintf(rsp, BUFSIZ, "%s (%06X)", presel_border_color, presel_border_color_pxl);
494 else if (strcmp(name, "focused_locked_border_color") == 0)
495 snprintf(rsp, BUFSIZ, "%s (%06X)", focused_locked_border_color, focused_locked_border_color_pxl);
496 else if (strcmp(name, "active_locked_border_color") == 0)
497 snprintf(rsp, BUFSIZ, "%s (%06X)", active_locked_border_color, active_locked_border_color_pxl);
498 else if (strcmp(name, "normal_locked_border_color") == 0)
499 snprintf(rsp, BUFSIZ, "%s (%06X)", normal_locked_border_color, normal_locked_border_color_pxl);
500 else if (strcmp(name, "urgent_border_color") == 0)
501 snprintf(rsp, BUFSIZ, "%s (%06X)", urgent_border_color, urgent_border_color_pxl);
502 else if (strcmp(name, "borderless_monocle") == 0)
503 snprintf(rsp, BUFSIZ, "%s", BOOLSTR(borderless_monocle));
504 else if (strcmp(name, "gapless_monocle") == 0)
505 snprintf(rsp, BUFSIZ, "%s", BOOLSTR(gapless_monocle));
506 else if (strcmp(name, "focus_follows_mouse") == 0)
507 snprintf(rsp, BUFSIZ, "%s", BOOLSTR(focus_follows_mouse));
508 else if (strcmp(name, "adaptative_raise") == 0)
509 snprintf(rsp, BUFSIZ, "%s", BOOLSTR(adaptative_raise));
510 else if (strcmp(name, "status_stdout") == 0)
511 snprintf(rsp, BUFSIZ, "%s", BOOLSTR(status_stdout));
512 else if (strcmp(name, "wm_name") == 0)
513 snprintf(rsp, BUFSIZ, "%s", wm_name);
514 else if (strcmp(name, "button_modifier") == 0)
515 print_modifier_mask(rsp, button_modifier);
516 else if (strcmp(name, "numlock_modifier") == 0)
517 print_modifier_mask(rsp, numlock_modifier);
518 else if (strcmp(name, "capslock_modifier") == 0)
519 print_modifier_mask(rsp, capslock_modifier);
521 snprintf(rsp, BUFSIZ, "unknown setting: %s", name);
524 bool parse_bool(char *value, bool *b)
526 if (strcmp(value, "true") == 0) {
529 } else if (strcmp(value, "false") == 0) {
536 bool parse_layout(char *s, layout_t *l)
538 if (strcmp(s, "monocle") == 0) {
541 } else if (strcmp(s, "tiled") == 0) {
548 bool parse_direction(char *s, direction_t *d)
550 if (strcmp(s, "up") == 0) {
553 } else if (strcmp(s, "down") == 0) {
556 } else if (strcmp(s, "left") == 0) {
559 } else if (strcmp(s, "right") == 0) {
566 bool parse_nearest_argument(char *s, nearest_arg_t *a)
568 if (strcmp(s, "older") == 0) {
571 } else if (strcmp(s, "newer") == 0) {
578 bool parse_cycle_direction(char *s, cycle_dir_t *d)
580 if (strcmp(s, "prev") == 0) {
583 } else if (strcmp(s, "next") == 0) {
590 bool parse_circulate_direction(char *s, circulate_dir_t *d)
592 if (strcmp(s, "forward") == 0) {
593 *d = CIRCULATE_FORWARD;
595 } else if (strcmp(s, "backward") == 0) {
596 *d = CIRCULATE_BACKWARD;
602 bool parse_skip_client(char *s, skip_client_t *k)
605 *k = CLIENT_SKIP_NONE;
607 } else if (strcmp(s, "--skip-floating") == 0) {
608 *k = CLIENT_SKIP_FLOATING;
610 } else if (strcmp(s, "--skip-tiled") == 0) {
611 *k = CLIENT_SKIP_TILED;
613 } else if (strcmp(s, "--skip-class-equal") == 0) {
614 *k = CLIENT_SKIP_CLASS_EQUAL;
616 } else if (strcmp(s, "--skip-class-differ") == 0) {
617 *k = CLIENT_SKIP_CLASS_DIFFER;
623 bool parse_skip_desktop(char *s, skip_desktop_t *k)
626 *k = DESKTOP_SKIP_NONE;
628 } else if (strcmp(s, "--skip-free") == 0) {
629 *k = DESKTOP_SKIP_FREE;
631 } else if (strcmp(s, "--skip-occupied") == 0) {
632 *k = DESKTOP_SKIP_OCCUPIED;
638 bool parse_list_option(char *s, list_option_t *o)
640 if (s == NULL || strcmp(s, "--verbose") == 0) {
641 *o = LIST_OPTION_VERBOSE;
643 } else if (strcmp(s, "--quiet") == 0) {
644 *o = LIST_OPTION_QUIET;
650 bool parse_rotate(char *s, rotate_t *r)
652 if (strcmp(s, "clockwise") == 0) {
653 *r = ROTATE_CLOCKWISE;
655 } else if (strcmp(s, "counter_clockwise") == 0) {
656 *r = ROTATE_COUNTER_CLOCKWISE;
658 } else if (strcmp(s, "full_cycle") == 0) {
659 *r = ROTATE_FULL_CYCLE;
665 bool parse_fence_move(char *s, fence_move_t *m)
667 if (strcmp(s, "push") == 0) {
670 } else if (strcmp(s, "pull") == 0) {
677 bool parse_modifier_mask(char *s, unsigned int *m)
679 if (strcmp(s, "shift") == 0) {
680 *m = XCB_MOD_MASK_SHIFT;
682 } else if (strcmp(s, "control") == 0) {
683 *m = XCB_MOD_MASK_CONTROL;
685 } else if (strcmp(s, "lock") == 0) {
686 *m = XCB_MOD_MASK_LOCK;
688 } else if (strcmp(s, "mod1") == 0) {
691 } else if (strcmp(s, "mod2") == 0) {
694 } else if (strcmp(s, "mod3") == 0) {
697 } else if (strcmp(s, "mod4") == 0) {
700 } else if (strcmp(s, "mod5") == 0) {
707 void print_modifier_mask(char *s, unsigned int m)
710 case XCB_MOD_MASK_SHIFT:
711 snprintf(s, BUFSIZ, "shift");
713 case XCB_MOD_MASK_CONTROL:
714 snprintf(s, BUFSIZ, "control");
716 case XCB_MOD_MASK_LOCK:
717 snprintf(s, BUFSIZ, "lock");
720 snprintf(s, BUFSIZ, "mod1");
723 snprintf(s, BUFSIZ, "mod2");
726 snprintf(s, BUFSIZ, "mod3");
729 snprintf(s, BUFSIZ, "mod4");
732 snprintf(s, BUFSIZ, "mod5");