]> git.lizzy.rs Git - bspwm.git/blobdiff - settings.c
Remove settings: auto_cancel and auto_alternate
[bspwm.git] / settings.c
index 52a5e91257a7603e051ec0e178b7934e2dbc2286..9330e625d4e50d0e2dc2ed43214cfb1f8a000583 100644 (file)
@@ -1,76 +1,77 @@
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include "utils.h"
-#include "luautils.h"
-#include "settings.h"
-#include "common.h"
-
-void load_settings(void)
-{
-    lua_State *L = lua_open();
-    luaopen_base(L);
+/* Copyright (c) 2012, Bastien Dejean
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice, this
+ *    list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
+ *    this list of conditions and the following disclaimer in the documentation
+ *    and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
+ * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
 
-    if (luaL_loadfile(L, CONFIG_FILE) == 0) {
-        if (lua_pcall(L, 0, 0, 0) == 0)
-            apply_settings(L);
-        else
-            die("error: cannot interpret configuration file\n");
-    } else {
-        die("error: could not load configuration file\n");
-    }
-
-    lua_close(L);
-}
-
-void apply_settings(lua_State *L)
-{
-    normal_border_color = string_expr(L, "normal_border_color", NORMAL_BORDER_COLOR);
-    smart_surroundings = bool_expr(L, "smart_surroundings", SMART_SURROUNDINGS);
-    outer_border_width = int_expr(L, "outer_border_width", OUTER_BORDER_WIDTH);
-    inner_border_width = int_expr(L, "inner_border_width", INNER_BORDER_WIDTH);
-    inner_border_color = string_expr(L, "inner_border_color", INNER_BORDER_COLOR);
-    border_width = inner_border_width + outer_border_width;
-}
+#include <unistd.h>
+#include "bspwm.h"
+#include "settings.h"
 
-void get_setting(lua_State *L, char* rsp)
+void run_config(void)
 {
-    char *name;
-
-    if (!has_table(L, "get"))
-        return;
-
-    name = string_expr(L, "get.name", NULL);
-    if (name == NULL)
-        return;
-
-    if (strcmp(name, "inner_border_width") == 0)
-        sprintf(rsp, "%i\n", inner_border_width);
-    else if (strcmp(name, "normal_border_color") == 0)
-        sprintf(rsp, "%s\n", normal_border_color);
-    else if (strcmp(name, "inner_border_color") == 0)
-        sprintf(rsp, "%s\n", inner_border_color);
+       if (fork() == 0) {
+               if (dpy != NULL)
+                       close(xcb_get_file_descriptor(dpy));
+               setsid();
+               execl(config_path, config_path, NULL);
+               err("Couldn't execute the configuration file.\n");
+       }
 }
 
-void set_setting(lua_State *L)
+void load_settings(void)
 {
-    char *name;
-
-    if (!has_table(L, "set"))
-        return;
+       snprintf(external_rules_command, sizeof(external_rules_command), "%s", EXTERNAL_RULES_COMMAND);
+       snprintf(status_prefix, sizeof(status_prefix), "%s", STATUS_PREFIX);
 
-    name = string_expr(L, "set.name", NULL);
+       snprintf(normal_border_color, sizeof(normal_border_color), "%s", NORMAL_BORDER_COLOR);
+       snprintf(focused_border_color, sizeof(focused_border_color), "%s", FOCUSED_BORDER_COLOR);
+       snprintf(active_border_color, sizeof(active_border_color), "%s", ACTIVE_BORDER_COLOR);
+       snprintf(presel_border_color, sizeof(presel_border_color), "%s", PRESEL_BORDER_COLOR);
+       snprintf(focused_locked_border_color, sizeof(focused_locked_border_color), "%s", FOCUSED_LOCKED_BORDER_COLOR);
+       snprintf(active_locked_border_color, sizeof(active_locked_border_color), "%s", ACTIVE_LOCKED_BORDER_COLOR);
+       snprintf(normal_locked_border_color, sizeof(normal_locked_border_color), "%s", NORMAL_LOCKED_BORDER_COLOR);
+       snprintf(focused_sticky_border_color, sizeof(focused_sticky_border_color), "%s", FOCUSED_STICKY_BORDER_COLOR);
+       snprintf(active_sticky_border_color, sizeof(active_sticky_border_color), "%s", ACTIVE_STICKY_BORDER_COLOR);
+       snprintf(normal_sticky_border_color, sizeof(normal_sticky_border_color), "%s", NORMAL_STICKY_BORDER_COLOR);
+       snprintf(focused_private_border_color, sizeof(focused_private_border_color), "%s", FOCUSED_PRIVATE_BORDER_COLOR);
+       snprintf(active_private_border_color, sizeof(active_private_border_color), "%s", ACTIVE_PRIVATE_BORDER_COLOR);
+       snprintf(normal_private_border_color, sizeof(normal_private_border_color), "%s", NORMAL_PRIVATE_BORDER_COLOR);
+       snprintf(urgent_border_color, sizeof(urgent_border_color), "%s", URGENT_BORDER_COLOR);
 
-    if (name == NULL)
-        return;
+       split_ratio = SPLIT_RATIO;
+       window_gap = WINDOW_GAP;
+       border_width = BORDER_WIDTH;
+       initial_polarity = FIRST_CHILD;
 
-    if (strcmp(name, "inner_border_width") == 0) {
-        inner_border_width = int_expr(L, "set.value", INNER_BORDER_WIDTH);
-    } else if (strcmp(name, "normal_border_color") == 0) {
-        free(normal_border_color);
-        normal_border_color = string_expr(L, "set.value", NORMAL_BORDER_COLOR);
-    } else if (strcmp(name, "inner_border_color") == 0) {
-        free(inner_border_color);
-        inner_border_color = string_expr(L, "set.value", INNER_BORDER_COLOR);
-    }
+       borderless_monocle = BORDERLESS_MONOCLE;
+       gapless_monocle = GAPLESS_MONOCLE;
+       leaf_monocle = LEAF_MONOCLE;
+       focus_follows_pointer = FOCUS_FOLLOWS_POINTER;
+       pointer_follows_focus = POINTER_FOLLOWS_FOCUS;
+       pointer_follows_monitor = POINTER_FOLLOWS_MONITOR;
+       history_aware_focus = HISTORY_AWARE_FOCUS;
+       ignore_ewmh_focus = IGNORE_EWMH_FOCUS;
+       center_pseudo_tiled = CENTER_PSEUDO_TILED;
+       remove_disabled_monitors = REMOVE_DISABLED_MONITORS;
+       remove_unplugged_monitors = REMOVE_UNPLUGGED_MONITORS;
+       merge_overlapping_monitors = MERGE_OVERLAPPING_MONITORS;
 }