/*
* vim:ts=4:sw=4:expandtab
*
+ * i3 - an improved dynamic tiling window manager
+ * © 2009-2011 Michael Stapelberg and contributors (see also: LICENSE)
+ *
+ * load_layout.c: Restore (parts of) the layout, for example after an inplace
+ * restart.
+ *
*/
+#include "all.h"
+
#include <yajl/yajl_common.h>
#include <yajl/yajl_gen.h>
#include <yajl/yajl_parse.h>
#include <yajl/yajl_version.h>
-#include "all.h"
-
/* TODO: refactor the whole parsing thing */
static char *last_key;
LOG("sticky_group of this container is %s\n", json_node->sticky_group);
} else if (strcasecmp(last_key, "orientation") == 0) {
char *buf = NULL;
- asprintf(&buf, "%.*s", (int)len, val);
+ sasprintf(&buf, "%.*s", (int)len, val);
if (strcasecmp(buf, "none") == 0)
json_node->orientation = NO_ORIENTATION;
else if (strcasecmp(buf, "horizontal") == 0)
free(buf);
} else if (strcasecmp(last_key, "border") == 0) {
char *buf = NULL;
- asprintf(&buf, "%.*s", (int)len, val);
+ sasprintf(&buf, "%.*s", (int)len, val);
if (strcasecmp(buf, "none") == 0)
json_node->border_style = BS_NONE;
else if (strcasecmp(buf, "1pixel") == 0)
free(buf);
} else if (strcasecmp(last_key, "layout") == 0) {
char *buf = NULL;
- asprintf(&buf, "%.*s", (int)len, val);
+ sasprintf(&buf, "%.*s", (int)len, val);
if (strcasecmp(buf, "default") == 0)
json_node->layout = L_DEFAULT;
else if (strcasecmp(buf, "stacked") == 0)
json_node->layout = L_OUTPUT;
else LOG("Unhandled \"layout\": %s\n", buf);
free(buf);
+ } else if (strcasecmp(last_key, "mark") == 0) {
+ char *buf = NULL;
+ sasprintf(&buf, "%.*s", (int)len, val);
+ json_node->mark = buf;
+ } else if (strcasecmp(last_key, "floating") == 0) {
+ char *buf = NULL;
+ sasprintf(&buf, "%.*s", (int)len, val);
+ if (strcasecmp(buf, "auto_off") == 0)
+ json_node->floating = FLOATING_AUTO_OFF;
+ else if (strcasecmp(buf, "auto_on") == 0)
+ json_node->floating = FLOATING_AUTO_ON;
+ else if (strcasecmp(buf, "user_off") == 0)
+ json_node->floating = FLOATING_USER_OFF;
+ else if (strcasecmp(buf, "user_on") == 0)
+ json_node->floating = FLOATING_USER_ON;
+ free(buf);
+ } else if (strcasecmp(last_key, "scratchpad_state") == 0) {
+ char *buf = NULL;
+ sasprintf(&buf, "%.*s", (int)len, val);
+ if (strcasecmp(buf, "none") == 0)
+ json_node->scratchpad_state = SCRATCHPAD_NONE;
+ else if (strcasecmp(buf, "fresh") == 0)
+ json_node->scratchpad_state = SCRATCHPAD_FRESH;
+ else if (strcasecmp(buf, "changed") == 0)
+ json_node->scratchpad_state = SCRATCHPAD_CHANGED;
+ free(buf);
}
}
return 1;
#if YAJL_MAJOR >= 2
static int json_int(void *ctx, long long val) {
+ LOG("int %lld for key %s\n", val, last_key);
#else
static int json_int(void *ctx, long val) {
+ LOG("int %ld for key %s\n", val, last_key);
#endif
- LOG("int %d for key %s\n", val, last_key);
- // TODO: remove this after the next preview release
- if (strcasecmp(last_key, "layout") == 0) {
- json_node->layout = val;
- }
if (strcasecmp(last_key, "type") == 0) {
json_node->type = val;
}
if (strcasecmp(last_key, "fullscreen_mode") == 0) {
json_node->fullscreen_mode = val;
}
- if (strcasecmp(last_key, "focused") == 0 && val == 1) {
- to_focus = json_node;
- }
-
if (strcasecmp(last_key, "num") == 0)
json_node->num = val;
return 1;
}
+static int json_bool(void *ctx, int val) {
+ LOG("bool %d for key %s\n", val, last_key);
+ if (strcasecmp(last_key, "focused") == 0 && val) {
+ to_focus = json_node;
+ }
+
+ return 1;
+}
+
static int json_double(void *ctx, double val) {
LOG("double %f for key %s\n", val, last_key);
if (strcasecmp(last_key, "percent") == 0) {
callbacks.yajl_map_key = json_key;
callbacks.yajl_integer = json_int;
callbacks.yajl_double = json_double;
+ callbacks.yajl_boolean = json_bool;
#if YAJL_MAJOR >= 2
g = yajl_gen_alloc(NULL);
hand = yajl_alloc(&callbacks, NULL, (void*)g);