]> git.lizzy.rs Git - bspwm.git/blobdiff - settings.c
Merge branch 'master' into status
[bspwm.git] / settings.c
index b7045f9ccaa286408093c952aa6f438b16f60574..3a31829f45cd88a5b997157a801f2db1e5cb1f82 100644 (file)
-#define _BSD_SOURCE
-
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
-#include <lua.h>
-#include <lualib.h>
-#include <lauxlib.h>
+#include <unistd.h>
+#include <sys/wait.h>
 #include <xcb/xcb.h>
 #include <xcb/xcb_event.h>
+#include "bspwm.h"
 #include "helpers.h"
-#include "utils.h"
-#include "luautils.h"
 #include "common.h"
 #include "settings.h"
 
-void load_settings(void)
+void run_autostart(void)
 {
-    lua_State *L = lua_open();
-    luaopen_base(L);
-
-    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");
+    char path[MAXLEN];
+
+    snprintf(path, sizeof(path), "%s/%s/%s", getenv("XDG_CONFIG_HOME"), WM_NAME, AUTOSTART_FILE);
+
+    if (fork() == 0) {
+        if (dpy != NULL)
+            close(xcb_get_file_descriptor(dpy));
+        if (fork() == 0) {
+            setsid();
+            execl(path, path, NULL);
+            err("could not run autostart file\n");
+        }
+        exit(EXIT_SUCCESS);
     }
 
-    lua_close(L);
+    wait(NULL);
 }
 
-void apply_settings(lua_State *L)
+void load_settings(void)
 {
-    normal_border_color = string_expr(L, "normal_border_color", NORMAL_BORDER_COLOR);
-    active_border_color = string_expr(L, "active_border_color", ACTIVE_BORDER_COLOR);
-    inner_border_color = string_expr(L, "inner_border_color", INNER_BORDER_COLOR);
-    outer_border_color = string_expr(L, "outer_border_color", OUTER_BORDER_COLOR);
-    preselect_border_color = string_expr(L, "preselect_border_color", PRESELECT_BORDER_COLOR);
-    locked_border_color = string_expr(L, "locked_border_color", LOCKED_BORDER_COLOR);
-
-    smart_window_border = bool_expr(L, "smart_window_border", SMART_WINDOW_BORDER);
-    smart_window_gap = bool_expr(L, "smart_window_gap", SMART_WINDOW_GAP);
-
-    inner_border_width = int_expr(L, "inner_border_width", INNER_BORDER_WIDTH);
-    main_border_width = int_expr(L, "main_border_width", MAIN_BORDER_WIDTH);
-    outer_border_width = int_expr(L, "outer_border_width", OUTER_BORDER_WIDTH);
+    strncpy(normal_border_color, NORMAL_BORDER_COLOR, sizeof(normal_border_color));
+    strncpy(focused_border_color, FOCUSED_BORDER_COLOR, sizeof(focused_border_color));
+    strncpy(active_border_color, ACTIVE_BORDER_COLOR, sizeof(active_border_color));
+    strncpy(inner_border_color, INNER_BORDER_COLOR, sizeof(inner_border_color));
+    strncpy(outer_border_color, OUTER_BORDER_COLOR, sizeof(outer_border_color));
+    strncpy(presel_border_color, PRESEL_BORDER_COLOR, sizeof(presel_border_color));
+    strncpy(focused_locked_border_color, FOCUSED_LOCKED_BORDER_COLOR, sizeof(focused_locked_border_color));
+    strncpy(active_locked_border_color, ACTIVE_LOCKED_BORDER_COLOR, sizeof(active_locked_border_color));
+    strncpy(normal_locked_border_color, NORMAL_LOCKED_BORDER_COLOR, sizeof(normal_locked_border_color));
+    strncpy(urgent_border_color, URGENT_BORDER_COLOR, sizeof(urgent_border_color));
+
+    normal_border_color_pxl = get_color(normal_border_color);
+    focused_border_color_pxl = get_color(active_border_color);
+    active_border_color_pxl = get_color(active_border_color);
+    inner_border_color_pxl = get_color(inner_border_color);
+    outer_border_color_pxl = get_color(outer_border_color);
+    presel_border_color_pxl = get_color(presel_border_color);
+    focused_locked_border_color_pxl = get_color(active_locked_border_color);
+    active_locked_border_color_pxl = get_color(active_locked_border_color);
+    normal_locked_border_color_pxl = get_color(normal_locked_border_color);
+    urgent_border_color_pxl = get_color(urgent_border_color);
+
+    strncpy(wm_name, WM_NAME, sizeof(wm_name));
+    button_modifier = BUTTON_MODIFIER;
+    numlock_modifier = NUMLOCK_MODIFIER;
+    capslock_modifier = CAPSLOCK_MODIFIER;
+
+    inner_border_width = INNER_BORDER_WIDTH;
+    main_border_width = MAIN_BORDER_WIDTH;
+    outer_border_width = OUTER_BORDER_WIDTH;
 
     border_width = inner_border_width + main_border_width + outer_border_width;
-    window_gap = int_expr(L, "window_gap", WINDOW_GAP);
-}
-
-void get_setting(lua_State *L, char* rsp)
-{
-    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, "main_border_width") == 0)
-        sprintf(rsp, "%i\n", main_border_width);
-    else if (strcmp(name, "outer_border_width") == 0)
-        sprintf(rsp, "%i\n", outer_border_width);
-    else if (strcmp(name, "border_width") == 0)
-        sprintf(rsp, "%i\n", border_width);
-    else if (strcmp(name, "window_gap") == 0)
-        sprintf(rsp, "%i\n", window_gap);
-    else if (strcmp(name, "normal_border_color") == 0)
-        sprintf(rsp, "%s\n", normal_border_color);
-    else if (strcmp(name, "active_border_color") == 0)
-        sprintf(rsp, "%s\n", active_border_color);
-    else if (strcmp(name, "inner_border_color") == 0)
-        sprintf(rsp, "%s\n", inner_border_color);
-    else if (strcmp(name, "outer_border_color") == 0)
-        sprintf(rsp, "%s\n", outer_border_color);
-    else if (strcmp(name, "preselect_border_color") == 0)
-        sprintf(rsp, "%s\n", preselect_border_color);
-    else if (strcmp(name, "locked_border_color") == 0)
-        sprintf(rsp, "%s\n", locked_border_color);
-    else if (strcmp(name, "smart_window_border") == 0)
-        sprintf(rsp, "%s\n", BOOLSTR(smart_window_border));
-    else if (strcmp(name, "smart_window_gap") == 0)
-        sprintf(rsp, "%s\n", BOOLSTR(smart_window_gap));
-}
-
-void set_setting(lua_State *L)
-{
-    char *name, *backup;
-
-    if (!has_table(L, "set"))
-        return;
-
-    name = string_expr(L, "set.name", NULL);
-
-    if (name == NULL)
-        return;
-
-    if (strcmp(name, "inner_border_width") == 0) {
-        inner_border_width = int_expr(L, "set.value", inner_border_width);
-        border_width = inner_border_width + main_border_width + outer_border_width;
-    } else if (strcmp(name, "main_border_width") == 0) {
-        main_border_width = int_expr(L, "set.value", main_border_width);
-        border_width = inner_border_width + main_border_width + outer_border_width;
-    } else if (strcmp(name, "outer_border_width") == 0) {
-        outer_border_width = int_expr(L, "set.value", outer_border_width);
-        border_width = inner_border_width + main_border_width + outer_border_width;
-    } else if (strcmp(name, "normal_border_color") == 0) {
-        backup = strdup(normal_border_color);
-        free(normal_border_color);
-        normal_border_color = string_expr(L, "set.value", backup);
-    } else if (strcmp(name, "active_border_color") == 0) {
-        backup = strdup(active_border_color);
-        free(active_border_color);
-        active_border_color = string_expr(L, "set.value", backup);
-    } else if (strcmp(name, "inner_border_color") == 0) {
-        backup = strdup(inner_border_color);
-        free(inner_border_color);
-        inner_border_color = string_expr(L, "set.value", backup);
-    } else if (strcmp(name, "outer_border_color") == 0) {
-        backup = strdup(outer_border_color);
-        free(outer_border_color);
-        outer_border_color = string_expr(L, "set.value", backup);
-    } else if (strcmp(name, "preselect_border_color") == 0) {
-        backup = strdup(preselect_border_color);
-        free(preselect_border_color);
-        preselect_border_color = string_expr(L, "set.value", backup);
-    } else if (strcmp(name, "locked_border_color") == 0) {
-        backup = strdup(locked_border_color);
-        free(locked_border_color);
-        locked_border_color = string_expr(L, "set.value", backup);
-    } else if (strcmp(name, "smart_window_border") == 0) {
-        smart_window_border = bool_expr(L, "set.value", smart_window_border);
-    } else if (strcmp(name, "smart_window_gap") == 0) {
-        smart_window_gap = bool_expr(L, "set.value", smart_window_gap);
-    }
+    window_gap = WINDOW_GAP;
 
-    if (backup != NULL)
-        free(backup);
+    borderless_monocle = BORDERLESS_MONOCLE;
+    gapless_monocle = GAPLESS_MONOCLE;
+    focus_follows_mouse = FOCUS_FOLLOWS_MOUSE;
+    adaptative_raise = ADAPTATIVE_RAISE;
+    status_stdout = STATUS_STDOUT;
 }