-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
+/* * Copyright (c) 2012-2013 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:
+ *
+ * * Redistributions of source code must retain the above copyright notice, this
+ * list of conditions and the following disclaimer.
+ * * 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 HOLDER 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 <unistd.h>
-#include <sys/wait.h>
-#include <xcb/xcb.h>
-#include <xcb/xcb_event.h>
#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);
+ setsid();
+ execl(config_path, config_path, NULL);
+ err("Couldn't execute the configuration file.\n");
}
-
- wait(NULL);
}
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));
+ snprintf(rule_command, sizeof(rule_command), "%s", RULE_COMMAND);
+ snprintf(status_prefix, sizeof(status_prefix), "%s", STATUS_PREFIX);
- 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(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);
- strncpy(wm_name, WM_NAME, sizeof(wm_name));
+ focused_frame_opacity = FOCUSED_FRAME_OPACITY;
+ active_frame_opacity = ACTIVE_FRAME_OPACITY;
+ normal_frame_opacity = NORMAL_FRAME_OPACITY;
- border_width = BORDER_WIDTH;
- window_gap = WINDOW_GAP;
split_ratio = SPLIT_RATIO;
+ growth_factor = GROWTH_FACTOR;
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;
+ apply_floating_atom = APPLY_FLOATING_ATOM;
auto_alternate = AUTO_ALTERNATE;
- focus_by_distance = FOCUS_BY_DISTANCE;
+ auto_cancel = AUTO_CANCEL;
+ history_aware_focus = HISTORY_AWARE_FOCUS;
+ ignore_ewmh_focus = IGNORE_EWMH_FOCUS;
+ remove_disabled_monitor = REMOVE_DISABLED_MONITOR;
}