mirror of
https://github.com/swaywm/sway.git
synced 2025-01-15 23:56:00 +01:00
Merge branch 'master' into leaks
This commit is contained in:
commit
b3c55dd909
14 changed files with 60 additions and 37 deletions
|
@ -50,6 +50,7 @@ struct sway_mode {
|
||||||
char *name;
|
char *name;
|
||||||
list_t *keysym_bindings;
|
list_t *keysym_bindings;
|
||||||
list_t *keycode_bindings;
|
list_t *keycode_bindings;
|
||||||
|
bool pango;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct input_config_mapped_from_region {
|
struct input_config_mapped_from_region {
|
||||||
|
|
|
@ -15,6 +15,6 @@ void ipc_event_workspace(struct sway_container *old,
|
||||||
struct sway_container *new, const char *change);
|
struct sway_container *new, const char *change);
|
||||||
void ipc_event_window(struct sway_container *window, const char *change);
|
void ipc_event_window(struct sway_container *window, const char *change);
|
||||||
void ipc_event_barconfig_update(struct bar_config *bar);
|
void ipc_event_barconfig_update(struct bar_config *bar);
|
||||||
void ipc_event_mode(const char *mode);
|
void ipc_event_mode(const char *mode, bool pango);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -26,7 +26,17 @@ struct cmd_results *cmd_mode(int argc, char **argv) {
|
||||||
"mode", "Can only be used in config file.");
|
"mode", "Can only be used in config file.");
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *mode_name = argv[0];
|
bool pango = strcmp(*argv, "--pango_markup") == 0;
|
||||||
|
if (pango) {
|
||||||
|
argc--; argv++;
|
||||||
|
if (argc == 0) {
|
||||||
|
return cmd_results_new(CMD_FAILURE, "mode",
|
||||||
|
"Mode name is missing");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
char *mode_name = *argv;
|
||||||
|
strip_quotes(mode_name);
|
||||||
struct sway_mode *mode = NULL;
|
struct sway_mode *mode = NULL;
|
||||||
// Find mode
|
// Find mode
|
||||||
for (int i = 0; i < config->modes->length; ++i) {
|
for (int i = 0; i < config->modes->length; ++i) {
|
||||||
|
@ -46,6 +56,7 @@ struct cmd_results *cmd_mode(int argc, char **argv) {
|
||||||
mode->name = strdup(mode_name);
|
mode->name = strdup(mode_name);
|
||||||
mode->keysym_bindings = create_list();
|
mode->keysym_bindings = create_list();
|
||||||
mode->keycode_bindings = create_list();
|
mode->keycode_bindings = create_list();
|
||||||
|
mode->pango = pango;
|
||||||
list_add(config->modes, mode);
|
list_add(config->modes, mode);
|
||||||
}
|
}
|
||||||
if (!mode) {
|
if (!mode) {
|
||||||
|
@ -54,13 +65,15 @@ struct cmd_results *cmd_mode(int argc, char **argv) {
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
if ((config->reading && argc > 1) || (!config->reading && argc == 1)) {
|
if ((config->reading && argc > 1) || (!config->reading && argc == 1)) {
|
||||||
wlr_log(L_DEBUG, "Switching to mode `%s'",mode->name);
|
wlr_log(L_DEBUG, "Switching to mode `%s' (pango=%d)",
|
||||||
|
mode->name, mode->pango);
|
||||||
}
|
}
|
||||||
// Set current mode
|
// Set current mode
|
||||||
config->current_mode = mode;
|
config->current_mode = mode;
|
||||||
if (argc == 1) {
|
if (argc == 1) {
|
||||||
// trigger IPC mode event
|
// trigger IPC mode event
|
||||||
ipc_event_mode(config->current_mode->name);
|
ipc_event_mode(config->current_mode->name,
|
||||||
|
config->current_mode->pango);
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -81,8 +81,8 @@ static bool get_surface_box(struct root_geometry *geo,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sw = surface->current->width;
|
int sw = surface->current.width;
|
||||||
int sh = surface->current->height;
|
int sh = surface->current.height;
|
||||||
|
|
||||||
double _sx = sx, _sy = sy;
|
double _sx = sx, _sy = sy;
|
||||||
rotate_child_position(&_sx, &_sy, sw, sh, geo->width, geo->height,
|
rotate_child_position(&_sx, &_sy, sw, sh, geo->width, geo->height,
|
||||||
|
@ -115,8 +115,8 @@ static void surface_for_each_surface(struct wlr_surface *surface,
|
||||||
wlr_surface_iterator_func_t iterator, void *user_data) {
|
wlr_surface_iterator_func_t iterator, void *user_data) {
|
||||||
geo->x = ox;
|
geo->x = ox;
|
||||||
geo->y = oy;
|
geo->y = oy;
|
||||||
geo->width = surface->current->width;
|
geo->width = surface->current.width;
|
||||||
geo->height = surface->current->height;
|
geo->height = surface->current.height;
|
||||||
geo->rotation = 0;
|
geo->rotation = 0;
|
||||||
|
|
||||||
wlr_surface_for_each_surface(surface, iterator, user_data);
|
wlr_surface_for_each_surface(surface, iterator, user_data);
|
||||||
|
@ -258,7 +258,7 @@ static void render_surface_iterator(struct wlr_surface *surface, int sx, int sy,
|
||||||
|
|
||||||
float matrix[9];
|
float matrix[9];
|
||||||
enum wl_output_transform transform =
|
enum wl_output_transform transform =
|
||||||
wlr_output_transform_invert(surface->current->transform);
|
wlr_output_transform_invert(surface->current.transform);
|
||||||
wlr_matrix_project_box(matrix, &box, transform, rotation,
|
wlr_matrix_project_box(matrix, &box, transform, rotation,
|
||||||
wlr_output->transform_matrix);
|
wlr_output->transform_matrix);
|
||||||
|
|
||||||
|
@ -1163,16 +1163,22 @@ static void damage_surface_iterator(struct wlr_surface *surface, int sx, int sy,
|
||||||
int center_x = box.x + box.width/2;
|
int center_x = box.x + box.width/2;
|
||||||
int center_y = box.y + box.height/2;
|
int center_y = box.y + box.height/2;
|
||||||
|
|
||||||
if (pixman_region32_not_empty(&surface->current->surface_damage)) {
|
if (pixman_region32_not_empty(&surface->buffer_damage)) {
|
||||||
|
enum wl_output_transform transform =
|
||||||
|
wlr_output_transform_invert(surface->current.transform);
|
||||||
|
|
||||||
pixman_region32_t damage;
|
pixman_region32_t damage;
|
||||||
pixman_region32_init(&damage);
|
pixman_region32_init(&damage);
|
||||||
pixman_region32_copy(&damage, &surface->current->surface_damage);
|
pixman_region32_copy(&damage, &surface->buffer_damage);
|
||||||
wlr_region_scale(&damage, &damage, output->wlr_output->scale);
|
wlr_region_transform(&damage, &damage, transform,
|
||||||
if (ceil(output->wlr_output->scale) > surface->current->scale) {
|
surface->current.buffer_width, surface->current.buffer_height);
|
||||||
|
wlr_region_scale(&damage, &damage,
|
||||||
|
output->wlr_output->scale / (float)surface->current.scale);
|
||||||
|
if (ceil(output->wlr_output->scale) > surface->current.scale) {
|
||||||
// When scaling up a surface, it'll become blurry so we need to
|
// When scaling up a surface, it'll become blurry so we need to
|
||||||
// expand the damage region
|
// expand the damage region
|
||||||
wlr_region_expand(&damage, &damage,
|
wlr_region_expand(&damage, &damage,
|
||||||
ceil(output->wlr_output->scale) - surface->current->scale);
|
ceil(output->wlr_output->scale) - surface->current.scale);
|
||||||
}
|
}
|
||||||
pixman_region32_translate(&damage, box.x, box.y);
|
pixman_region32_translate(&damage, box.x, box.y);
|
||||||
wlr_region_rotated_bounds(&damage, &damage, rotation,
|
wlr_region_rotated_bounds(&damage, &damage, rotation,
|
||||||
|
|
|
@ -73,8 +73,8 @@ static void save_view_buffer(struct sway_view *view,
|
||||||
}
|
}
|
||||||
if (view->surface && wlr_surface_has_buffer(view->surface)) {
|
if (view->surface && wlr_surface_has_buffer(view->surface)) {
|
||||||
instruction->saved_buffer = wlr_buffer_ref(view->surface->buffer);
|
instruction->saved_buffer = wlr_buffer_ref(view->surface->buffer);
|
||||||
instruction->saved_buffer_width = view->surface->current->width;
|
instruction->saved_buffer_width = view->surface->current.width;
|
||||||
instruction->saved_buffer_height = view->surface->current->height;
|
instruction->saved_buffer_height = view->surface->current.height;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -251,8 +251,8 @@ static void handle_map(struct wl_listener *listener, void *data) {
|
||||||
view->natural_width = view->wlr_xdg_surface->geometry.width;
|
view->natural_width = view->wlr_xdg_surface->geometry.width;
|
||||||
view->natural_height = view->wlr_xdg_surface->geometry.height;
|
view->natural_height = view->wlr_xdg_surface->geometry.height;
|
||||||
if (!view->natural_width && !view->natural_height) {
|
if (!view->natural_width && !view->natural_height) {
|
||||||
view->natural_width = view->wlr_xdg_surface->surface->current->width;
|
view->natural_width = view->wlr_xdg_surface->surface->current.width;
|
||||||
view->natural_height = view->wlr_xdg_surface->surface->current->height;
|
view->natural_height = view->wlr_xdg_surface->surface->current.height;
|
||||||
}
|
}
|
||||||
|
|
||||||
view_map(view, view->wlr_xdg_surface->surface);
|
view_map(view, view->wlr_xdg_surface->surface);
|
||||||
|
|
|
@ -246,8 +246,8 @@ static void handle_map(struct wl_listener *listener, void *data) {
|
||||||
view->natural_width = view->wlr_xdg_surface_v6->geometry.width;
|
view->natural_width = view->wlr_xdg_surface_v6->geometry.width;
|
||||||
view->natural_height = view->wlr_xdg_surface_v6->geometry.height;
|
view->natural_height = view->wlr_xdg_surface_v6->geometry.height;
|
||||||
if (!view->natural_width && !view->natural_height) {
|
if (!view->natural_width && !view->natural_height) {
|
||||||
view->natural_width = view->wlr_xdg_surface_v6->surface->current->width;
|
view->natural_width = view->wlr_xdg_surface_v6->surface->current.width;
|
||||||
view->natural_height = view->wlr_xdg_surface_v6->surface->current->height;
|
view->natural_height = view->wlr_xdg_surface_v6->surface->current.height;
|
||||||
}
|
}
|
||||||
|
|
||||||
view_map(view, view->wlr_xdg_surface_v6->surface);
|
view_map(view, view->wlr_xdg_surface_v6->surface);
|
||||||
|
|
|
@ -278,7 +278,7 @@ static void handle_commit(struct wl_listener *listener, void *data) {
|
||||||
wl_container_of(listener, xwayland_view, commit);
|
wl_container_of(listener, xwayland_view, commit);
|
||||||
struct sway_view *view = &xwayland_view->view;
|
struct sway_view *view = &xwayland_view->view;
|
||||||
struct wlr_xwayland_surface *xsurface = view->wlr_xwayland_surface;
|
struct wlr_xwayland_surface *xsurface = view->wlr_xwayland_surface;
|
||||||
struct wlr_surface_state *surface_state = xsurface->surface->current;
|
struct wlr_surface_state *surface_state = &xsurface->surface->current;
|
||||||
|
|
||||||
if (view->swayc->instructions->length) {
|
if (view->swayc->instructions->length) {
|
||||||
transaction_notify_view_ready_by_size(view,
|
transaction_notify_view_ready_by_size(view,
|
||||||
|
|
|
@ -255,14 +255,12 @@ void dispatch_cursor_button(struct sway_cursor *cursor,
|
||||||
wlr_layer_surface_from_wlr_surface(surface);
|
wlr_layer_surface_from_wlr_surface(surface);
|
||||||
if (layer->current.keyboard_interactive) {
|
if (layer->current.keyboard_interactive) {
|
||||||
seat_set_focus_layer(cursor->seat, layer);
|
seat_set_focus_layer(cursor->seat, layer);
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
} else if (surface && cont && cont->type != C_VIEW) {
|
||||||
// Avoid moving keyboard focus from a surface that accepts it to one
|
// Avoid moving keyboard focus from a surface that accepts it to one
|
||||||
// that does not unless the change would move us to a new workspace.
|
// that does not unless the change would move us to a new workspace.
|
||||||
//
|
//
|
||||||
// This prevents, for example, losing focus when clicking on swaybar.
|
// This prevents, for example, losing focus when clicking on swaybar.
|
||||||
if (surface && cont && cont->type != C_VIEW) {
|
|
||||||
struct sway_container *new_ws = cont;
|
struct sway_container *new_ws = cont;
|
||||||
if (new_ws && new_ws->type != C_WORKSPACE) {
|
if (new_ws && new_ws->type != C_WORKSPACE) {
|
||||||
new_ws = container_parent(new_ws, C_WORKSPACE);
|
new_ws = container_parent(new_ws, C_WORKSPACE);
|
||||||
|
|
|
@ -224,6 +224,9 @@ static void handle_new_input(struct wl_listener *listener, void *data) {
|
||||||
input_manager_libinput_config_pointer(input_device);
|
input_manager_libinput_config_pointer(input_device);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wl_signal_add(&device->events.destroy, &input_device->device_destroy);
|
||||||
|
input_device->device_destroy.notify = handle_device_destroy;
|
||||||
|
|
||||||
struct sway_seat *seat = NULL;
|
struct sway_seat *seat = NULL;
|
||||||
if (!input_has_seat_configuration(input)) {
|
if (!input_has_seat_configuration(input)) {
|
||||||
wlr_log(L_DEBUG, "no seat configuration, using default seat");
|
wlr_log(L_DEBUG, "no seat configuration, using default seat");
|
||||||
|
@ -260,9 +263,6 @@ static void handle_new_input(struct wl_listener *listener, void *data) {
|
||||||
"device '%s' is not configured on any seats",
|
"device '%s' is not configured on any seats",
|
||||||
input_device->identifier);
|
input_device->identifier);
|
||||||
}
|
}
|
||||||
|
|
||||||
wl_signal_add(&device->events.destroy, &input_device->device_destroy);
|
|
||||||
input_device->device_destroy.notify = handle_device_destroy;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void handle_inhibit_activate(struct wl_listener *listener, void *data) {
|
static void handle_inhibit_activate(struct wl_listener *listener, void *data) {
|
||||||
|
|
|
@ -336,13 +336,15 @@ void ipc_event_barconfig_update(struct bar_config *bar) {
|
||||||
json_object_put(json);
|
json_object_put(json);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ipc_event_mode(const char *mode) {
|
void ipc_event_mode(const char *mode, bool pango) {
|
||||||
if (!ipc_has_event_listeners(IPC_EVENT_MODE)) {
|
if (!ipc_has_event_listeners(IPC_EVENT_MODE)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
wlr_log(L_DEBUG, "Sending mode::%s event", mode);
|
wlr_log(L_DEBUG, "Sending mode::%s event", mode);
|
||||||
json_object *obj = json_object_new_object();
|
json_object *obj = json_object_new_object();
|
||||||
json_object_object_add(obj, "change", json_object_new_string(mode));
|
json_object_object_add(obj, "change", json_object_new_string(mode));
|
||||||
|
json_object_object_add(obj, "pango_markup",
|
||||||
|
json_object_new_boolean(pango));
|
||||||
|
|
||||||
const char *json_string = json_object_to_json_string(obj);
|
const char *json_string = json_object_to_json_string(obj);
|
||||||
ipc_send_event(json_string, IPC_EVENT_MODE);
|
ipc_send_event(json_string, IPC_EVENT_MODE);
|
||||||
|
|
|
@ -67,8 +67,8 @@ For more information on these xkb configuration options, see
|
||||||
Enables or disables disable-while-typing for the specified input device.
|
Enables or disables disable-while-typing for the specified input device.
|
||||||
|
|
||||||
*input* <identifier> events enabled|disabled|disabled\_on\_external\_mouse
|
*input* <identifier> events enabled|disabled|disabled\_on\_external\_mouse
|
||||||
Enables or disables send_events for specified input device. (Disabling
|
Enables or disables send\_events for specified input device. (Disabling
|
||||||
send_events disables the input device)
|
send\_events disables the input device)
|
||||||
|
|
||||||
*input* <identifier> left\_handed enabled|disabled
|
*input* <identifier> left\_handed enabled|disabled
|
||||||
Enables or disables left handed mode for specified input device.
|
Enables or disables left handed mode for specified input device.
|
||||||
|
|
|
@ -413,10 +413,12 @@ The default colors are:
|
||||||
*mode* <mode>
|
*mode* <mode>
|
||||||
Switches to the specified mode. The default mode _default_.
|
Switches to the specified mode. The default mode _default_.
|
||||||
|
|
||||||
*mode* <mode> *{* <commands...> *}*
|
*mode* [--pango\_markup] <mode> *{* <commands...> *}*
|
||||||
_commands..._ after *{* will be added to the specified mode. A newline is
|
_commands..._ after *{* will be added to the specified mode. A newline is
|
||||||
required between *{* and the first command, and *}* must be alone on a
|
required between *{* and the first command, and *}* must be alone on a
|
||||||
line. Only *bindsym* and *bindcode* commands are permitted in mode blocks.
|
line. Only *bindsym* and *bindcode* commands are permitted in mode blocks.
|
||||||
|
If _--pango\_markup_ is given, then _mode_ will be interpreted as pango
|
||||||
|
markup.
|
||||||
|
|
||||||
*mouse\_warping* output|none
|
*mouse\_warping* output|none
|
||||||
If _output_ is specified, the mouse will be moved to new outputs as you
|
If _output_ is specified, the mouse will be moved to new outputs as you
|
||||||
|
|
|
@ -298,7 +298,8 @@ static uint32_t render_binding_mode_indicator(cairo_t *cairo,
|
||||||
|
|
||||||
int text_width, text_height;
|
int text_width, text_height;
|
||||||
get_text_size(cairo, config->font, &text_width, &text_height,
|
get_text_size(cairo, config->font, &text_width, &text_height,
|
||||||
output->scale, config->pango_markup, "%s", mode);
|
output->scale, config->mode_pango_markup,
|
||||||
|
"%s", mode);
|
||||||
|
|
||||||
int ws_vertical_padding = WS_VERTICAL_PADDING * output->scale;
|
int ws_vertical_padding = WS_VERTICAL_PADDING * output->scale;
|
||||||
int ws_horizontal_padding = WS_HORIZONTAL_PADDING * output->scale;
|
int ws_horizontal_padding = WS_HORIZONTAL_PADDING * output->scale;
|
||||||
|
@ -329,7 +330,7 @@ static uint32_t render_binding_mode_indicator(cairo_t *cairo,
|
||||||
double text_y = height / 2.0 - text_height / 2.0;
|
double text_y = height / 2.0 - text_height / 2.0;
|
||||||
cairo_set_source_u32(cairo, config->colors.binding_mode.text);
|
cairo_set_source_u32(cairo, config->colors.binding_mode.text);
|
||||||
cairo_move_to(cairo, x + width / 2 - text_width / 2, (int)floor(text_y));
|
cairo_move_to(cairo, x + width / 2 - text_width / 2, (int)floor(text_y));
|
||||||
pango_printf(cairo, config->font, output->scale, config->pango_markup,
|
pango_printf(cairo, config->font, output->scale, config->mode_pango_markup,
|
||||||
"%s", mode);
|
"%s", mode);
|
||||||
return surface_height;
|
return surface_height;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue