- ConfigDefEntry *def;
- gboolean ret = FALSE;
-
- name = g_ascii_strdown(name, -1);
- g_message("Setting %s", name);
-
- g_datalist_foreach(&config_def, print_config, NULL);
- def = g_datalist_get_data(&config_def, name);
-
- if (def == NULL) {
- g_message("Invalid config option '%s'", name);
- } else {
- if (def->hasList) {
- gboolean found = FALSE;
- GSList *it;
-
- it = def->values;
- g_assert(it != NULL);
- do {
- if (g_ascii_strcasecmp(it->data, value.string) == 0) {
- found = TRUE;
- break;
- }
- } while ((it = it->next));
-
- if (!found)
- g_message("Invalid value '%s' for config option '%s'",
- value.string, name);
+ if (!g_ascii_strcasecmp(name, "stacking")) {
+ if (value->type != TOKEN_STRING)
+ yyerror("invalid value");
+ else {
+ if (!g_ascii_strcasecmp(value->data.string, "bottom"))
+ config_dock_layer = Layer_Below;
+ else if (!g_ascii_strcasecmp(value->data.string, "normal"))
+ config_dock_layer = Layer_Normal;
+ else if (!g_ascii_strcasecmp(value->data.string, "top"))
+ config_dock_layer = Layer_Top;
+ else
+ yyerror("invalid layer");
+ }
+ } else if (!g_ascii_strcasecmp(name, "position")) {
+ if (value->type != TOKEN_STRING)
+ yyerror("invalid value");
+ else {
+ if (!g_ascii_strcasecmp(value->data.string, "topleft"))
+ config_dock_pos = DockPos_TopLeft;
+ else if (!g_ascii_strcasecmp(value->data.string, "top"))
+ config_dock_pos = DockPos_Top;
+ else if (!g_ascii_strcasecmp(value->data.string, "topright"))
+ config_dock_pos = DockPos_TopRight;
+ else if (!g_ascii_strcasecmp(value->data.string, "right"))
+ config_dock_pos = DockPos_Right;
+ else if (!g_ascii_strcasecmp(value->data.string, "bottomright"))
+ config_dock_pos = DockPos_BottomRight;
+ else if (!g_ascii_strcasecmp(value->data.string, "bottom"))
+ config_dock_pos = DockPos_Bottom;
+ else if (!g_ascii_strcasecmp(value->data.string, "bottomleft"))
+ config_dock_pos = DockPos_BottomLeft;
+ else if (!g_ascii_strcasecmp(value->data.string, "left"))
+ config_dock_pos = DockPos_Left;
+ else if (!g_ascii_strcasecmp(value->data.string, "floating"))
+ config_dock_pos = DockPos_Floating;