mirror of
https://github.com/swaywm/sway.git
synced 2025-01-16 16:11:11 +01:00
Merge branch 'master' into master
This commit is contained in:
commit
4c06a10004
8 changed files with 127 additions and 8 deletions
|
@ -1,7 +1,16 @@
|
||||||
BasedOnStyle: LLVM
|
BasedOnStyle: LLVM
|
||||||
IndentWidth: 8
|
IndentWidth: 4
|
||||||
|
TabWidth: 4
|
||||||
UseTab: Always
|
UseTab: Always
|
||||||
BreakBeforeBraces: Attach
|
BreakBeforeBraces: Attach
|
||||||
AllowShortIfStatementsOnASingleLine: false
|
AllowShortIfStatementsOnASingleLine: false
|
||||||
IndentCaseLabels: false
|
IndentCaseLabels: false
|
||||||
ColumnLimit: 0
|
SortIncludes: false
|
||||||
|
ColumnLimit: 80
|
||||||
|
AlignAfterOpenBracket: DontAlign
|
||||||
|
BinPackParameters: false
|
||||||
|
BinPackArguments: false
|
||||||
|
ContinuationIndentWidth: 8
|
||||||
|
AllowAllParametersOfDeclarationOnNextLine: false
|
||||||
|
AllowShortLoopsOnASingleLine: true
|
||||||
|
ReflowComments: false
|
||||||
|
|
|
@ -178,7 +178,8 @@ enum edge_border_types {
|
||||||
E_NONE, /**< Don't hide edge borders */
|
E_NONE, /**< Don't hide edge borders */
|
||||||
E_VERTICAL, /**< hide vertical edge borders */
|
E_VERTICAL, /**< hide vertical edge borders */
|
||||||
E_HORIZONTAL, /**< hide horizontal edge borders */
|
E_HORIZONTAL, /**< hide horizontal edge borders */
|
||||||
E_BOTH /**< hide vertical and horizontal edge borders */
|
E_BOTH, /**< hide vertical and horizontal edge borders */
|
||||||
|
E_SMART /**< hide both if precisely one window is present in workspace */
|
||||||
};
|
};
|
||||||
|
|
||||||
enum command_context {
|
enum command_context {
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
// Position is absolute coordinates on the edge where the adjacent output
|
// Position is absolute coordinates on the edge where the adjacent output
|
||||||
// should be searched for.
|
// should be searched for.
|
||||||
swayc_t *output_by_name(const char* name, const struct wlc_point *abs_pos);
|
swayc_t *output_by_name(const char* name, const struct wlc_point *abs_pos);
|
||||||
|
swayc_t *swayc_opposite_output(enum movement_direction dir, const struct wlc_point *abs_pos);
|
||||||
swayc_t *swayc_adjacent_output(swayc_t *output, enum movement_direction dir, const struct wlc_point *abs_pos, bool pick_closest);
|
swayc_t *swayc_adjacent_output(swayc_t *output, enum movement_direction dir, const struct wlc_point *abs_pos, bool pick_closest);
|
||||||
|
|
||||||
// Place absolute coordinates for given container into given wlc_point.
|
// Place absolute coordinates for given container into given wlc_point.
|
||||||
|
|
|
@ -15,6 +15,8 @@ struct cmd_results *cmd_hide_edge_borders(int argc, char **argv) {
|
||||||
config->hide_edge_borders = E_HORIZONTAL;
|
config->hide_edge_borders = E_HORIZONTAL;
|
||||||
} else if (strcasecmp(argv[0], "both") == 0) {
|
} else if (strcasecmp(argv[0], "both") == 0) {
|
||||||
config->hide_edge_borders = E_BOTH;
|
config->hide_edge_borders = E_BOTH;
|
||||||
|
} else if (strcasecmp(argv[0], "smart") == 0) {
|
||||||
|
config->hide_edge_borders = E_SMART;
|
||||||
} else {
|
} else {
|
||||||
return cmd_results_new(CMD_INVALID, "hide_edge_borders",
|
return cmd_results_new(CMD_INVALID, "hide_edge_borders",
|
||||||
"Expected 'hide_edge_borders <none|vertical|horizontal|both>'");
|
"Expected 'hide_edge_borders <none|vertical|horizontal|both>'");
|
||||||
|
|
|
@ -807,6 +807,10 @@ static bool swayc_border_check(swayc_t *c, const void *_origin) {
|
||||||
const struct wlc_point *origin = _origin;
|
const struct wlc_point *origin = _origin;
|
||||||
const struct wlc_geometry title_bar = c->title_bar_geometry;
|
const struct wlc_geometry title_bar = c->title_bar_geometry;
|
||||||
|
|
||||||
|
if (c->border_type != B_NORMAL) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (origin->x >= title_bar.origin.x && origin->y >= title_bar.origin.y
|
if (origin->x >= title_bar.origin.x && origin->y >= title_bar.origin.y
|
||||||
&& origin->x < title_bar.origin.x + (int32_t)title_bar.size.w
|
&& origin->x < title_bar.origin.x + (int32_t)title_bar.size.w
|
||||||
&& origin->y < title_bar.origin.y + (int32_t)title_bar.size.h) {
|
&& origin->y < title_bar.origin.y + (int32_t)title_bar.size.h) {
|
||||||
|
|
|
@ -717,6 +717,13 @@ void update_geometry(swayc_t *container) {
|
||||||
border_bottom = 0;
|
border_bottom = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (config->hide_edge_borders == E_SMART && workspace->children->length == 1) {
|
||||||
|
border_top = 0;
|
||||||
|
border_bottom = 0;
|
||||||
|
border_left = 0;
|
||||||
|
border_right = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int title_bar_height = config->font_height + 4; //borders + padding
|
int title_bar_height = config->font_height + 4; //borders + padding
|
||||||
|
|
29
sway/main.c
29
sway/main.c
|
@ -10,6 +10,9 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
#include <sys/capability.h>
|
#include <sys/capability.h>
|
||||||
|
#ifdef __linux__
|
||||||
|
#include <sys/prctl.h>
|
||||||
|
#endif
|
||||||
#include "sway/extensions.h"
|
#include "sway/extensions.h"
|
||||||
#include "sway/layout.h"
|
#include "sway/layout.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
@ -289,6 +292,18 @@ int main(int argc, char **argv) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef __linux__
|
||||||
|
bool suid = false;
|
||||||
|
if (getuid() != geteuid() || getgid() != getegid()) {
|
||||||
|
// Retain capabilities after setuid()
|
||||||
|
if (prctl(PR_SET_KEEPCAPS, 1, 0, 0, 0)) {
|
||||||
|
sway_log(L_ERROR, "Cannot keep caps after setuid()");
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
suid = true;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// we need to setup logging before wlc_init in case it fails.
|
// we need to setup logging before wlc_init in case it fails.
|
||||||
if (debug) {
|
if (debug) {
|
||||||
init_log(L_DEBUG);
|
init_log(L_DEBUG);
|
||||||
|
@ -311,6 +326,20 @@ int main(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
register_extensions();
|
register_extensions();
|
||||||
|
|
||||||
|
#ifdef __linux__
|
||||||
|
if (suid) {
|
||||||
|
// Drop every cap except CAP_SYS_PTRACE
|
||||||
|
cap_t caps = cap_init();
|
||||||
|
cap_value_t keep = CAP_SYS_PTRACE;
|
||||||
|
sway_log(L_INFO, "Dropping extra capabilities");
|
||||||
|
if (cap_set_flag(caps, CAP_PERMITTED, 1, &keep, CAP_SET) ||
|
||||||
|
cap_set_flag(caps, CAP_EFFECTIVE, 1, &keep, CAP_SET) ||
|
||||||
|
cap_set_proc(caps)) {
|
||||||
|
sway_log(L_ERROR, "Failed to drop extra capabilities");
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
// handle SIGTERM signals
|
// handle SIGTERM signals
|
||||||
signal(SIGTERM, sig_handler);
|
signal(SIGTERM, sig_handler);
|
||||||
|
|
||||||
|
|
|
@ -13,14 +13,29 @@ void output_get_scaled_size(wlc_handle handle, struct wlc_size *size) {
|
||||||
}
|
}
|
||||||
|
|
||||||
swayc_t *output_by_name(const char* name, const struct wlc_point *abs_pos) {
|
swayc_t *output_by_name(const char* name, const struct wlc_point *abs_pos) {
|
||||||
|
swayc_t *output = NULL;
|
||||||
|
// If there is no output directly next to the current one, use
|
||||||
|
// swayc_opposite_output to wrap.
|
||||||
if (strcasecmp(name, "left") == 0) {
|
if (strcasecmp(name, "left") == 0) {
|
||||||
return swayc_adjacent_output(NULL, MOVE_LEFT, abs_pos, true);
|
output = swayc_adjacent_output(NULL, MOVE_LEFT, abs_pos, true);
|
||||||
|
if (!output) {
|
||||||
|
output = swayc_opposite_output(MOVE_RIGHT, abs_pos);
|
||||||
|
}
|
||||||
} else if (strcasecmp(name, "right") == 0) {
|
} else if (strcasecmp(name, "right") == 0) {
|
||||||
return swayc_adjacent_output(NULL, MOVE_RIGHT, abs_pos, true);
|
output = swayc_adjacent_output(NULL, MOVE_RIGHT, abs_pos, true);
|
||||||
|
if (!output) {
|
||||||
|
output = swayc_opposite_output(MOVE_LEFT, abs_pos);
|
||||||
|
}
|
||||||
} else if (strcasecmp(name, "up") == 0) {
|
} else if (strcasecmp(name, "up") == 0) {
|
||||||
return swayc_adjacent_output(NULL, MOVE_UP, abs_pos, true);
|
output = swayc_adjacent_output(NULL, MOVE_UP, abs_pos, true);
|
||||||
|
if (!output) {
|
||||||
|
output = swayc_opposite_output(MOVE_DOWN, abs_pos);
|
||||||
|
}
|
||||||
} else if (strcasecmp(name, "down") == 0) {
|
} else if (strcasecmp(name, "down") == 0) {
|
||||||
return swayc_adjacent_output(NULL, MOVE_DOWN, abs_pos, true);
|
output = swayc_adjacent_output(NULL, MOVE_DOWN, abs_pos, true);
|
||||||
|
if (!output) {
|
||||||
|
output = swayc_opposite_output(MOVE_UP, abs_pos);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
for(int i = 0; i < root_container.children->length; ++i) {
|
for(int i = 0; i < root_container.children->length; ++i) {
|
||||||
swayc_t *c = root_container.children->items[i];
|
swayc_t *c = root_container.children->items[i];
|
||||||
|
@ -29,7 +44,58 @@ swayc_t *output_by_name(const char* name, const struct wlc_point *abs_pos) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return output;
|
||||||
|
}
|
||||||
|
|
||||||
|
swayc_t *swayc_opposite_output(enum movement_direction dir,
|
||||||
|
const struct wlc_point *abs_pos) {
|
||||||
|
|
||||||
|
// Search through all the outputs and pick the output whose edge covers the
|
||||||
|
// given position, and is at leftmost/rightmost/upmost/downmost side of the
|
||||||
|
// screen (decided by the direction given).
|
||||||
|
swayc_t *opposite = NULL;
|
||||||
|
char *dir_text = NULL;
|
||||||
|
switch(dir) {
|
||||||
|
case MOVE_LEFT:
|
||||||
|
case MOVE_RIGHT: ;
|
||||||
|
for (int i = 0; i < root_container.children->length; ++i) {
|
||||||
|
swayc_t *c = root_container.children->items[i];
|
||||||
|
if (abs_pos->y >= c->y && abs_pos->y <= c->y + c->height) {
|
||||||
|
if (!opposite) {
|
||||||
|
opposite = c;
|
||||||
|
} else if ((dir == MOVE_LEFT && c->x < opposite->x)
|
||||||
|
|| (dir == MOVE_RIGHT && c->x > opposite->x)) {
|
||||||
|
opposite = c;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dir_text = dir == MOVE_LEFT ? "leftmost" : "rightmost";
|
||||||
|
break;
|
||||||
|
case MOVE_UP:
|
||||||
|
case MOVE_DOWN: ;
|
||||||
|
for (int i = 0; i < root_container.children->length; ++i) {
|
||||||
|
swayc_t *c = root_container.children->items[i];
|
||||||
|
if (abs_pos->x >= c->x && abs_pos->x <= c->x + c->width) {
|
||||||
|
if (!opposite) {
|
||||||
|
opposite = c;
|
||||||
|
} else if ((dir == MOVE_UP && c->y < opposite->y)
|
||||||
|
|| (dir == MOVE_DOWN && c->y > opposite->y)) {
|
||||||
|
opposite = c;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dir_text = dir == MOVE_UP ? "upmost" : "downmost";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
sway_abort("Function called with invalid argument.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (opposite) {
|
||||||
|
sway_log(L_DEBUG, "%s (%.0fx%.0f+%.0f+%.0f) is %s from y-position %i",
|
||||||
|
opposite->name, opposite->width, opposite->height, opposite->x, opposite->y,
|
||||||
|
dir_text, abs_pos->y);
|
||||||
|
}
|
||||||
|
return opposite;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Position is where on the edge (as absolute position) the adjacent output should be searched for.
|
// Position is where on the edge (as absolute position) the adjacent output should be searched for.
|
||||||
|
|
Loading…
Reference in a new issue