1
0
Fork 0
mirror of https://github.com/NickHu/sway synced 2025-01-15 15:41:59 +01:00

Merge pull request from Luminarys/master

Added in reload and exec_always handling.
This commit is contained in:
Drew DeVault 2015-08-10 15:26:49 -04:00
commit c9bce5dd22
9 changed files with 122 additions and 70 deletions

View file

@ -39,7 +39,7 @@ int cmd_bindsym(struct sway_config *config, int argc, char **argv) {
binding->keys = create_list(); binding->keys = create_list();
binding->modifiers = 0; binding->modifiers = 0;
binding->command = join_args(argv + 1, argc - 1); binding->command = join_args(argv + 1, argc - 1);
list_t *split = split_string(argv[0], "+"); list_t *split = split_string(argv[0], "+");
int i; int i;
for (i = 0; i < split->length; ++i) { for (i = 0; i < split->length; ++i) {
@ -78,6 +78,28 @@ int cmd_exec(struct sway_config *config, int argc, char **argv) {
sway_log(L_ERROR, "Invalid exec command (expected at least 1 argument, got %d)", argc); sway_log(L_ERROR, "Invalid exec command (expected at least 1 argument, got %d)", argc);
return 1; return 1;
} }
if (config->reloading) {
sway_log(L_DEBUG, "Ignoring exec %s due to reload", join_args(argv, argc));
return 0;
}
if (fork() == 0) {
char *args = join_args(argv, argc);
sway_log(L_DEBUG, "Executing %s", args);
execl("/bin/sh", "sh", "-c", args, (char *)NULL);
free(args);
exit(0);
}
return 0;
}
int cmd_exec_always(struct sway_config *config, int argc, char **argv) {
if (argc < 1) {
sway_log(L_ERROR, "Invalid exec_always command (expected at least 1 argument, got %d)", argc);
return 1;
}
if (fork() == 0) { if (fork() == 0) {
char *args = join_args(argv, argc); char *args = join_args(argv, argc);
sway_log(L_DEBUG, "Executing %s", args); sway_log(L_DEBUG, "Executing %s", args);
@ -152,6 +174,18 @@ int cmd_layout(struct sway_config *config, int argc, char **argv) {
return 0; return 0;
} }
int cmd_reload(struct sway_config *config, int argc, char **argv) {
if (argc != 0) {
sway_log(L_ERROR, "Invalid reload command (expected 0 arguments, got %d)", argc);
return 1;
}
if (!load_config()) {
return 1;
}
return 0;
}
int cmd_set(struct sway_config *config, int argc, char **argv) { int cmd_set(struct sway_config *config, int argc, char **argv) {
if (argc != 2) { if (argc != 2) {
sway_log(L_ERROR, "Invalid set command (expected 2 arguments, got %d)", argc); sway_log(L_ERROR, "Invalid set command (expected 2 arguments, got %d)", argc);
@ -232,12 +266,14 @@ int cmd_fullscreen(struct sway_config *config, int argc, char **argv) {
struct cmd_handler handlers[] = { struct cmd_handler handlers[] = {
{ "bindsym", cmd_bindsym }, { "bindsym", cmd_bindsym },
{ "exec", cmd_exec }, { "exec", cmd_exec },
{ "exec_always", cmd_exec_always },
{ "exit", cmd_exit }, { "exit", cmd_exit },
{ "focus", cmd_focus }, { "focus", cmd_focus },
{ "focus_follows_mouse", cmd_focus_follows_mouse }, { "focus_follows_mouse", cmd_focus_follows_mouse },
{ "fullscreen", cmd_fullscreen }, { "fullscreen", cmd_fullscreen },
{ "layout", cmd_layout }, { "layout", cmd_layout },
{ "log_colors", cmd_log_colors }, { "log_colors", cmd_log_colors },
{ "reload", cmd_reload },
{ "set", cmd_set }, { "set", cmd_set },
{ "splith", cmd_splith }, { "splith", cmd_splith },
{ "splitv", cmd_splitv } { "splitv", cmd_splitv }

View file

@ -4,8 +4,8 @@
#include "config.h" #include "config.h"
struct cmd_handler { struct cmd_handler {
char *command; char *command;
int (*handle)(struct sway_config *config, int argc, char **argv); int (*handle)(struct sway_config *config, int argc, char **argv);
}; };
int handle_command(struct sway_config *config, char *command); int handle_command(struct sway_config *config, char *command);

View file

@ -8,6 +8,25 @@
#include "commands.h" #include "commands.h"
#include "config.h" #include "config.h"
bool load_config() {
// TODO: Allow use of more config file locations
const char *name = "/.sway/config";
const char *home = getenv("HOME");
char *temp = malloc(strlen(home) + strlen(name) + 1);
strcpy(temp, home);
strcat(temp, name);
FILE *f = fopen(temp, "r");
if (!f) {
fprintf(stderr, "Unable to open %s for reading", temp);
free(temp);
return false;
}
free(temp);
config = read_config(f, false);
fclose(f);
return true;
}
void config_defaults(struct sway_config *config) { void config_defaults(struct sway_config *config) {
config->symbols = create_list(); config->symbols = create_list();
config->modes = create_list(); config->modes = create_list();
@ -18,12 +37,17 @@ void config_defaults(struct sway_config *config) {
// Flags // Flags
config->focus_follows_mouse = true; config->focus_follows_mouse = true;
config->mouse_warping = true; config->mouse_warping = true;
config->reloading = false;
} }
struct sway_config *read_config(FILE *file) { struct sway_config *read_config(FILE *file, bool is_active) {
struct sway_config *config = malloc(sizeof(struct sway_config)); struct sway_config *config = malloc(sizeof(struct sway_config));
config_defaults(config); config_defaults(config);
if (is_active) {
config->reloading = true;
}
bool success = true; bool success = true;
int temp_depth = 0; // Temporary: skip all config sections with depth int temp_depth = 0; // Temporary: skip all config sections with depth
@ -44,7 +68,7 @@ struct sway_config *read_config(FILE *file) {
if (!temp_depth && handle_command(config, line) != 0) { if (!temp_depth && handle_command(config, line) != 0) {
success = false; success = false;
} }
_continue: _continue:
if (line && line[strlen(line) - 1] == '{') { if (line && line[strlen(line) - 1] == '{') {
temp_depth++; temp_depth++;
@ -56,6 +80,10 @@ _continue:
exit(1); exit(1);
} }
if (is_active) {
config->reloading = true;
}
return config; return config;
} }

View file

@ -6,32 +6,35 @@
#include "list.h" #include "list.h"
struct sway_variable { struct sway_variable {
char *name; char *name;
char *value; char *value;
}; };
struct sway_binding { struct sway_binding {
list_t *keys; list_t *keys;
uint32_t modifiers; uint32_t modifiers;
char *command; char *command;
}; };
struct sway_mode { struct sway_mode {
char *name; char *name;
list_t *bindings; list_t *bindings;
}; };
struct sway_config { struct sway_config {
list_t *symbols; list_t *symbols;
list_t *modes; list_t *modes;
struct sway_mode *current_mode; struct sway_mode *current_mode;
// Flags // Flags
bool focus_follows_mouse; bool focus_follows_mouse;
bool mouse_warping; bool mouse_warping;
bool reloading;
}; };
struct sway_config *read_config(FILE *file); bool load_config();
struct sway_config *read_config(FILE *file, bool is_active);
char *do_var_replacement(struct sway_config *config, char *str); char *do_var_replacement(struct sway_config *config, char *str);
extern struct sway_config *config; extern struct sway_config *config;

View file

@ -5,38 +5,38 @@
#include "list.h" #include "list.h"
struct sway_container { struct sway_container {
wlc_handle handle; wlc_handle handle;
enum { enum {
C_ROOT, C_ROOT,
C_OUTPUT, C_OUTPUT,
C_WORKSPACE, C_WORKSPACE,
C_CONTAINER, C_CONTAINER,
C_VIEW C_VIEW
} type; } type;
enum { enum {
L_NONE, L_NONE,
L_HORIZ, L_HORIZ,
L_VERT, L_VERT,
L_STACKED, L_STACKED,
L_TABBED, L_TABBED,
L_FLOATING L_FLOATING
} layout; } layout;
// Not including borders or margins // Not including borders or margins
int width, height; int width, height;
int x, y; int x, y;
int weight; int weight;
char *name; char *name;
list_t *children; list_t *children;
struct sway_container *parent; struct sway_container *parent;
struct sway_container *focused; struct sway_container *focused;
}; };
typedef struct sway_container swayc_t; typedef struct sway_container swayc_t;

View file

@ -2,9 +2,9 @@
#define _SWAY_LIST_H #define _SWAY_LIST_H
typedef struct { typedef struct {
int capacity; int capacity;
int length; int length;
void **items; void **items;
} list_t; } list_t;
list_t *create_list(); list_t *create_list();

View file

@ -18,7 +18,7 @@ void init_log(int verbosity) {
} }
void sway_log_colors(int mode) { void sway_log_colors(int mode) {
colored = (mode == 1) ? 1 : 0; colored = (mode == 1) ? 1 : 0;
} }
void sway_abort(char *format, ...) { void sway_abort(char *format, ...) {

View file

@ -2,10 +2,10 @@
#define _SWAY_LOG_H #define _SWAY_LOG_H
typedef enum { typedef enum {
L_SILENT = 0, L_SILENT = 0,
L_ERROR = 1, L_ERROR = 1,
L_INFO = 2, L_INFO = 2,
L_DEBUG = 3, L_DEBUG = 3,
} log_importance_t; } log_importance_t;
void init_log(int verbosity); void init_log(int verbosity);

View file

@ -9,24 +9,6 @@
struct sway_config *config; struct sway_config *config;
void load_config() {
// TODO: Allow use of more config file locations
const char *name = "/.sway/config";
const char *home = getenv("HOME");
char *temp = malloc(strlen(home) + strlen(name) + 1);
strcpy(temp, home);
strcat(temp, name);
FILE *f = fopen(temp, "r");
if (!f) {
fprintf(stderr, "Unable to open %s for reading", temp);
free(temp);
exit(1);
}
free(temp);
config = read_config(f);
fclose(f);
}
int main(int argc, char **argv) { int main(int argc, char **argv) {
init_log(L_DEBUG); // TODO: Control this with command line arg init_log(L_DEBUG); // TODO: Control this with command line arg
init_layout(); init_layout();
@ -52,6 +34,7 @@ int main(int argc, char **argv) {
.motion = handle_pointer_motion, .motion = handle_pointer_motion,
.button = handle_pointer_button .button = handle_pointer_button
} }
}; };
setenv("WLC_DIM", "0", 0); setenv("WLC_DIM", "0", 0);
@ -60,7 +43,9 @@ int main(int argc, char **argv) {
} }
setenv("DISPLAY", ":1", 1); setenv("DISPLAY", ":1", 1);
load_config(); if (load_config()) {
exit(1);
}
wlc_run(); wlc_run();
return 0; return 0;