mirror of
https://github.com/swaywm/sway.git
synced 2025-11-01 22:58:41 -04:00
Make gaps implementation consistent with i3-gaps
This changes our gaps implementation to behave like i3-gaps. Our previous implementation allowed you to set gaps on a per container basis. This isn't supported by i3-gaps and doesn't seem to have a practical use case. The gaps_outer and gaps_inner properties on containers are now removed as they just read the gaps_inner from the workspace. `gaps inner|outer <px>` no longer changes the gaps for all workspaces. It only sets defaults for new workspaces. `gaps inner|outer current|workspace|all set|plus|minus <px>` is now runtime only, and the workspace option is now removed. `current` now sets gaps for the current workspace as opposed to the current container. `workspace <ws> gaps inner|outer <px>` is now implemented. This sets defaults for a workspace. This also fixes a bug where changing the layout of a split container from linear to tabbed would cause gaps to not be applied to it until you switch to another workspace and back.
This commit is contained in:
parent
dc01e884f7
commit
415a48ac63
8 changed files with 215 additions and 170 deletions
|
|
@ -173,6 +173,8 @@ struct output_config {
|
|||
struct workspace_config {
|
||||
char *workspace;
|
||||
char *output;
|
||||
int gaps_inner;
|
||||
int gaps_outer;
|
||||
};
|
||||
|
||||
struct bar_config {
|
||||
|
|
|
|||
|
|
@ -94,9 +94,6 @@ struct sway_container {
|
|||
|
||||
// The gaps currently applied to the container.
|
||||
double current_gaps;
|
||||
bool has_gaps;
|
||||
double gaps_inner;
|
||||
double gaps_outer;
|
||||
|
||||
struct sway_workspace *workspace; // NULL when hidden in the scratchpad
|
||||
struct sway_container *parent; // NULL if container in root of workspace
|
||||
|
|
|
|||
|
|
@ -32,10 +32,9 @@ struct sway_workspace {
|
|||
enum sway_container_layout layout;
|
||||
enum sway_container_layout prev_split_layout;
|
||||
|
||||
double current_gaps;
|
||||
bool has_gaps;
|
||||
double gaps_inner;
|
||||
double gaps_outer;
|
||||
int current_gaps;
|
||||
int gaps_inner;
|
||||
int gaps_outer;
|
||||
|
||||
struct sway_output *output; // NULL if no outputs are connected
|
||||
list_t *floating; // struct sway_container
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue