Merge pull request #1555 from martinetd/cmd_reload

commands: add 'reload' command
This commit is contained in:
Drew DeVault 2018-01-29 16:16:23 -05:00 committed by GitHub
commit 38903e5801
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
10 changed files with 68 additions and 1 deletions

View file

@ -25,6 +25,7 @@ struct sway_cursor {
struct wl_listener request_set_cursor; struct wl_listener request_set_cursor;
}; };
void sway_cursor_destroy(struct sway_cursor *cursor);
struct sway_cursor *sway_cursor_create(struct sway_seat *seat); struct sway_cursor *sway_cursor_create(struct sway_seat *seat);
#endif #endif

View file

@ -46,4 +46,6 @@ void sway_input_manager_apply_seat_config(struct sway_input_manager *input,
struct sway_seat *sway_input_manager_get_default_seat( struct sway_seat *sway_input_manager_get_default_seat(
struct sway_input_manager *input); struct sway_input_manager *input);
struct sway_seat *input_manager_get_seat(struct sway_input_manager *input,
const char *seat_name);
#endif #endif

View file

@ -29,6 +29,8 @@ struct sway_seat {
struct sway_seat *sway_seat_create(struct sway_input_manager *input, struct sway_seat *sway_seat_create(struct sway_input_manager *input,
const char *seat_name); const char *seat_name);
void sway_seat_destroy(struct sway_seat *seat);
void sway_seat_add_device(struct sway_seat *seat, void sway_seat_add_device(struct sway_seat *seat,
struct sway_input_device *device); struct sway_input_device *device);

View file

@ -136,6 +136,7 @@ static struct cmd_handler handlers[] = {
{ "input", cmd_input }, { "input", cmd_input },
{ "kill", cmd_kill }, { "kill", cmd_kill },
{ "output", cmd_output }, { "output", cmd_output },
{ "reload", cmd_reload },
{ "seat", cmd_seat }, { "seat", cmd_seat },
{ "set", cmd_set }, { "set", cmd_set },
}; };

21
sway/commands/reload.c Normal file
View file

@ -0,0 +1,21 @@
#include "sway/commands.h"
#include "sway/config.h"
#include "sway/layout.h"
struct cmd_results *cmd_reload(int argc, char **argv) {
struct cmd_results *error = NULL;
if (config->reading) {
return cmd_results_new(CMD_FAILURE, "reload", "Can't be used in config file.");
}
if ((error = checkarg(argc, "reload", EXPECTED_EQUAL_TO, 0))) {
return error;
}
if (!load_main_config(config->current_config, true)) {
return cmd_results_new(CMD_FAILURE, "reload", "Error(s) reloading config.");
}
/* load_swaybars(); -- for when it's implemented */
arrange_windows(&root_container, -1, -1);
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
}

View file

@ -21,6 +21,7 @@
#endif #endif
#include <wlr/types/wlr_output.h> #include <wlr/types/wlr_output.h>
#include "sway/input/input-manager.h" #include "sway/input/input-manager.h"
#include "sway/input/seat.h"
#include "sway/commands.h" #include "sway/commands.h"
#include "sway/config.h" #include "sway/config.h"
#include "sway/layout.h" #include "sway/layout.h"
@ -109,6 +110,23 @@ void free_config(struct sway_config *config) {
free(config); free(config);
} }
static void destroy_removed_seats(struct sway_config *old_config,
struct sway_config *new_config) {
struct seat_config *seat_config;
struct sway_seat *seat;
int i;
for (i = 0; i < old_config->seat_configs->length; i++) {
seat_config = old_config->seat_configs->items[i];
/* Also destroy seats that aren't present in new config */
if (new_config && list_seq_find(new_config->seat_configs,
seat_name_cmp, seat_config->name) < 0) {
seat = input_manager_get_seat(input_manager,
seat_config->name);
sway_seat_destroy(seat);
}
}
}
static void config_defaults(struct sway_config *config) { static void config_defaults(struct sway_config *config) {
if (!(config->symbols = create_list())) goto cleanup; if (!(config->symbols = create_list())) goto cleanup;
if (!(config->modes = create_list())) goto cleanup; if (!(config->modes = create_list())) goto cleanup;
@ -382,6 +400,7 @@ bool load_main_config(const char *file, bool is_active) {
} }
if (old_config) { if (old_config) {
destroy_removed_seats(old_config, config);
free_config(old_config); free_config(old_config);
} }
config->reading = false; config->reading = false;

View file

@ -149,6 +149,16 @@ static void handle_request_set_cursor(struct wl_listener *listener,
wlr_log(L_DEBUG, "TODO: handle request set cursor event: %p", event); wlr_log(L_DEBUG, "TODO: handle request set cursor event: %p", event);
} }
void sway_cursor_destroy(struct sway_cursor *cursor) {
if (!cursor) {
return;
}
wlr_xcursor_manager_destroy(cursor->xcursor_manager);
wlr_cursor_destroy(cursor->cursor);
free(cursor);
}
struct sway_cursor *sway_cursor_create(struct sway_seat *seat) { struct sway_cursor *sway_cursor_create(struct sway_seat *seat) {
struct sway_cursor *cursor = calloc(1, sizeof(struct sway_cursor)); struct sway_cursor *cursor = calloc(1, sizeof(struct sway_cursor));
if (!sway_assert(cursor, "could not allocate sway cursor")) { if (!sway_assert(cursor, "could not allocate sway cursor")) {

View file

@ -23,7 +23,7 @@ struct sway_input_manager *input_manager;
struct input_config *current_input_config = NULL; struct input_config *current_input_config = NULL;
struct seat_config *current_seat_config = NULL; struct seat_config *current_seat_config = NULL;
static struct sway_seat *input_manager_get_seat( struct sway_seat *input_manager_get_seat(
struct sway_input_manager *input, const char *seat_name) { struct sway_input_manager *input, const char *seat_name) {
struct sway_seat *seat = NULL; struct sway_seat *seat = NULL;
wl_list_for_each(seat, &input->seats, link) { wl_list_for_each(seat, &input->seats, link) {

View file

@ -21,6 +21,16 @@ static void seat_device_destroy(struct sway_seat_device *seat_device) {
free(seat_device); free(seat_device);
} }
void sway_seat_destroy(struct sway_seat *seat) {
struct sway_seat_device *seat_device, *next;
wl_list_for_each_safe(seat_device, next, &seat->devices, link) {
seat_device_destroy(seat_device);
}
sway_cursor_destroy(seat->cursor);
wl_list_remove(&seat->link);
wlr_seat_destroy(seat->wlr_seat);
}
struct sway_seat *sway_seat_create(struct sway_input_manager *input, struct sway_seat *sway_seat_create(struct sway_input_manager *input,
const char *seat_name) { const char *seat_name) {
struct sway_seat *seat = calloc(1, sizeof(struct sway_seat)); struct sway_seat *seat = calloc(1, sizeof(struct sway_seat));

View file

@ -34,6 +34,7 @@ sway_sources = files(
'commands/input/xkb_rules.c', 'commands/input/xkb_rules.c',
'commands/input/xkb_variant.c', 'commands/input/xkb_variant.c',
'commands/output.c', 'commands/output.c',
'commands/reload.c',
'config.c', 'config.c',
'config/output.c', 'config/output.c',
'config/seat.c', 'config/seat.c',