X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=settings.c;h=e6ab7cca0de201501cfd69a71e31e2167325c8e2;hb=a172aea6185aaf1769a1a06d048ec8fc393e84ee;hp=8852740226cb7dc009e09afb13daefb681849279;hpb=311fbc06d53a7d0447b0b9918bb9cfea845c395d;p=bspwm.git diff --git a/settings.c b/settings.c index 8852740..e6ab7cc 100644 --- a/settings.c +++ b/settings.c @@ -1,71 +1,79 @@ -#include -#include -#include +/* 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. + */ + #include -#include -#include -#include #include "bspwm.h" -#include "helpers.h" -#include "common.h" #include "settings.h" -void run_autostart(void) +void run_config(void) { - char path[MAXLEN]; - - char *config_home = getenv(CONFIG_HOME_ENV); - if (config_home != NULL) - snprintf(path, sizeof(path), "%s/%s/%s", config_home, WM_NAME, AUTOSTART_FILE); - else - snprintf(path, sizeof(path), "%s/%s/%s/%s", getenv("HOME"), ".config", 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("Couldn't spawn the autostart file.\n"); - } - exit(EXIT_SUCCESS); - } - - wait(NULL); + 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 load_settings(void) { - 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(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); - 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); + snprintf(external_rules_command, sizeof(external_rules_command), "%s", EXTERNAL_RULES_COMMAND); + snprintf(status_prefix, sizeof(status_prefix), "%s", STATUS_PREFIX); - strncpy(wm_name, WM_NAME, sizeof(wm_name)); + 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); - border_width = BORDER_WIDTH; - window_gap = WINDOW_GAP; - split_ratio = SPLIT_RATIO; + split_ratio = SPLIT_RATIO; + window_gap = WINDOW_GAP; + border_width = BORDER_WIDTH; + initial_polarity = FIRST_CHILD; - borderless_monocle = BORDERLESS_MONOCLE; - gapless_monocle = GAPLESS_MONOCLE; - focus_follows_pointer = FOCUS_FOLLOWS_POINTER; - pointer_follows_monitor = POINTER_FOLLOWS_MONITOR; - adaptative_raise = ADAPTATIVE_RAISE; - apply_shadow_property = APPLY_SHADOW_PROPERTY; - auto_alternate = AUTO_ALTERNATE; - focus_by_distance = FOCUS_BY_DISTANCE; + borderless_monocle = BORDERLESS_MONOCLE; + gapless_monocle = GAPLESS_MONOCLE; + focus_follows_pointer = FOCUS_FOLLOWS_POINTER; + pointer_follows_focus = POINTER_FOLLOWS_FOCUS; + pointer_follows_monitor = POINTER_FOLLOWS_MONITOR; + apply_floating_atom = APPLY_FLOATING_ATOM; + auto_alternate = AUTO_ALTERNATE; + auto_cancel = AUTO_CANCEL; + 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; }