mirror of https://github.com/swaywm/sway.git
Compare commits
141 Commits
Author | SHA1 | Date |
---|---|---|
Violet Purcell | 2e9139df66 | |
Simon Ser | d0bd591ee7 | |
Simon Ser | df69367d92 | |
Simon Ser | 700f4805bc | |
thal | a168b20299 | |
Simon Ser | 9704152414 | |
Anna (navi) Figueiredo Gomes | fd3b643d15 | |
Simon Ser | 796898519b | |
Manuel Stoeckl | dcdb72757a | |
Simon Ser | 30f5c3a911 | |
Alexander Orzechowski | b463957021 | |
Kenny Levinsen | 2686afb95c | |
Kenny Levinsen | 4c28916d68 | |
Kenny Levinsen | ee5c4f38c9 | |
Kenny Levinsen | 646019cad9 | |
Kenny Levinsen | ffcde7a70c | |
Simon Ser | 087226d997 | |
Simon Ser | f11c5d562e | |
Kenny Levinsen | 1267e47de9 | |
Ferdinand Bachmann | bc258a3be2 | |
Daniel Kahn Gillmor | dcb142bf5e | |
Simon Ser | 9e14651077 | |
Kenny Levinsen | a4ef37752f | |
Kenny Levinsen | 26a9a6b479 | |
Kenny Levinsen | c3fca26d30 | |
Kenny Levinsen | 9becff0ba5 | |
Kenny Levinsen | 56e97b7d60 | |
Kenny Levinsen | 3b419020a3 | |
Kenny Levinsen | 98be797356 | |
Kenny Levinsen | 923f642b70 | |
Kenny Levinsen | 3e03eb3a01 | |
Kenny Levinsen | e2f3ebad8c | |
Ferdinand Bachmann | 125c74338a | |
Andri Yngvason | 5a7477cb8f | |
Simon Ser | dc9f217307 | |
Simon Ser | 9139da6149 | |
Simon Ser | 3bc75221bc | |
Simon Ser | 2b08e79061 | |
Alexander Orzechowski | 2e951163c5 | |
Simon Ser | 23389ebd1f | |
Simon Ser | 3ef5abd405 | |
Simon Ser | 4e6d7612ff | |
Simon Ser | f2a0e81b24 | |
Simon Ser | 59f6292383 | |
Simon Ser | fd9ab9ee06 | |
Ronan Pigott | 5e18ed3cf0 | |
Luofan Chen | 2058209a13 | |
llyyr | 0b84d82b9a | |
llyyr | 2867ef646b | |
Simon Ser | fca8474e9b | |
llyyr | 469411d484 | |
Simon Ser | 829c75b9c9 | |
Simon Ser | fc640d5f6c | |
Simon Ser | 07b0598526 | |
llyyr | d6150b6bb0 | |
Access | 7c11c463a3 | |
Aleksei Bavshin | d19810eba8 | |
Ronan Pigott | f6d22f8e68 | |
Simon Ser | 541e6e260c | |
Simon Ser | ca40663d42 | |
Kirill Primak | 7a2ff7ba81 | |
Alexander Orzechowski | 09c360d503 | |
Alexander Orzechowski | 1846944f04 | |
Alexander Orzechowski | 1dc661af17 | |
Merlin Lex | 1b5515400d | |
Simon Ser | 88b2abf5f2 | |
Simon Ser | 93d391651c | |
Simon Ser | f7a0f06dff | |
Simon Ser | ecfef1348a | |
Violet Purcell | 6b2aa83246 | |
Simon Ser | 88e99fa84f | |
Alexander Orzechowski | ba427a469a | |
Tamino Bauknecht | c8676fad54 | |
Simon Ser | e39b0b816b | |
Kirill Primak | f202bc84d2 | |
Kirill Primak | a4e85332a1 | |
Alexander Orzechowski | e8c421e917 | |
Daniel De Graaf | 2c2625acd3 | |
Simon Ser | 08a06a7b6b | |
Simon Ser | ae33f4eb37 | |
Alexander Orzechowski | 5fc85c5066 | |
Alexander Orzechowski | 7c635b61fe | |
Alexander Orzechowski | bab6b79af2 | |
Alexander Orzechowski | 9da295c11f | |
Alexander Orzechowski | 09e11dabb2 | |
Alexander Orzechowski | 2e53de80bb | |
Alexander Orzechowski | 5f0801b6f2 | |
Alexander Orzechowski | 1e018e72b4 | |
Alexander Orzechowski | 06ad734e70 | |
Alexander Orzechowski | ed2724bd6c | |
Alexander Orzechowski | 6e5fc4c2aa | |
Alexander Orzechowski | b38ed8b479 | |
Alexander Orzechowski | 08c484f46f | |
Alexander Orzechowski | 6d7b1321db | |
Alexander Orzechowski | 188811f808 | |
Alexander Orzechowski | 5b8b505af5 | |
Alexander Orzechowski | 946fc80945 | |
Alexander Orzechowski | 869baff252 | |
Alexander Orzechowski | bac3ab5526 | |
Alexander Orzechowski | 9a57966606 | |
Alexander Orzechowski | 0639bde9fb | |
Alexander Orzechowski | c640c3015f | |
Alexander Orzechowski | 9c17cba0b2 | |
Alexander Orzechowski | 0e1a02bf0a | |
Alexander Orzechowski | 1b09238645 | |
Alexander Orzechowski | 1eb16d1367 | |
Alexander Orzechowski | dbd2fbf430 | |
Alexander Orzechowski | b4d7e84d38 | |
Kirill Primak | 2c69e19fd3 | |
Kirill Primak | 8d1b0cecd9 | |
Kirill Primak | 904d256581 | |
Simon Ser | c5fd8c050f | |
Simon Ser | 7e69a7076f | |
Simon Ser | fa294a9094 | |
Simon Ser | 95265fba59 | |
Billli11 | 0aceff7469 | |
Bill Li | 64d644f0da | |
Simon Ser | 22d0dd8bde | |
Alexander Orzechowski | bbabb9aae8 | |
Simon Ser | c6edbb7e5a | |
Simon Ser | e8a0205607 | |
Simon Ser | 607b8aed0c | |
Simon Ser | 7ad8c80bfe | |
Simon Ser | dbd70faf2e | |
Simon Ser | a6ef12d968 | |
Simon Ser | ff07eab85b | |
Simon Ser | b81c4da494 | |
Tamino Bauknecht | 255ff665c5 | |
Simon Ser | bf2b79b284 | |
mrusme | ae3acf26f8 | |
Alexander Orzechowski | f12023b1a2 | |
Sergei Trofimovich | 2cd73a33c2 | |
apreiml | bc7d15d64d | |
Manuel Stoeckl | e633fe0b40 | |
Manuel Stoeckl | 439122e887 | |
Manuel Stoeckl | 39b9c0d6ba | |
Kirill Primak | 47e6a1164c | |
Simon Ser | 128b6253a9 | |
Simon Ser | fd6d6f1d97 | |
llyyr | a946b1aecf | |
llyyr | 4ad15a4015 |
|
@ -38,9 +38,14 @@ tasks:
|
||||||
cd sway
|
cd sway
|
||||||
ninja -C build
|
ninja -C build
|
||||||
- build-no-xwayland: |
|
- build-no-xwayland: |
|
||||||
cd sway
|
cd wlroots
|
||||||
meson configure build -Dxwayland=disabled
|
meson configure build -Dxwayland=disabled
|
||||||
ninja -C build
|
ninja -C build
|
||||||
|
sudo ninja -C build install
|
||||||
|
|
||||||
|
cd ../sway
|
||||||
|
meson configure build --clearcache
|
||||||
|
ninja -C build
|
||||||
- build-static: |
|
- build-static: |
|
||||||
cd sway
|
cd sway
|
||||||
mkdir subprojects
|
mkdir subprojects
|
||||||
|
|
12
README.de.md
12
README.de.md
|
@ -2,13 +2,13 @@
|
||||||
Sway ist ein [i3](https://i3wm.org/)-kompatibler [Wayland](http://wayland.freedesktop.org/)-Compositor. Lies die [FAQ](https://github.com/swaywm/sway/wiki). Tritt dem [IRC Channel](https://web.libera.chat/gamja/?channels=#sway) bei (#sway on irc.libera.chat; Englisch).
|
Sway ist ein [i3](https://i3wm.org/)-kompatibler [Wayland](http://wayland.freedesktop.org/)-Compositor. Lies die [FAQ](https://github.com/swaywm/sway/wiki). Tritt dem [IRC Channel](https://web.libera.chat/gamja/?channels=#sway) bei (#sway on irc.libera.chat; Englisch).
|
||||||
|
|
||||||
## Signaturen
|
## Signaturen
|
||||||
Jedes Release wird mit dem PGP-Schlüssel [E88F5E48](https://keys.openpgp.org/search?q=34FF9526CFEF0E97A340E2E40FDE7BE0E88F5E48) signiert und auf GitHub veröffentlicht.
|
Jedes Release wird mit dem PGP-Schlüssel [E88F5E48](https://keys.openpgp.org/search?q=34FF9526CFEF0E97A340E2E40FDE7BE0E88F5E48) signiert und [auf GitHub](https://github.com/swaywm/sway/releases) veröffentlicht.
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
### Mit der Paketverwaltung
|
|
||||||
Sway kann in vielen Distributionen direkt durch die Paketverwaltung installiert werden. Das Paket sollte "sway" heißen. Falls es kein solches Paket gibt, kannst du im [Wiki](https://github.com/swaywm/sway/wiki/Unsupported-packages) (englisch) nach mehr Informationen bezüglich deiner Distribution suchen.
|
|
||||||
|
|
||||||
Falls du sway für deine eigene Distribution als Paket bereitstellen möchtest, solltest du die Entwickler per IRC oder E-Mail (sir@cmpwn.com) kontaktieren.
|
### Über die Paketverwaltung
|
||||||
|
|
||||||
|
Sway kann in vielen Distributionen direkt durch die Paketverwaltung installiert werden. Versuche einfach das Packet "sway" zu installieren.
|
||||||
|
|
||||||
### Quellcode selbst kompilieren
|
### Quellcode selbst kompilieren
|
||||||
|
|
||||||
|
@ -23,8 +23,8 @@ sway benötigt die folgenden Pakete:
|
||||||
* pango
|
* pango
|
||||||
* cairo
|
* cairo
|
||||||
* gdk-pixbuf2 (Optional, wird für das Benachrichtigungsfeld (System Tray) benötigt)
|
* gdk-pixbuf2 (Optional, wird für das Benachrichtigungsfeld (System Tray) benötigt)
|
||||||
* [scdoc](https://git.sr.ht/~sircmpwn/scdoc)\* (Optional, wird für die Dokumentation (Man Pages) benötigt)
|
* [scdoc](https://git.sr.ht/~sircmpwn/scdoc) (Optional, wird für die Dokumentation (Man Pages) benötigt)\*
|
||||||
* git\*
|
* git (Optional: Versionsinfo)\*
|
||||||
|
|
||||||
_\*Werden nur während des Kompilierens benötigt_
|
_\*Werden nur während des Kompilierens benötigt_
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,8 @@ Install dependencies:
|
||||||
* json-c
|
* json-c
|
||||||
* pango
|
* pango
|
||||||
* cairo
|
* cairo
|
||||||
* gdk-pixbuf2 (optional: system tray)
|
* gdk-pixbuf2 (optional: additional image formats for system tray)
|
||||||
|
* [swaybg] (optional: wallpaper)
|
||||||
* [scdoc] (optional: man pages) \*
|
* [scdoc] (optional: man pages) \*
|
||||||
* git (optional: version info) \*
|
* git (optional: version info) \*
|
||||||
|
|
||||||
|
@ -89,4 +90,5 @@ sway (gdm is known to work fairly well).
|
||||||
[GitHub releases]: https://github.com/swaywm/sway/releases
|
[GitHub releases]: https://github.com/swaywm/sway/releases
|
||||||
[Development setup]: https://github.com/swaywm/sway/wiki/Development-Setup
|
[Development setup]: https://github.com/swaywm/sway/wiki/Development-Setup
|
||||||
[wlroots]: https://gitlab.freedesktop.org/wlroots/wlroots
|
[wlroots]: https://gitlab.freedesktop.org/wlroots/wlroots
|
||||||
|
[swaybg]: https://github.com/swaywm/swaybg/
|
||||||
[scdoc]: https://git.sr.ht/~sircmpwn/scdoc
|
[scdoc]: https://git.sr.ht/~sircmpwn/scdoc
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <cairo.h>
|
#include <cairo.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include "gesture.h"
|
#include "gesture.h"
|
||||||
|
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200112L
|
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200112L
|
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
lib_sway_common = static_library(
|
lib_sway_common = static_library(
|
||||||
'sway-common',
|
'sway-common',
|
||||||
files(
|
files(
|
||||||
'background-image.c',
|
|
||||||
'cairo.c',
|
'cairo.c',
|
||||||
'gesture.c',
|
'gesture.c',
|
||||||
'ipc-client.c',
|
'ipc-client.c',
|
||||||
|
@ -14,7 +13,6 @@ lib_sway_common = static_library(
|
||||||
),
|
),
|
||||||
dependencies: [
|
dependencies: [
|
||||||
cairo,
|
cairo,
|
||||||
gdk_pixbuf,
|
|
||||||
pango,
|
pango,
|
||||||
pangocairo,
|
pangocairo,
|
||||||
wayland_client.partial_dependency(compile_args: true)
|
wayland_client.partial_dependency(compile_args: true)
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
|
@ -1,20 +0,0 @@
|
||||||
#ifndef _SWAY_BACKGROUND_IMAGE_H
|
|
||||||
#define _SWAY_BACKGROUND_IMAGE_H
|
|
||||||
#include "cairo_util.h"
|
|
||||||
|
|
||||||
enum background_mode {
|
|
||||||
BACKGROUND_MODE_STRETCH,
|
|
||||||
BACKGROUND_MODE_FILL,
|
|
||||||
BACKGROUND_MODE_FIT,
|
|
||||||
BACKGROUND_MODE_CENTER,
|
|
||||||
BACKGROUND_MODE_TILE,
|
|
||||||
BACKGROUND_MODE_SOLID_COLOR,
|
|
||||||
BACKGROUND_MODE_INVALID,
|
|
||||||
};
|
|
||||||
|
|
||||||
enum background_mode parse_background_mode(const char *mode);
|
|
||||||
cairo_surface_t *load_background_image(const char *path);
|
|
||||||
void render_background_image(cairo_t *cairo, cairo_surface_t *image,
|
|
||||||
enum background_mode mode, int buffer_width, int buffer_height);
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -291,6 +291,14 @@ struct output_config {
|
||||||
char *background_fallback;
|
char *background_fallback;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An output config pre-matched to an output
|
||||||
|
*/
|
||||||
|
struct matched_output_config {
|
||||||
|
struct sway_output *output;
|
||||||
|
struct output_config *config;
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stores size of gaps for each side
|
* Stores size of gaps for each side
|
||||||
*/
|
*/
|
||||||
|
@ -680,20 +688,25 @@ const char *sway_output_scale_filter_to_string(enum scale_filter_mode scale_filt
|
||||||
|
|
||||||
struct output_config *new_output_config(const char *name);
|
struct output_config *new_output_config(const char *name);
|
||||||
|
|
||||||
void merge_output_config(struct output_config *dst, struct output_config *src);
|
bool apply_output_configs(struct matched_output_config *configs,
|
||||||
|
size_t configs_len, bool test_only, bool degrade_to_off);
|
||||||
|
|
||||||
bool apply_output_config(struct output_config *oc, struct sway_output *output);
|
void apply_all_output_configs(void);
|
||||||
|
|
||||||
bool test_output_config(struct output_config *oc, struct sway_output *output);
|
void sort_output_configs_by_priority(struct matched_output_config *configs,
|
||||||
|
size_t configs_len);
|
||||||
|
|
||||||
struct output_config *store_output_config(struct output_config *oc);
|
/**
|
||||||
|
* store_output_config stores a new output config. An output may be matched by
|
||||||
|
* three different config types, in order of precedence: Identifier, name and
|
||||||
|
* wildcard. When storing a config type of lower precedence, assume that the
|
||||||
|
* user wants the config to take immediate effect by superseding (clearing) the
|
||||||
|
* same values from higher presedence configuration.
|
||||||
|
*/
|
||||||
|
void store_output_config(struct output_config *oc);
|
||||||
|
|
||||||
struct output_config *find_output_config(struct sway_output *output);
|
struct output_config *find_output_config(struct sway_output *output);
|
||||||
|
|
||||||
void apply_output_config_to_outputs(struct output_config *oc);
|
|
||||||
|
|
||||||
void reset_outputs(void);
|
|
||||||
|
|
||||||
void free_output_config(struct output_config *oc);
|
void free_output_config(struct output_config *oc);
|
||||||
|
|
||||||
bool spawn_swaybg(void);
|
bool spawn_swaybg(void);
|
||||||
|
|
|
@ -7,6 +7,10 @@
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
#include "tree/view.h"
|
#include "tree/view.h"
|
||||||
|
|
||||||
|
#if WLR_HAS_XWAYLAND
|
||||||
|
#include "sway/xwayland.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
enum criteria_type {
|
enum criteria_type {
|
||||||
CT_COMMAND = 1 << 0,
|
CT_COMMAND = 1 << 0,
|
||||||
CT_ASSIGN_OUTPUT = 1 << 1,
|
CT_ASSIGN_OUTPUT = 1 << 1,
|
||||||
|
@ -36,7 +40,7 @@ struct criteria {
|
||||||
struct pattern *app_id;
|
struct pattern *app_id;
|
||||||
struct pattern *con_mark;
|
struct pattern *con_mark;
|
||||||
uint32_t con_id; // internal ID
|
uint32_t con_id; // internal ID
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
struct pattern *class;
|
struct pattern *class;
|
||||||
uint32_t id; // X11 window ID
|
uint32_t id; // X11 window ID
|
||||||
struct pattern *instance;
|
struct pattern *instance;
|
||||||
|
|
|
@ -1,13 +0,0 @@
|
||||||
#include <wlr/types/wlr_compositor.h>
|
|
||||||
|
|
||||||
struct sway_container;
|
|
||||||
struct sway_view;
|
|
||||||
|
|
||||||
void desktop_damage_surface(struct wlr_surface *surface, double lx, double ly,
|
|
||||||
bool whole);
|
|
||||||
|
|
||||||
void desktop_damage_whole_container(struct sway_container *con);
|
|
||||||
|
|
||||||
void desktop_damage_box(struct wlr_box *box);
|
|
||||||
|
|
||||||
void desktop_damage_view(struct sway_view *view);
|
|
|
@ -3,14 +3,18 @@
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <wayland-server-core.h>
|
#include <wayland-server-core.h>
|
||||||
|
#include "sway/input/seat.h"
|
||||||
|
|
||||||
struct launcher_ctx {
|
struct launcher_ctx {
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
char *fallback_name;
|
char *fallback_name;
|
||||||
struct wlr_xdg_activation_token_v1 *token;
|
struct wlr_xdg_activation_token_v1 *token;
|
||||||
struct wl_listener token_destroy;
|
struct wl_listener token_destroy;
|
||||||
|
struct sway_seat *seat;
|
||||||
|
struct wl_listener seat_destroy;
|
||||||
|
|
||||||
bool activated;
|
bool activated;
|
||||||
|
bool had_focused_surface;
|
||||||
|
|
||||||
struct sway_node *node;
|
struct sway_node *node;
|
||||||
struct wl_listener node_destroy;
|
struct wl_listener node_destroy;
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
#ifndef _SWAY_TRANSACTION_H
|
#ifndef _SWAY_TRANSACTION_H
|
||||||
#define _SWAY_TRANSACTION_H
|
#define _SWAY_TRANSACTION_H
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Transactions enable us to perform atomic layout updates.
|
* Transactions enable us to perform atomic layout updates.
|
||||||
|
@ -38,8 +40,11 @@ void transaction_commit_dirty_client(void);
|
||||||
* Notify the transaction system that a view is ready for the new layout.
|
* Notify the transaction system that a view is ready for the new layout.
|
||||||
*
|
*
|
||||||
* When all views in the transaction are ready, the layout will be applied.
|
* When all views in the transaction are ready, the layout will be applied.
|
||||||
|
*
|
||||||
|
* A success boolean is returned denoting that this part of the transaction is
|
||||||
|
* ready.
|
||||||
*/
|
*/
|
||||||
void transaction_notify_view_ready_by_serial(struct sway_view *view,
|
bool transaction_notify_view_ready_by_serial(struct sway_view *view,
|
||||||
uint32_t serial);
|
uint32_t serial);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -47,8 +52,13 @@ void transaction_notify_view_ready_by_serial(struct sway_view *view,
|
||||||
* identifying the instruction by geometry rather than by serial.
|
* identifying the instruction by geometry rather than by serial.
|
||||||
*
|
*
|
||||||
* This is used by xwayland views, as they don't have serials.
|
* This is used by xwayland views, as they don't have serials.
|
||||||
|
*
|
||||||
|
* A success boolean is returned denoting that this part of the transaction is
|
||||||
|
* ready.
|
||||||
*/
|
*/
|
||||||
void transaction_notify_view_ready_by_geometry(struct sway_view *view,
|
bool transaction_notify_view_ready_by_geometry(struct sway_view *view,
|
||||||
double x, double y, int width, int height);
|
double x, double y, int width, int height);
|
||||||
|
|
||||||
|
void arrange_popups(struct wlr_scene_tree *popups);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -114,7 +114,7 @@ void pointer_motion(struct sway_cursor *cursor, uint32_t time_msec,
|
||||||
|
|
||||||
void dispatch_cursor_button(struct sway_cursor *cursor,
|
void dispatch_cursor_button(struct sway_cursor *cursor,
|
||||||
struct wlr_input_device *device, uint32_t time_msec, uint32_t button,
|
struct wlr_input_device *device, uint32_t time_msec, uint32_t button,
|
||||||
enum wlr_button_state state);
|
enum wl_pointer_button_state state);
|
||||||
|
|
||||||
void dispatch_cursor_axis(struct sway_cursor *cursor,
|
void dispatch_cursor_axis(struct sway_cursor *cursor,
|
||||||
struct wlr_pointer_axis_event *event);
|
struct wlr_pointer_axis_event *event);
|
||||||
|
|
|
@ -1,14 +1,15 @@
|
||||||
#ifndef _SWAY_INPUT_INPUT_MANAGER_H
|
#ifndef _SWAY_INPUT_INPUT_MANAGER_H
|
||||||
#define _SWAY_INPUT_INPUT_MANAGER_H
|
#define _SWAY_INPUT_INPUT_MANAGER_H
|
||||||
#include <libinput.h>
|
#include <libinput.h>
|
||||||
#include <wlr/types/wlr_input_inhibitor.h>
|
|
||||||
#include <wlr/types/wlr_keyboard_shortcuts_inhibit_v1.h>
|
#include <wlr/types/wlr_keyboard_shortcuts_inhibit_v1.h>
|
||||||
#include <wlr/types/wlr_virtual_keyboard_v1.h>
|
#include <wlr/types/wlr_virtual_keyboard_v1.h>
|
||||||
#include <wlr/types/wlr_virtual_pointer_v1.h>
|
#include <wlr/types/wlr_virtual_pointer_v1.h>
|
||||||
#include "sway/server.h"
|
#include <wlr/types/wlr_transient_seat_v1.h>
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
|
|
||||||
|
struct sway_server;
|
||||||
|
|
||||||
struct sway_input_device {
|
struct sway_input_device {
|
||||||
char *identifier;
|
char *identifier;
|
||||||
struct wlr_input_device *wlr_device;
|
struct wlr_input_device *wlr_device;
|
||||||
|
@ -21,11 +22,11 @@ struct sway_input_manager {
|
||||||
struct wl_list devices;
|
struct wl_list devices;
|
||||||
struct wl_list seats;
|
struct wl_list seats;
|
||||||
|
|
||||||
struct wlr_input_inhibit_manager *inhibit;
|
|
||||||
struct wlr_keyboard_shortcuts_inhibit_manager_v1 *keyboard_shortcuts_inhibit;
|
struct wlr_keyboard_shortcuts_inhibit_manager_v1 *keyboard_shortcuts_inhibit;
|
||||||
struct wlr_virtual_keyboard_manager_v1 *virtual_keyboard;
|
struct wlr_virtual_keyboard_manager_v1 *virtual_keyboard;
|
||||||
struct wlr_virtual_pointer_manager_v1 *virtual_pointer;
|
struct wlr_virtual_pointer_manager_v1 *virtual_pointer;
|
||||||
struct wlr_pointer_gestures_v1 *pointer_gestures;
|
struct wlr_pointer_gestures_v1 *pointer_gestures;
|
||||||
|
struct wlr_transient_seat_manager_v1 *transient_seat_manager;
|
||||||
|
|
||||||
struct wl_listener new_input;
|
struct wl_listener new_input;
|
||||||
struct wl_listener inhibit_activate;
|
struct wl_listener inhibit_activate;
|
||||||
|
@ -33,6 +34,7 @@ struct sway_input_manager {
|
||||||
struct wl_listener keyboard_shortcuts_inhibit_new_inhibitor;
|
struct wl_listener keyboard_shortcuts_inhibit_new_inhibitor;
|
||||||
struct wl_listener virtual_keyboard_new;
|
struct wl_listener virtual_keyboard_new;
|
||||||
struct wl_listener virtual_pointer_new;
|
struct wl_listener virtual_pointer_new;
|
||||||
|
struct wl_listener transient_seat_create;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct sway_input_manager *input_manager_create(struct sway_server *server);
|
struct sway_input_manager *input_manager_create(struct sway_server *server);
|
||||||
|
|
|
@ -4,6 +4,9 @@
|
||||||
|
|
||||||
bool sway_input_configure_libinput_device(struct sway_input_device *device);
|
bool sway_input_configure_libinput_device(struct sway_input_device *device);
|
||||||
|
|
||||||
|
void sway_input_configure_libinput_device_send_events(
|
||||||
|
struct sway_input_device *device);
|
||||||
|
|
||||||
void sway_input_reset_libinput_device(struct sway_input_device *device);
|
void sway_input_reset_libinput_device(struct sway_input_device *device);
|
||||||
|
|
||||||
bool sway_libinput_device_is_builtin(struct sway_input_device *device);
|
bool sway_libinput_device_is_builtin(struct sway_input_device *device);
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
|
|
||||||
#include <wlr/types/wlr_keyboard_shortcuts_inhibit_v1.h>
|
#include <wlr/types/wlr_keyboard_shortcuts_inhibit_v1.h>
|
||||||
#include <wlr/types/wlr_layer_shell_v1.h>
|
#include <wlr/types/wlr_layer_shell_v1.h>
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
#include <wlr/types/wlr_seat.h>
|
#include <wlr/types/wlr_seat.h>
|
||||||
#include <wlr/types/wlr_touch.h>
|
#include <wlr/types/wlr_touch.h>
|
||||||
#include <wlr/util/edges.h>
|
#include <wlr/util/edges.h>
|
||||||
|
@ -12,12 +13,11 @@
|
||||||
#include "sway/input/text_input.h"
|
#include "sway/input/text_input.h"
|
||||||
|
|
||||||
struct sway_seat;
|
struct sway_seat;
|
||||||
struct render_context;
|
|
||||||
|
|
||||||
struct sway_seatop_impl {
|
struct sway_seatop_impl {
|
||||||
void (*button)(struct sway_seat *seat, uint32_t time_msec,
|
void (*button)(struct sway_seat *seat, uint32_t time_msec,
|
||||||
struct wlr_input_device *device, uint32_t button,
|
struct wlr_input_device *device, uint32_t button,
|
||||||
enum wlr_button_state state);
|
enum wl_pointer_button_state state);
|
||||||
void (*pointer_motion)(struct sway_seat *seat, uint32_t time_msec);
|
void (*pointer_motion)(struct sway_seat *seat, uint32_t time_msec);
|
||||||
void (*pointer_axis)(struct sway_seat *seat,
|
void (*pointer_axis)(struct sway_seat *seat,
|
||||||
struct wlr_pointer_axis_event *event);
|
struct wlr_pointer_axis_event *event);
|
||||||
|
@ -52,7 +52,6 @@ struct sway_seatop_impl {
|
||||||
uint32_t time_msec, enum wlr_tablet_tool_tip_state state);
|
uint32_t time_msec, enum wlr_tablet_tool_tip_state state);
|
||||||
void (*end)(struct sway_seat *seat);
|
void (*end)(struct sway_seat *seat);
|
||||||
void (*unref)(struct sway_seat *seat, struct sway_container *con);
|
void (*unref)(struct sway_seat *seat, struct sway_container *con);
|
||||||
void (*render)(struct sway_seat *seat, struct render_context *ctx);
|
|
||||||
bool allow_set_cursor;
|
bool allow_set_cursor;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -75,20 +74,6 @@ struct sway_seat_node {
|
||||||
struct wl_listener destroy;
|
struct wl_listener destroy;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct sway_drag_icon {
|
|
||||||
struct sway_seat *seat;
|
|
||||||
struct wlr_drag_icon *wlr_drag_icon;
|
|
||||||
struct wl_list link; // sway_root::drag_icons
|
|
||||||
|
|
||||||
double x, y; // in layout-local coordinates
|
|
||||||
int dx, dy; // offset in surface-local coordinates
|
|
||||||
|
|
||||||
struct wl_listener surface_commit;
|
|
||||||
struct wl_listener map;
|
|
||||||
struct wl_listener unmap;
|
|
||||||
struct wl_listener destroy;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct sway_drag {
|
struct sway_drag {
|
||||||
struct sway_seat *seat;
|
struct sway_seat *seat;
|
||||||
struct wlr_drag *wlr_drag;
|
struct wlr_drag *wlr_drag;
|
||||||
|
@ -99,6 +84,15 @@ struct sway_seat {
|
||||||
struct wlr_seat *wlr_seat;
|
struct wlr_seat *wlr_seat;
|
||||||
struct sway_cursor *cursor;
|
struct sway_cursor *cursor;
|
||||||
|
|
||||||
|
// Seat scene tree structure
|
||||||
|
// - scene_tree
|
||||||
|
// - drag icons
|
||||||
|
// - drag icon 1
|
||||||
|
// - drag icon 2
|
||||||
|
// - seatop specific stuff
|
||||||
|
struct wlr_scene_tree *scene_tree;
|
||||||
|
struct wlr_scene_tree *drag_icons;
|
||||||
|
|
||||||
bool has_focus;
|
bool has_focus;
|
||||||
struct wl_list focus_stack; // list of containers in focus order
|
struct wl_list focus_stack; // list of containers in focus order
|
||||||
struct sway_workspace *workspace;
|
struct sway_workspace *workspace;
|
||||||
|
@ -108,9 +102,6 @@ struct sway_seat {
|
||||||
// If the exclusive layer is set, views cannot receive keyboard focus
|
// If the exclusive layer is set, views cannot receive keyboard focus
|
||||||
bool has_exclusive_layer;
|
bool has_exclusive_layer;
|
||||||
|
|
||||||
// If exclusive_client is set, no other clients will receive input events
|
|
||||||
struct wl_client *exclusive_client;
|
|
||||||
|
|
||||||
// Last touch point
|
// Last touch point
|
||||||
int32_t touch_id;
|
int32_t touch_id;
|
||||||
double touch_x, touch_y;
|
double touch_x, touch_y;
|
||||||
|
@ -133,6 +124,7 @@ struct sway_seat {
|
||||||
struct wl_listener start_drag;
|
struct wl_listener start_drag;
|
||||||
struct wl_listener request_set_selection;
|
struct wl_listener request_set_selection;
|
||||||
struct wl_listener request_set_primary_selection;
|
struct wl_listener request_set_primary_selection;
|
||||||
|
struct wl_listener destroy;
|
||||||
|
|
||||||
struct wl_list devices; // sway_seat_device::link
|
struct wl_list devices; // sway_seat_device::link
|
||||||
struct wl_list keyboard_groups; // sway_keyboard_group::link
|
struct wl_list keyboard_groups; // sway_keyboard_group::link
|
||||||
|
@ -201,8 +193,7 @@ void seat_set_focus_surface(struct sway_seat *seat,
|
||||||
void seat_set_focus_layer(struct sway_seat *seat,
|
void seat_set_focus_layer(struct sway_seat *seat,
|
||||||
struct wlr_layer_surface_v1 *layer);
|
struct wlr_layer_surface_v1 *layer);
|
||||||
|
|
||||||
void seat_set_exclusive_client(struct sway_seat *seat,
|
void seat_unfocus_unless_client(struct sway_seat *seat, struct wl_client *client);
|
||||||
struct wl_client *client);
|
|
||||||
|
|
||||||
struct sway_node *seat_get_focus(struct sway_seat *seat);
|
struct sway_node *seat_get_focus(struct sway_seat *seat);
|
||||||
|
|
||||||
|
@ -261,7 +252,7 @@ void seat_idle_notify_activity(struct sway_seat *seat,
|
||||||
|
|
||||||
bool seat_is_input_allowed(struct sway_seat *seat, struct wlr_surface *surface);
|
bool seat_is_input_allowed(struct sway_seat *seat, struct wlr_surface *surface);
|
||||||
|
|
||||||
void drag_icon_update_position(struct sway_drag_icon *icon);
|
void drag_icons_update_position(struct sway_seat *seat);
|
||||||
|
|
||||||
enum wlr_edges find_resize_edge(struct sway_container *cont,
|
enum wlr_edges find_resize_edge(struct sway_container *cont,
|
||||||
struct wlr_surface *surface, struct sway_cursor *cursor);
|
struct wlr_surface *surface, struct sway_cursor *cursor);
|
||||||
|
@ -296,13 +287,13 @@ struct sway_container *seat_get_focus_inactive_floating(struct sway_seat *seat,
|
||||||
struct sway_workspace *workspace);
|
struct sway_workspace *workspace);
|
||||||
|
|
||||||
void seat_pointer_notify_button(struct sway_seat *seat, uint32_t time_msec,
|
void seat_pointer_notify_button(struct sway_seat *seat, uint32_t time_msec,
|
||||||
uint32_t button, enum wlr_button_state state);
|
uint32_t button, enum wl_pointer_button_state state);
|
||||||
|
|
||||||
void seat_consider_warp_to_focus(struct sway_seat *seat);
|
void seat_consider_warp_to_focus(struct sway_seat *seat);
|
||||||
|
|
||||||
void seatop_button(struct sway_seat *seat, uint32_t time_msec,
|
void seatop_button(struct sway_seat *seat, uint32_t time_msec,
|
||||||
struct wlr_input_device *device, uint32_t button,
|
struct wlr_input_device *device, uint32_t button,
|
||||||
enum wlr_button_state state);
|
enum wl_pointer_button_state state);
|
||||||
|
|
||||||
void seatop_pointer_motion(struct sway_seat *seat, uint32_t time_msec);
|
void seatop_pointer_motion(struct sway_seat *seat, uint32_t time_msec);
|
||||||
|
|
||||||
|
@ -361,12 +352,6 @@ void seatop_end(struct sway_seat *seat);
|
||||||
*/
|
*/
|
||||||
void seatop_unref(struct sway_seat *seat, struct sway_container *con);
|
void seatop_unref(struct sway_seat *seat, struct sway_container *con);
|
||||||
|
|
||||||
/**
|
|
||||||
* Instructs a seatop to render anything that it needs to render
|
|
||||||
* (eg. dropzone for move-tiling)
|
|
||||||
*/
|
|
||||||
void seatop_render(struct sway_seat *seat, struct render_context *ctx);
|
|
||||||
|
|
||||||
bool seatop_allows_set_cursor(struct sway_seat *seat);
|
bool seatop_allows_set_cursor(struct sway_seat *seat);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -21,18 +21,21 @@ struct sway_input_method_relay {
|
||||||
struct sway_seat *seat;
|
struct sway_seat *seat;
|
||||||
|
|
||||||
struct wl_list text_inputs; // sway_text_input::link
|
struct wl_list text_inputs; // sway_text_input::link
|
||||||
|
struct wl_list input_popups; // sway_input_popup::link
|
||||||
struct wlr_input_method_v2 *input_method; // doesn't have to be present
|
struct wlr_input_method_v2 *input_method; // doesn't have to be present
|
||||||
|
|
||||||
struct wl_listener text_input_new;
|
struct wl_listener text_input_new;
|
||||||
|
|
||||||
struct wl_listener input_method_new;
|
struct wl_listener input_method_new;
|
||||||
struct wl_listener input_method_commit;
|
struct wl_listener input_method_commit;
|
||||||
|
struct wl_listener input_method_new_popup_surface;
|
||||||
struct wl_listener input_method_grab_keyboard;
|
struct wl_listener input_method_grab_keyboard;
|
||||||
struct wl_listener input_method_destroy;
|
struct wl_listener input_method_destroy;
|
||||||
|
|
||||||
struct wl_listener input_method_keyboard_grab_destroy;
|
struct wl_listener input_method_keyboard_grab_destroy;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
struct sway_text_input {
|
struct sway_text_input {
|
||||||
struct sway_input_method_relay *relay;
|
struct sway_input_method_relay *relay;
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
#ifndef _SWAY_INPUT_TEXT_INPUT_POPUP_H
|
||||||
|
#define _SWAY_INPUT_TEXT_INPUT_POPUP_H
|
||||||
|
|
||||||
|
#include "sway/tree/view.h"
|
||||||
|
|
||||||
|
struct sway_input_popup {
|
||||||
|
struct sway_input_method_relay *relay;
|
||||||
|
|
||||||
|
struct wlr_scene_tree *scene_tree;
|
||||||
|
struct sway_popup_desc desc;
|
||||||
|
struct wlr_input_popup_surface_v2 *popup_surface;
|
||||||
|
|
||||||
|
struct wl_list link;
|
||||||
|
|
||||||
|
struct wl_listener popup_destroy;
|
||||||
|
struct wl_listener popup_surface_commit;
|
||||||
|
|
||||||
|
struct wl_listener focused_surface_unmap;
|
||||||
|
};
|
||||||
|
#endif
|
|
@ -3,54 +3,34 @@
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <wlr/types/wlr_compositor.h>
|
#include <wlr/types/wlr_compositor.h>
|
||||||
#include <wlr/types/wlr_layer_shell_v1.h>
|
#include <wlr/types/wlr_layer_shell_v1.h>
|
||||||
|
#include "sway/tree/view.h"
|
||||||
enum layer_parent {
|
|
||||||
LAYER_PARENT_LAYER,
|
|
||||||
LAYER_PARENT_POPUP,
|
|
||||||
};
|
|
||||||
|
|
||||||
struct sway_layer_surface {
|
struct sway_layer_surface {
|
||||||
struct wlr_layer_surface_v1 *layer_surface;
|
|
||||||
struct wl_list link;
|
|
||||||
|
|
||||||
struct wl_listener destroy;
|
|
||||||
struct wl_listener map;
|
struct wl_listener map;
|
||||||
struct wl_listener unmap;
|
struct wl_listener unmap;
|
||||||
struct wl_listener surface_commit;
|
struct wl_listener surface_commit;
|
||||||
struct wl_listener output_destroy;
|
struct wl_listener output_destroy;
|
||||||
|
struct wl_listener node_destroy;
|
||||||
struct wl_listener new_popup;
|
struct wl_listener new_popup;
|
||||||
struct wl_listener new_subsurface;
|
|
||||||
|
|
||||||
struct wlr_box geo;
|
|
||||||
bool mapped;
|
bool mapped;
|
||||||
struct wlr_box extent;
|
|
||||||
enum zwlr_layer_shell_v1_layer layer;
|
|
||||||
|
|
||||||
struct wl_list subsurfaces;
|
struct wlr_scene_tree *popups;
|
||||||
|
struct sway_popup_desc desc;
|
||||||
|
|
||||||
|
struct sway_output *output;
|
||||||
|
struct wlr_scene_layer_surface_v1 *scene;
|
||||||
|
struct wlr_scene_tree *tree;
|
||||||
|
struct wlr_layer_surface_v1 *layer_surface;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct sway_layer_popup {
|
struct sway_layer_popup {
|
||||||
struct wlr_xdg_popup *wlr_popup;
|
struct wlr_xdg_popup *wlr_popup;
|
||||||
enum layer_parent parent_type;
|
struct wlr_scene_tree *scene;
|
||||||
union {
|
struct sway_layer_surface *toplevel;
|
||||||
struct sway_layer_surface *parent_layer;
|
|
||||||
struct sway_layer_popup *parent_popup;
|
|
||||||
};
|
|
||||||
struct wl_listener map;
|
|
||||||
struct wl_listener unmap;
|
|
||||||
struct wl_listener destroy;
|
struct wl_listener destroy;
|
||||||
struct wl_listener commit;
|
|
||||||
struct wl_listener new_popup;
|
struct wl_listener new_popup;
|
||||||
};
|
|
||||||
|
|
||||||
struct sway_layer_subsurface {
|
|
||||||
struct wlr_subsurface *wlr_subsurface;
|
|
||||||
struct sway_layer_surface *layer_surface;
|
|
||||||
struct wl_list link;
|
|
||||||
|
|
||||||
struct wl_listener map;
|
|
||||||
struct wl_listener unmap;
|
|
||||||
struct wl_listener destroy;
|
|
||||||
struct wl_listener commit;
|
struct wl_listener commit;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -61,7 +41,4 @@ struct wlr_layer_surface_v1 *toplevel_layer_surface_from_surface(
|
||||||
|
|
||||||
void arrange_layers(struct sway_output *output);
|
void arrange_layers(struct sway_output *output);
|
||||||
|
|
||||||
struct sway_layer_surface *layer_from_wlr_layer_surface_v1(
|
|
||||||
struct wlr_layer_surface_v1 *layer_surface);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include <wayland-server-core.h>
|
#include <wayland-server-core.h>
|
||||||
#include <wlr/types/wlr_damage_ring.h>
|
#include <wlr/types/wlr_damage_ring.h>
|
||||||
#include <wlr/types/wlr_output.h>
|
#include <wlr/types/wlr_output.h>
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "sway/tree/node.h"
|
#include "sway/tree/node.h"
|
||||||
#include "sway/tree/view.h"
|
#include "sway/tree/view.h"
|
||||||
|
@ -19,32 +20,46 @@ struct sway_output_state {
|
||||||
|
|
||||||
struct sway_output {
|
struct sway_output {
|
||||||
struct sway_node node;
|
struct sway_node node;
|
||||||
|
|
||||||
|
struct {
|
||||||
|
struct wlr_scene_tree *shell_background;
|
||||||
|
struct wlr_scene_tree *shell_bottom;
|
||||||
|
struct wlr_scene_tree *tiling;
|
||||||
|
struct wlr_scene_tree *fullscreen;
|
||||||
|
struct wlr_scene_tree *shell_top;
|
||||||
|
struct wlr_scene_tree *shell_overlay;
|
||||||
|
struct wlr_scene_tree *session_lock;
|
||||||
|
} layers;
|
||||||
|
|
||||||
|
// when a container is fullscreen, in case the fullscreen surface is
|
||||||
|
// translucent (can see behind) we must make sure that the background is a
|
||||||
|
// solid color in order to conform to the wayland protocol. This rect
|
||||||
|
// ensures that when looking through a surface, all that will be seen
|
||||||
|
// is black.
|
||||||
|
struct wlr_scene_rect *fullscreen_background;
|
||||||
|
|
||||||
struct wlr_output *wlr_output;
|
struct wlr_output *wlr_output;
|
||||||
|
struct wlr_scene_output *scene_output;
|
||||||
struct sway_server *server;
|
struct sway_server *server;
|
||||||
struct wl_list link;
|
struct wl_list link;
|
||||||
|
|
||||||
struct wl_list layers[4]; // sway_layer_surface::link
|
|
||||||
struct wlr_box usable_area;
|
struct wlr_box usable_area;
|
||||||
|
|
||||||
struct timespec last_frame;
|
|
||||||
struct wlr_damage_ring damage_ring;
|
|
||||||
|
|
||||||
int lx, ly; // layout coords
|
int lx, ly; // layout coords
|
||||||
int width, height; // transformed buffer size
|
int width, height; // transformed buffer size
|
||||||
enum wl_output_subpixel detected_subpixel;
|
enum wl_output_subpixel detected_subpixel;
|
||||||
enum scale_filter_mode scale_filter;
|
enum scale_filter_mode scale_filter;
|
||||||
|
|
||||||
bool enabling, enabled;
|
bool enabled;
|
||||||
list_t *workspaces;
|
list_t *workspaces;
|
||||||
|
|
||||||
struct sway_output_state current;
|
struct sway_output_state current;
|
||||||
|
|
||||||
|
struct wl_listener layout_destroy;
|
||||||
struct wl_listener destroy;
|
struct wl_listener destroy;
|
||||||
struct wl_listener commit;
|
struct wl_listener commit;
|
||||||
struct wl_listener present;
|
struct wl_listener present;
|
||||||
struct wl_listener damage;
|
|
||||||
struct wl_listener frame;
|
struct wl_listener frame;
|
||||||
struct wl_listener needs_frame;
|
|
||||||
struct wl_listener request_state;
|
struct wl_listener request_state;
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
|
@ -64,14 +79,6 @@ struct sway_output_non_desktop {
|
||||||
struct wl_listener destroy;
|
struct wl_listener destroy;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct render_context {
|
|
||||||
struct sway_output *output;
|
|
||||||
struct wlr_renderer *renderer;
|
|
||||||
const pixman_region32_t *output_damage;
|
|
||||||
|
|
||||||
struct wlr_render_pass *pass;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct sway_output *output_create(struct wlr_output *wlr_output);
|
struct sway_output *output_create(struct wlr_output *wlr_output);
|
||||||
|
|
||||||
void output_destroy(struct sway_output *output);
|
void output_destroy(struct sway_output *output);
|
||||||
|
@ -90,19 +97,6 @@ typedef void (*sway_surface_iterator_func_t)(struct sway_output *output,
|
||||||
struct sway_view *view, struct wlr_surface *surface, struct wlr_box *box,
|
struct sway_view *view, struct wlr_surface *surface, struct wlr_box *box,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
void output_damage_whole(struct sway_output *output);
|
|
||||||
|
|
||||||
void output_damage_surface(struct sway_output *output, double ox, double oy,
|
|
||||||
struct wlr_surface *surface, bool whole);
|
|
||||||
|
|
||||||
void output_damage_from_view(struct sway_output *output,
|
|
||||||
struct sway_view *view);
|
|
||||||
|
|
||||||
void output_damage_box(struct sway_output *output, struct wlr_box *box);
|
|
||||||
|
|
||||||
void output_damage_whole_container(struct sway_output *output,
|
|
||||||
struct sway_container *con);
|
|
||||||
|
|
||||||
bool output_match_name_or_id(struct sway_output *output,
|
bool output_match_name_or_id(struct sway_output *output,
|
||||||
const char *name_or_id);
|
const char *name_or_id);
|
||||||
|
|
||||||
|
@ -118,46 +112,8 @@ void output_enable(struct sway_output *output);
|
||||||
|
|
||||||
void output_disable(struct sway_output *output);
|
void output_disable(struct sway_output *output);
|
||||||
|
|
||||||
bool output_has_opaque_overlay_layer_surface(struct sway_output *output);
|
|
||||||
|
|
||||||
struct sway_workspace *output_get_active_workspace(struct sway_output *output);
|
struct sway_workspace *output_get_active_workspace(struct sway_output *output);
|
||||||
|
|
||||||
void output_render(struct render_context *ctx);
|
|
||||||
|
|
||||||
void output_surface_for_each_surface(struct sway_output *output,
|
|
||||||
struct wlr_surface *surface, double ox, double oy,
|
|
||||||
sway_surface_iterator_func_t iterator, void *user_data);
|
|
||||||
|
|
||||||
void output_view_for_each_surface(struct sway_output *output,
|
|
||||||
struct sway_view *view, sway_surface_iterator_func_t iterator,
|
|
||||||
void *user_data);
|
|
||||||
|
|
||||||
void output_view_for_each_popup_surface(struct sway_output *output,
|
|
||||||
struct sway_view *view, sway_surface_iterator_func_t iterator,
|
|
||||||
void *user_data);
|
|
||||||
|
|
||||||
void output_layer_for_each_surface(struct sway_output *output,
|
|
||||||
struct wl_list *layer_surfaces, sway_surface_iterator_func_t iterator,
|
|
||||||
void *user_data);
|
|
||||||
|
|
||||||
void output_layer_for_each_toplevel_surface(struct sway_output *output,
|
|
||||||
struct wl_list *layer_surfaces, sway_surface_iterator_func_t iterator,
|
|
||||||
void *user_data);
|
|
||||||
|
|
||||||
void output_layer_for_each_popup_surface(struct sway_output *output,
|
|
||||||
struct wl_list *layer_surfaces, sway_surface_iterator_func_t iterator,
|
|
||||||
void *user_data);
|
|
||||||
|
|
||||||
#if HAVE_XWAYLAND
|
|
||||||
void output_unmanaged_for_each_surface(struct sway_output *output,
|
|
||||||
struct wl_list *unmanaged, sway_surface_iterator_func_t iterator,
|
|
||||||
void *user_data);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void output_drag_icons_for_each_surface(struct sway_output *output,
|
|
||||||
struct wl_list *drag_icons, sway_surface_iterator_func_t iterator,
|
|
||||||
void *user_data);
|
|
||||||
|
|
||||||
void output_for_each_workspace(struct sway_output *output,
|
void output_for_each_workspace(struct sway_output *output,
|
||||||
void (*f)(struct sway_workspace *ws, void *data), void *data);
|
void (*f)(struct sway_workspace *ws, void *data), void *data);
|
||||||
|
|
||||||
|
@ -175,13 +131,6 @@ void output_get_box(struct sway_output *output, struct wlr_box *box);
|
||||||
enum sway_container_layout output_get_default_layout(
|
enum sway_container_layout output_get_default_layout(
|
||||||
struct sway_output *output);
|
struct sway_output *output);
|
||||||
|
|
||||||
void render_rect(struct render_context *ctx, const struct wlr_box *_box,
|
|
||||||
float color[static 4]);
|
|
||||||
|
|
||||||
void premultiply_alpha(float color[4], float opacity);
|
|
||||||
|
|
||||||
void scale_box(struct wlr_box *box, float scale);
|
|
||||||
|
|
||||||
enum wlr_direction opposite_direction(enum wlr_direction d);
|
enum wlr_direction opposite_direction(enum wlr_direction d);
|
||||||
|
|
||||||
void handle_output_layout_change(struct wl_listener *listener, void *data);
|
void handle_output_layout_change(struct wl_listener *listener, void *data);
|
||||||
|
|
|
@ -0,0 +1,33 @@
|
||||||
|
/**
|
||||||
|
* Across a wayland compositor, there are multiple shells: It can be
|
||||||
|
* a toplevel, or a layer_shell, or even something more meta like a drag
|
||||||
|
* icon or highlight indicators when dragging windows around.
|
||||||
|
*
|
||||||
|
* This object lets us store values that represent these modes of operation
|
||||||
|
* and keep track of what object is being represented.
|
||||||
|
*/
|
||||||
|
#ifndef _SWAY_SCENE_DESCRIPTOR_H
|
||||||
|
#define _SWAY_SCENE_DESCRIPTOR_H
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
|
|
||||||
|
enum sway_scene_descriptor_type {
|
||||||
|
SWAY_SCENE_DESC_BUFFER_TIMER,
|
||||||
|
SWAY_SCENE_DESC_NON_INTERACTIVE,
|
||||||
|
SWAY_SCENE_DESC_CONTAINER,
|
||||||
|
SWAY_SCENE_DESC_VIEW,
|
||||||
|
SWAY_SCENE_DESC_LAYER_SHELL,
|
||||||
|
SWAY_SCENE_DESC_XWAYLAND_UNMANAGED,
|
||||||
|
SWAY_SCENE_DESC_POPUP,
|
||||||
|
SWAY_SCENE_DESC_DRAG_ICON,
|
||||||
|
};
|
||||||
|
|
||||||
|
bool scene_descriptor_assign(struct wlr_scene_node *node,
|
||||||
|
enum sway_scene_descriptor_type type, void *data);
|
||||||
|
|
||||||
|
void *scene_descriptor_try_get(struct wlr_scene_node *node,
|
||||||
|
enum sway_scene_descriptor_type type);
|
||||||
|
|
||||||
|
void scene_descriptor_destroy(struct wlr_scene_node *node,
|
||||||
|
enum sway_scene_descriptor_type type);
|
||||||
|
|
||||||
|
#endif
|
|
@ -2,32 +2,28 @@
|
||||||
#define _SWAY_SERVER_H
|
#define _SWAY_SERVER_H
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <wayland-server-core.h>
|
#include <wayland-server-core.h>
|
||||||
#include <wlr/backend.h>
|
|
||||||
#include <wlr/render/allocator.h>
|
|
||||||
#include <wlr/render/wlr_renderer.h>
|
|
||||||
#include <wlr/types/wlr_compositor.h>
|
|
||||||
#include <wlr/types/wlr_data_device.h>
|
|
||||||
#include <wlr/types/wlr_input_method_v2.h>
|
|
||||||
#include <wlr/types/wlr_foreign_toplevel_management_v1.h>
|
|
||||||
#include <wlr/types/wlr_drm_lease_v1.h>
|
|
||||||
#include <wlr/types/wlr_layer_shell_v1.h>
|
|
||||||
#include <wlr/types/wlr_output_management_v1.h>
|
|
||||||
#include <wlr/types/wlr_output_power_management_v1.h>
|
|
||||||
#include <wlr/types/wlr_presentation_time.h>
|
|
||||||
#include <wlr/types/wlr_relative_pointer_v1.h>
|
|
||||||
#include <wlr/types/wlr_session_lock_v1.h>
|
|
||||||
#include <wlr/types/wlr_server_decoration.h>
|
|
||||||
#include <wlr/types/wlr_text_input_v3.h>
|
|
||||||
#include <wlr/types/wlr_xdg_shell.h>
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
#include "sway/desktop/idle_inhibit_v1.h"
|
#include "sway/desktop/idle_inhibit_v1.h"
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
#include "sway/xwayland.h"
|
#include "sway/xwayland.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct sway_transaction;
|
struct sway_transaction;
|
||||||
|
|
||||||
|
struct sway_session_lock {
|
||||||
|
struct wlr_session_lock_v1 *lock;
|
||||||
|
struct wlr_surface *focused;
|
||||||
|
bool abandoned;
|
||||||
|
|
||||||
|
struct wl_list outputs; // struct sway_session_lock_output
|
||||||
|
|
||||||
|
// invalid if the session is abandoned
|
||||||
|
struct wl_listener new_surface;
|
||||||
|
struct wl_listener unlock;
|
||||||
|
struct wl_listener destroy;
|
||||||
|
};
|
||||||
|
|
||||||
struct sway_server {
|
struct sway_server {
|
||||||
struct wl_display *wl_display;
|
struct wl_display *wl_display;
|
||||||
struct wl_event_loop *wl_event_loop;
|
struct wl_event_loop *wl_event_loop;
|
||||||
|
@ -41,7 +37,6 @@ struct sway_server {
|
||||||
struct wlr_allocator *allocator;
|
struct wlr_allocator *allocator;
|
||||||
|
|
||||||
struct wlr_compositor *compositor;
|
struct wlr_compositor *compositor;
|
||||||
struct wl_listener compositor_new_surface;
|
|
||||||
|
|
||||||
struct wlr_linux_dmabuf_v1 *linux_dmabuf_v1;
|
struct wlr_linux_dmabuf_v1 *linux_dmabuf_v1;
|
||||||
|
|
||||||
|
@ -51,6 +46,7 @@ struct sway_server {
|
||||||
|
|
||||||
struct wl_listener new_output;
|
struct wl_listener new_output;
|
||||||
struct wl_listener output_layout_change;
|
struct wl_listener output_layout_change;
|
||||||
|
struct wl_listener renderer_lost;
|
||||||
|
|
||||||
struct wlr_idle_notifier_v1 *idle_notifier_v1;
|
struct wlr_idle_notifier_v1 *idle_notifier_v1;
|
||||||
struct sway_idle_inhibit_manager_v1 idle_inhibit_manager_v1;
|
struct sway_idle_inhibit_manager_v1 idle_inhibit_manager_v1;
|
||||||
|
@ -59,11 +55,11 @@ struct sway_server {
|
||||||
struct wl_listener layer_shell_surface;
|
struct wl_listener layer_shell_surface;
|
||||||
|
|
||||||
struct wlr_xdg_shell *xdg_shell;
|
struct wlr_xdg_shell *xdg_shell;
|
||||||
struct wl_listener xdg_shell_surface;
|
struct wl_listener xdg_shell_toplevel;
|
||||||
|
|
||||||
struct wlr_tablet_manager_v2 *tablet_v2;
|
struct wlr_tablet_manager_v2 *tablet_v2;
|
||||||
|
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
struct sway_xwayland xwayland;
|
struct sway_xwayland xwayland;
|
||||||
struct wl_listener xwayland_surface;
|
struct wl_listener xwayland_surface;
|
||||||
struct wl_listener xwayland_ready;
|
struct wl_listener xwayland_ready;
|
||||||
|
@ -82,11 +78,11 @@ struct sway_server {
|
||||||
struct wlr_drm_lease_v1_manager *drm_lease_manager;
|
struct wlr_drm_lease_v1_manager *drm_lease_manager;
|
||||||
struct wl_listener drm_lease_request;
|
struct wl_listener drm_lease_request;
|
||||||
|
|
||||||
struct wlr_presentation *presentation;
|
|
||||||
|
|
||||||
struct wlr_pointer_constraints_v1 *pointer_constraints;
|
struct wlr_pointer_constraints_v1 *pointer_constraints;
|
||||||
struct wl_listener pointer_constraint;
|
struct wl_listener pointer_constraint;
|
||||||
|
|
||||||
|
struct wlr_xdg_output_manager_v1 *xdg_output_manager_v1;
|
||||||
|
|
||||||
struct wlr_output_manager_v1 *output_manager_v1;
|
struct wlr_output_manager_v1 *output_manager_v1;
|
||||||
struct wl_listener output_manager_apply;
|
struct wl_listener output_manager_apply;
|
||||||
struct wl_listener output_manager_test;
|
struct wl_listener output_manager_test;
|
||||||
|
@ -95,15 +91,9 @@ struct sway_server {
|
||||||
struct wl_listener gamma_control_set_gamma;
|
struct wl_listener gamma_control_set_gamma;
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
bool locked;
|
struct sway_session_lock *lock;
|
||||||
struct wlr_session_lock_manager_v1 *manager;
|
struct wlr_session_lock_manager_v1 *manager;
|
||||||
|
|
||||||
struct wlr_session_lock_v1 *lock;
|
|
||||||
struct wlr_surface *focused;
|
|
||||||
struct wl_listener lock_new_surface;
|
|
||||||
struct wl_listener lock_unlock;
|
|
||||||
struct wl_listener lock_destroy;
|
|
||||||
|
|
||||||
struct wl_listener new_lock;
|
struct wl_listener new_lock;
|
||||||
struct wl_listener manager_destroy;
|
struct wl_listener manager_destroy;
|
||||||
} session_lock;
|
} session_lock;
|
||||||
|
@ -112,6 +102,7 @@ struct sway_server {
|
||||||
struct wl_listener output_power_manager_set_mode;
|
struct wl_listener output_power_manager_set_mode;
|
||||||
struct wlr_input_method_manager_v2 *input_method;
|
struct wlr_input_method_manager_v2 *input_method;
|
||||||
struct wlr_text_input_manager_v3 *text_input;
|
struct wlr_text_input_manager_v3 *text_input;
|
||||||
|
struct wlr_ext_foreign_toplevel_list_v1 *foreign_toplevel_list;
|
||||||
struct wlr_foreign_toplevel_manager_v1 *foreign_toplevel_manager;
|
struct wlr_foreign_toplevel_manager_v1 *foreign_toplevel_manager;
|
||||||
struct wlr_content_type_manager_v1 *content_type_manager_v1;
|
struct wlr_content_type_manager_v1 *content_type_manager_v1;
|
||||||
struct wlr_data_control_manager_v1 *data_control_manager_v1;
|
struct wlr_data_control_manager_v1 *data_control_manager_v1;
|
||||||
|
@ -152,17 +143,13 @@ struct sway_debug {
|
||||||
bool noatomic; // Ignore atomic layout updates
|
bool noatomic; // Ignore atomic layout updates
|
||||||
bool txn_timings; // Log verbose messages about transactions
|
bool txn_timings; // Log verbose messages about transactions
|
||||||
bool txn_wait; // Always wait for the timeout before applying
|
bool txn_wait; // Always wait for the timeout before applying
|
||||||
bool noscanout; // Disable direct scan-out
|
bool legacy_wl_drm; // Enable the legacy wl_drm interface
|
||||||
|
|
||||||
enum {
|
|
||||||
DAMAGE_DEFAULT, // Default behaviour
|
|
||||||
DAMAGE_HIGHLIGHT, // Highlight regions of the screen being damaged
|
|
||||||
DAMAGE_RERENDER, // Render the full output when any damage occurs
|
|
||||||
} damage;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern struct sway_debug debug;
|
extern struct sway_debug debug;
|
||||||
|
|
||||||
|
extern bool allow_unsupported_gpu;
|
||||||
|
|
||||||
bool server_init(struct sway_server *server);
|
bool server_init(struct sway_server *server);
|
||||||
void server_fini(struct sway_server *server);
|
void server_fini(struct sway_server *server);
|
||||||
bool server_start(struct sway_server *server);
|
bool server_start(struct sway_server *server);
|
||||||
|
@ -170,14 +157,17 @@ void server_run(struct sway_server *server);
|
||||||
|
|
||||||
void restore_nofile_limit(void);
|
void restore_nofile_limit(void);
|
||||||
|
|
||||||
void handle_compositor_new_surface(struct wl_listener *listener, void *data);
|
|
||||||
void handle_new_output(struct wl_listener *listener, void *data);
|
void handle_new_output(struct wl_listener *listener, void *data);
|
||||||
|
|
||||||
void handle_idle_inhibitor_v1(struct wl_listener *listener, void *data);
|
void handle_idle_inhibitor_v1(struct wl_listener *listener, void *data);
|
||||||
void handle_layer_shell_surface(struct wl_listener *listener, void *data);
|
void handle_layer_shell_surface(struct wl_listener *listener, void *data);
|
||||||
void sway_session_lock_init(void);
|
void sway_session_lock_init(void);
|
||||||
void handle_xdg_shell_surface(struct wl_listener *listener, void *data);
|
void sway_session_lock_add_output(struct sway_session_lock *lock,
|
||||||
#if HAVE_XWAYLAND
|
struct sway_output *output);
|
||||||
|
bool sway_session_lock_has_surface(struct sway_session_lock *lock,
|
||||||
|
struct wlr_surface *surface);
|
||||||
|
void handle_xdg_shell_toplevel(struct wl_listener *listener, void *data);
|
||||||
|
#if WLR_HAS_XWAYLAND
|
||||||
void handle_xwayland_surface(struct wl_listener *listener, void *data);
|
void handle_xwayland_surface(struct wl_listener *listener, void *data);
|
||||||
#endif
|
#endif
|
||||||
void handle_server_decoration(struct wl_listener *listener, void *data);
|
void handle_server_decoration(struct wl_listener *listener, void *data);
|
||||||
|
|
|
@ -1,24 +0,0 @@
|
||||||
#ifndef _SWAY_SURFACE_H
|
|
||||||
#define _SWAY_SURFACE_H
|
|
||||||
#include <wlr/types/wlr_compositor.h>
|
|
||||||
|
|
||||||
struct sway_surface {
|
|
||||||
struct wlr_surface *wlr_surface;
|
|
||||||
|
|
||||||
struct wl_listener destroy;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This timer can be used for issuing delayed frame done callbacks (for
|
|
||||||
* example, to improve presentation latency). Its handler is set to a
|
|
||||||
* function that issues a frame done callback to this surface.
|
|
||||||
*/
|
|
||||||
struct wl_event_source *frame_done_timer;
|
|
||||||
};
|
|
||||||
|
|
||||||
void surface_update_outputs(struct wlr_surface *surface);
|
|
||||||
void surface_enter_output(struct wlr_surface *surface,
|
|
||||||
struct sway_output *output);
|
|
||||||
void surface_leave_output(struct wlr_surface *surface,
|
|
||||||
struct sway_output *output);
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
#ifndef _SWAY_BUFFER_H
|
||||||
|
#define _SWAY_BUFFER_H
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
|
|
||||||
|
struct sway_text_node {
|
||||||
|
int width;
|
||||||
|
int max_width;
|
||||||
|
int height;
|
||||||
|
int baseline;
|
||||||
|
bool pango_markup;
|
||||||
|
float color[4];
|
||||||
|
float background[4];
|
||||||
|
|
||||||
|
struct wlr_scene_node *node;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct sway_text_node *sway_text_node_create(struct wlr_scene_tree *parent,
|
||||||
|
char *text, float color[4], bool pango_markup);
|
||||||
|
|
||||||
|
void sway_text_node_set_color(struct sway_text_node *node, float color[4]);
|
||||||
|
|
||||||
|
void sway_text_node_set_text(struct sway_text_node *node, char *text);
|
||||||
|
|
||||||
|
void sway_text_node_set_max_width(struct sway_text_node *node, int max_width);
|
||||||
|
|
||||||
|
void sway_text_node_set_background(struct sway_text_node *node, float background[4]);
|
||||||
|
|
||||||
|
#endif
|
|
@ -3,6 +3,7 @@
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <wlr/types/wlr_compositor.h>
|
#include <wlr/types/wlr_compositor.h>
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
#include "sway/tree/node.h"
|
#include "sway/tree/node.h"
|
||||||
|
|
||||||
|
@ -68,11 +69,39 @@ struct sway_container {
|
||||||
struct sway_node node;
|
struct sway_node node;
|
||||||
struct sway_view *view;
|
struct sway_view *view;
|
||||||
|
|
||||||
|
struct wlr_scene_tree *scene_tree;
|
||||||
|
|
||||||
|
struct {
|
||||||
|
struct wlr_scene_tree *tree;
|
||||||
|
|
||||||
|
struct wlr_scene_tree *border;
|
||||||
|
struct wlr_scene_tree *background;
|
||||||
|
|
||||||
|
struct sway_text_node *title_text;
|
||||||
|
struct sway_text_node *marks_text;
|
||||||
|
} title_bar;
|
||||||
|
|
||||||
|
struct {
|
||||||
|
struct wlr_scene_tree *tree;
|
||||||
|
|
||||||
|
struct wlr_scene_rect *top;
|
||||||
|
struct wlr_scene_rect *bottom;
|
||||||
|
struct wlr_scene_rect *left;
|
||||||
|
struct wlr_scene_rect *right;
|
||||||
|
} border;
|
||||||
|
|
||||||
|
struct wlr_scene_tree *content_tree;
|
||||||
|
struct wlr_scene_buffer *output_handler;
|
||||||
|
|
||||||
|
struct wl_listener output_enter;
|
||||||
|
struct wl_listener output_leave;
|
||||||
|
|
||||||
struct sway_container_state current;
|
struct sway_container_state current;
|
||||||
struct sway_container_state pending;
|
struct sway_container_state pending;
|
||||||
|
|
||||||
char *title; // The view's title (unformatted)
|
char *title; // The view's title (unformatted)
|
||||||
char *formatted_title; // The title displayed in the title bar
|
char *formatted_title; // The title displayed in the title bar
|
||||||
|
int title_width;
|
||||||
|
|
||||||
enum sway_container_layout prev_split_layout;
|
enum sway_container_layout prev_split_layout;
|
||||||
|
|
||||||
|
@ -100,14 +129,6 @@ struct sway_container {
|
||||||
double child_total_width;
|
double child_total_width;
|
||||||
double child_total_height;
|
double child_total_height;
|
||||||
|
|
||||||
// In most cases this is the same as the content x and y, but if the view
|
|
||||||
// refuses to resize to the content dimensions then it can be smaller.
|
|
||||||
// These are in layout coordinates.
|
|
||||||
double surface_x, surface_y;
|
|
||||||
|
|
||||||
// Outputs currently being intersected
|
|
||||||
list_t *outputs; // struct sway_output
|
|
||||||
|
|
||||||
// Indicates that the container is a scratchpad container.
|
// Indicates that the container is a scratchpad container.
|
||||||
// Both hidden and visible scratchpad containers have scratchpad=true.
|
// Both hidden and visible scratchpad containers have scratchpad=true.
|
||||||
// Hidden scratchpad containers have a NULL parent.
|
// Hidden scratchpad containers have a NULL parent.
|
||||||
|
@ -120,18 +141,7 @@ struct sway_container {
|
||||||
|
|
||||||
float alpha;
|
float alpha;
|
||||||
|
|
||||||
struct wlr_texture *title_focused;
|
|
||||||
struct wlr_texture *title_focused_inactive;
|
|
||||||
struct wlr_texture *title_focused_tab_title;
|
|
||||||
struct wlr_texture *title_unfocused;
|
|
||||||
struct wlr_texture *title_urgent;
|
|
||||||
|
|
||||||
list_t *marks; // char *
|
list_t *marks; // char *
|
||||||
struct wlr_texture *marks_focused;
|
|
||||||
struct wlr_texture *marks_focused_inactive;
|
|
||||||
struct wlr_texture *marks_focused_tab_title;
|
|
||||||
struct wlr_texture *marks_unfocused;
|
|
||||||
struct wlr_texture *marks_urgent;
|
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
struct wl_signal destroy;
|
struct wl_signal destroy;
|
||||||
|
@ -151,19 +161,6 @@ void container_begin_destroy(struct sway_container *con);
|
||||||
struct sway_container *container_find_child(struct sway_container *container,
|
struct sway_container *container_find_child(struct sway_container *container,
|
||||||
bool (*test)(struct sway_container *view, void *data), void *data);
|
bool (*test)(struct sway_container *view, void *data), void *data);
|
||||||
|
|
||||||
/**
|
|
||||||
* Find a container at the given coordinates. Returns the surface and
|
|
||||||
* surface-local coordinates of the given layout coordinates if the container
|
|
||||||
* is a view and the view contains a surface at those coordinates.
|
|
||||||
*/
|
|
||||||
struct sway_container *container_at(struct sway_workspace *workspace,
|
|
||||||
double lx, double ly, struct wlr_surface **surface,
|
|
||||||
double *sx, double *sy);
|
|
||||||
|
|
||||||
struct sway_container *tiling_container_at(
|
|
||||||
struct sway_node *parent, double lx, double ly,
|
|
||||||
struct wlr_surface **surface, double *sx, double *sy);
|
|
||||||
|
|
||||||
void container_for_each_child(struct sway_container *container,
|
void container_for_each_child(struct sway_container *container,
|
||||||
void (*f)(struct sway_container *container, void *data), void *data);
|
void (*f)(struct sway_container *container, void *data), void *data);
|
||||||
|
|
||||||
|
@ -180,13 +177,13 @@ bool container_has_ancestor(struct sway_container *container,
|
||||||
|
|
||||||
void container_update_textures_recursive(struct sway_container *con);
|
void container_update_textures_recursive(struct sway_container *con);
|
||||||
|
|
||||||
void container_damage_whole(struct sway_container *container);
|
|
||||||
|
|
||||||
void container_reap_empty(struct sway_container *con);
|
void container_reap_empty(struct sway_container *con);
|
||||||
|
|
||||||
struct sway_container *container_flatten(struct sway_container *container);
|
struct sway_container *container_flatten(struct sway_container *container);
|
||||||
|
|
||||||
void container_update_title_textures(struct sway_container *container);
|
void container_update_title_bar(struct sway_container *container);
|
||||||
|
|
||||||
|
void container_update_marks(struct sway_container *container);
|
||||||
|
|
||||||
size_t container_build_representation(enum sway_container_layout layout,
|
size_t container_build_representation(enum sway_container_layout layout,
|
||||||
list_t *children, char *buffer);
|
list_t *children, char *buffer);
|
||||||
|
@ -222,11 +219,6 @@ void container_set_geometry_from_content(struct sway_container *con);
|
||||||
*/
|
*/
|
||||||
bool container_is_floating(struct sway_container *container);
|
bool container_is_floating(struct sway_container *container);
|
||||||
|
|
||||||
/**
|
|
||||||
* Same as above, but for current container state.
|
|
||||||
*/
|
|
||||||
bool container_is_current_floating(struct sway_container *container);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get a container's box in layout coordinates.
|
* Get a container's box in layout coordinates.
|
||||||
*/
|
*/
|
||||||
|
@ -289,26 +281,12 @@ bool container_is_floating_or_child(struct sway_container *container);
|
||||||
*/
|
*/
|
||||||
bool container_is_fullscreen_or_child(struct sway_container *container);
|
bool container_is_fullscreen_or_child(struct sway_container *container);
|
||||||
|
|
||||||
/**
|
|
||||||
* Return the output which will be used for scale purposes.
|
|
||||||
* This is the most recently entered output.
|
|
||||||
* If the container is not on any output, return NULL.
|
|
||||||
*/
|
|
||||||
struct sway_output *container_get_effective_output(struct sway_container *con);
|
|
||||||
|
|
||||||
void container_discover_outputs(struct sway_container *con);
|
|
||||||
|
|
||||||
enum sway_container_layout container_parent_layout(struct sway_container *con);
|
enum sway_container_layout container_parent_layout(struct sway_container *con);
|
||||||
|
|
||||||
enum sway_container_layout container_current_parent_layout(
|
|
||||||
struct sway_container *con);
|
|
||||||
|
|
||||||
list_t *container_get_siblings(struct sway_container *container);
|
list_t *container_get_siblings(struct sway_container *container);
|
||||||
|
|
||||||
int container_sibling_index(struct sway_container *child);
|
int container_sibling_index(struct sway_container *child);
|
||||||
|
|
||||||
list_t *container_get_current_siblings(struct sway_container *container);
|
|
||||||
|
|
||||||
void container_handle_fullscreen_reparent(struct sway_container *con);
|
void container_handle_fullscreen_reparent(struct sway_container *con);
|
||||||
|
|
||||||
void container_add_child(struct sway_container *parent,
|
void container_add_child(struct sway_container *parent,
|
||||||
|
@ -356,8 +334,6 @@ bool container_has_mark(struct sway_container *container, char *mark);
|
||||||
|
|
||||||
void container_add_mark(struct sway_container *container, char *mark);
|
void container_add_mark(struct sway_container *container, char *mark);
|
||||||
|
|
||||||
void container_update_marks_textures(struct sway_container *container);
|
|
||||||
|
|
||||||
void container_raise_floating(struct sway_container *con);
|
void container_raise_floating(struct sway_container *con);
|
||||||
|
|
||||||
bool container_is_scratchpad_hidden(struct sway_container *con);
|
bool container_is_scratchpad_hidden(struct sway_container *con);
|
||||||
|
@ -381,4 +357,10 @@ bool container_is_sticky_or_child(struct sway_container *con);
|
||||||
*/
|
*/
|
||||||
int container_squash(struct sway_container *con);
|
int container_squash(struct sway_container *con);
|
||||||
|
|
||||||
|
void container_arrange_title_bar(struct sway_container *con);
|
||||||
|
|
||||||
|
void container_update(struct sway_container *con);
|
||||||
|
|
||||||
|
void container_update_itself_and_parents(struct sway_container *con);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
#define _SWAY_NODE_H
|
#define _SWAY_NODE_H
|
||||||
#include <wayland-server-core.h>
|
#include <wayland-server-core.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
|
|
||||||
#define MIN_SANE_W 100
|
#define MIN_SANE_W 100
|
||||||
|
@ -75,4 +76,15 @@ list_t *node_get_children(struct sway_node *node);
|
||||||
|
|
||||||
bool node_has_ancestor(struct sway_node *node, struct sway_node *ancestor);
|
bool node_has_ancestor(struct sway_node *node, struct sway_node *ancestor);
|
||||||
|
|
||||||
|
// when destroying a sway tree, it's not known which order the tree will be
|
||||||
|
// destroyed. To prevent freeing of scene_nodes recursing up the tree,
|
||||||
|
// let's use this helper function to disown them to the staging node.
|
||||||
|
void scene_node_disown_children(struct wlr_scene_tree *tree);
|
||||||
|
|
||||||
|
// a helper function used to allocate tree nodes. If an allocation failure
|
||||||
|
// occurs a flag is flipped that can be checked later to destroy a parent
|
||||||
|
// of this scene node preventing memory leaks.
|
||||||
|
struct wlr_scene_tree *alloc_scene_tree(struct wlr_scene_tree *parent,
|
||||||
|
bool *failed);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2,11 +2,12 @@
|
||||||
#define _SWAY_ROOT_H
|
#define _SWAY_ROOT_H
|
||||||
#include <wayland-server-core.h>
|
#include <wayland-server-core.h>
|
||||||
#include <wayland-util.h>
|
#include <wayland-util.h>
|
||||||
|
#include <wlr/config.h>
|
||||||
#include <wlr/types/wlr_output_layout.h>
|
#include <wlr/types/wlr_output_layout.h>
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
#include <wlr/render/wlr_texture.h>
|
#include <wlr/render/wlr_texture.h>
|
||||||
#include "sway/tree/container.h"
|
#include "sway/tree/container.h"
|
||||||
#include "sway/tree/node.h"
|
#include "sway/tree/node.h"
|
||||||
#include "config.h"
|
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
|
|
||||||
extern struct sway_root *root;
|
extern struct sway_root *root;
|
||||||
|
@ -16,10 +17,44 @@ struct sway_root {
|
||||||
struct wlr_output_layout *output_layout;
|
struct wlr_output_layout *output_layout;
|
||||||
|
|
||||||
struct wl_listener output_layout_change;
|
struct wl_listener output_layout_change;
|
||||||
#if HAVE_XWAYLAND
|
|
||||||
struct wl_list xwayland_unmanaged; // sway_xwayland_unmanaged::link
|
// scene node layout:
|
||||||
|
// - root
|
||||||
|
// - staging
|
||||||
|
// - layer shell stuff
|
||||||
|
// - tiling
|
||||||
|
// - floating
|
||||||
|
// - fullscreen stuff
|
||||||
|
// - seat stuff
|
||||||
|
// - ext_session_lock
|
||||||
|
struct wlr_scene *root_scene;
|
||||||
|
|
||||||
|
// since wlr_scene nodes can't be orphaned and must always
|
||||||
|
// have a parent, use this staging scene_tree so that a
|
||||||
|
// node always have a valid parent. Nothing in this
|
||||||
|
// staging node will be visible.
|
||||||
|
struct wlr_scene_tree *staging;
|
||||||
|
|
||||||
|
// tree containing all layers the compositor will render. Cursor handling
|
||||||
|
// will end up iterating this tree.
|
||||||
|
struct wlr_scene_tree *layer_tree;
|
||||||
|
|
||||||
|
struct {
|
||||||
|
struct wlr_scene_tree *shell_background;
|
||||||
|
struct wlr_scene_tree *shell_bottom;
|
||||||
|
struct wlr_scene_tree *tiling;
|
||||||
|
struct wlr_scene_tree *floating;
|
||||||
|
struct wlr_scene_tree *shell_top;
|
||||||
|
struct wlr_scene_tree *fullscreen;
|
||||||
|
struct wlr_scene_tree *fullscreen_global;
|
||||||
|
#if WLR_HAS_XWAYLAND
|
||||||
|
struct wlr_scene_tree *unmanaged;
|
||||||
#endif
|
#endif
|
||||||
struct wl_list drag_icons; // sway_drag_icon::link
|
struct wlr_scene_tree *shell_overlay;
|
||||||
|
struct wlr_scene_tree *popup;
|
||||||
|
struct wlr_scene_tree *seat;
|
||||||
|
struct wlr_scene_tree *session_lock;
|
||||||
|
} layers;
|
||||||
|
|
||||||
// Includes disabled outputs
|
// Includes disabled outputs
|
||||||
struct wl_list all_outputs; // sway_output::link
|
struct wl_list all_outputs; // sway_output::link
|
||||||
|
@ -41,7 +76,7 @@ struct sway_root {
|
||||||
} events;
|
} events;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct sway_root *root_create(void);
|
struct sway_root *root_create(struct wl_display *display);
|
||||||
|
|
||||||
void root_destroy(struct sway_root *root);
|
void root_destroy(struct sway_root *root);
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
#ifndef _SWAY_VIEW_H
|
#ifndef _SWAY_VIEW_H
|
||||||
#define _SWAY_VIEW_H
|
#define _SWAY_VIEW_H
|
||||||
#include <wayland-server-core.h>
|
#include <wayland-server-core.h>
|
||||||
|
#include <wlr/config.h>
|
||||||
#include <wlr/types/wlr_compositor.h>
|
#include <wlr/types/wlr_compositor.h>
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
#include <wlr/xwayland.h>
|
#include <wlr/xwayland.h>
|
||||||
#endif
|
#endif
|
||||||
#include "sway/input/input-manager.h"
|
#include "sway/input/input-manager.h"
|
||||||
|
@ -14,7 +16,7 @@ struct sway_xdg_decoration;
|
||||||
|
|
||||||
enum sway_view_type {
|
enum sway_view_type {
|
||||||
SWAY_VIEW_XDG_SHELL,
|
SWAY_VIEW_XDG_SHELL,
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
SWAY_VIEW_XWAYLAND,
|
SWAY_VIEW_XWAYLAND,
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
@ -26,7 +28,7 @@ enum sway_view_prop {
|
||||||
VIEW_PROP_INSTANCE,
|
VIEW_PROP_INSTANCE,
|
||||||
VIEW_PROP_WINDOW_TYPE,
|
VIEW_PROP_WINDOW_TYPE,
|
||||||
VIEW_PROP_WINDOW_ROLE,
|
VIEW_PROP_WINDOW_ROLE,
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
VIEW_PROP_X11_WINDOW_ID,
|
VIEW_PROP_X11_WINDOW_ID,
|
||||||
VIEW_PROP_X11_PARENT_ID,
|
VIEW_PROP_X11_PARENT_ID,
|
||||||
#endif
|
#endif
|
||||||
|
@ -45,10 +47,6 @@ struct sway_view_impl {
|
||||||
void (*set_fullscreen)(struct sway_view *view, bool fullscreen);
|
void (*set_fullscreen)(struct sway_view *view, bool fullscreen);
|
||||||
void (*set_resizing)(struct sway_view *view, bool resizing);
|
void (*set_resizing)(struct sway_view *view, bool resizing);
|
||||||
bool (*wants_floating)(struct sway_view *view);
|
bool (*wants_floating)(struct sway_view *view);
|
||||||
void (*for_each_surface)(struct sway_view *view,
|
|
||||||
wlr_surface_iterator_func_t iterator, void *user_data);
|
|
||||||
void (*for_each_popup_surface)(struct sway_view *view,
|
|
||||||
wlr_surface_iterator_func_t iterator, void *user_data);
|
|
||||||
bool (*is_transient_for)(struct sway_view *child,
|
bool (*is_transient_for)(struct sway_view *child,
|
||||||
struct sway_view *ancestor);
|
struct sway_view *ancestor);
|
||||||
void (*close)(struct sway_view *view);
|
void (*close)(struct sway_view *view);
|
||||||
|
@ -56,19 +54,14 @@ struct sway_view_impl {
|
||||||
void (*destroy)(struct sway_view *view);
|
void (*destroy)(struct sway_view *view);
|
||||||
};
|
};
|
||||||
|
|
||||||
struct sway_saved_buffer {
|
|
||||||
struct wlr_client_buffer *buffer;
|
|
||||||
int x, y;
|
|
||||||
int width, height;
|
|
||||||
enum wl_output_transform transform;
|
|
||||||
struct wlr_fbox source_box;
|
|
||||||
struct wl_list link; // sway_view::saved_buffers
|
|
||||||
};
|
|
||||||
|
|
||||||
struct sway_view {
|
struct sway_view {
|
||||||
enum sway_view_type type;
|
enum sway_view_type type;
|
||||||
const struct sway_view_impl *impl;
|
const struct sway_view_impl *impl;
|
||||||
|
|
||||||
|
struct wlr_scene_tree *scene_tree;
|
||||||
|
struct wlr_scene_tree *content_tree;
|
||||||
|
struct wlr_scene_tree *saved_surface_tree;
|
||||||
|
|
||||||
struct sway_container *container; // NULL if unmapped and transactions finished
|
struct sway_container *container; // NULL if unmapped and transactions finished
|
||||||
struct wlr_surface *surface; // NULL for unmapped views
|
struct wlr_surface *surface; // NULL for unmapped views
|
||||||
struct sway_xdg_decoration *xdg_decoration;
|
struct sway_xdg_decoration *xdg_decoration;
|
||||||
|
@ -88,15 +81,11 @@ struct sway_view {
|
||||||
bool allow_request_urgent;
|
bool allow_request_urgent;
|
||||||
struct wl_event_source *urgent_timer;
|
struct wl_event_source *urgent_timer;
|
||||||
|
|
||||||
struct wl_list saved_buffers; // sway_saved_buffer::link
|
|
||||||
|
|
||||||
// The geometry for whatever the client is committing, regardless of
|
// The geometry for whatever the client is committing, regardless of
|
||||||
// transaction state. Updated on every commit.
|
// transaction state. Updated on every commit.
|
||||||
struct wlr_box geometry;
|
struct wlr_box geometry;
|
||||||
|
|
||||||
// The "old" geometry during a transaction. Used to damage the old location
|
struct wlr_ext_foreign_toplevel_handle_v1 *ext_foreign_toplevel;
|
||||||
// when a transaction is applied.
|
|
||||||
struct wlr_box saved_geometry;
|
|
||||||
|
|
||||||
struct wlr_foreign_toplevel_handle_v1 *foreign_toplevel;
|
struct wlr_foreign_toplevel_handle_v1 *foreign_toplevel;
|
||||||
struct wl_listener foreign_activate_request;
|
struct wl_listener foreign_activate_request;
|
||||||
|
@ -110,7 +99,7 @@ struct sway_view {
|
||||||
|
|
||||||
union {
|
union {
|
||||||
struct wlr_xdg_toplevel *wlr_xdg_toplevel;
|
struct wlr_xdg_toplevel *wlr_xdg_toplevel;
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
struct wlr_xwayland_surface *wlr_xwayland_surface;
|
struct wlr_xwayland_surface *wlr_xwayland_surface;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
@ -119,8 +108,6 @@ struct sway_view {
|
||||||
struct wl_signal unmap;
|
struct wl_signal unmap;
|
||||||
} events;
|
} events;
|
||||||
|
|
||||||
struct wl_listener surface_new_subsurface;
|
|
||||||
|
|
||||||
int max_render_time; // In milliseconds
|
int max_render_time; // In milliseconds
|
||||||
|
|
||||||
enum seat_config_shortcuts_inhibit shortcuts_inhibit;
|
enum seat_config_shortcuts_inhibit shortcuts_inhibit;
|
||||||
|
@ -141,10 +128,12 @@ struct sway_xdg_shell_view {
|
||||||
struct wl_listener unmap;
|
struct wl_listener unmap;
|
||||||
struct wl_listener destroy;
|
struct wl_listener destroy;
|
||||||
};
|
};
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
struct sway_xwayland_view {
|
struct sway_xwayland_view {
|
||||||
struct sway_view view;
|
struct sway_view view;
|
||||||
|
|
||||||
|
struct wlr_scene_tree *surface_tree;
|
||||||
|
|
||||||
struct wl_listener commit;
|
struct wl_listener commit;
|
||||||
struct wl_listener request_move;
|
struct wl_listener request_move;
|
||||||
struct wl_listener request_resize;
|
struct wl_listener request_resize;
|
||||||
|
@ -166,18 +155,18 @@ struct sway_xwayland_view {
|
||||||
struct wl_listener unmap;
|
struct wl_listener unmap;
|
||||||
struct wl_listener destroy;
|
struct wl_listener destroy;
|
||||||
struct wl_listener override_redirect;
|
struct wl_listener override_redirect;
|
||||||
|
|
||||||
|
struct wl_listener surface_tree_destroy;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct sway_xwayland_unmanaged {
|
struct sway_xwayland_unmanaged {
|
||||||
struct wlr_xwayland_surface *wlr_xwayland_surface;
|
struct wlr_xwayland_surface *wlr_xwayland_surface;
|
||||||
struct wl_list link;
|
|
||||||
|
|
||||||
int lx, ly;
|
struct wlr_scene_surface *surface_scene;
|
||||||
|
|
||||||
struct wl_listener request_activate;
|
struct wl_listener request_activate;
|
||||||
struct wl_listener request_configure;
|
struct wl_listener request_configure;
|
||||||
struct wl_listener request_fullscreen;
|
struct wl_listener request_fullscreen;
|
||||||
struct wl_listener commit;
|
|
||||||
struct wl_listener set_geometry;
|
struct wl_listener set_geometry;
|
||||||
struct wl_listener associate;
|
struct wl_listener associate;
|
||||||
struct wl_listener dissociate;
|
struct wl_listener dissociate;
|
||||||
|
@ -187,46 +176,24 @@ struct sway_xwayland_unmanaged {
|
||||||
struct wl_listener override_redirect;
|
struct wl_listener override_redirect;
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
struct sway_view_child;
|
|
||||||
|
|
||||||
struct sway_view_child_impl {
|
|
||||||
void (*get_view_coords)(struct sway_view_child *child, int *sx, int *sy);
|
|
||||||
void (*destroy)(struct sway_view_child *child);
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A view child is a surface in the view tree, such as a subsurface or a popup.
|
|
||||||
*/
|
|
||||||
struct sway_view_child {
|
|
||||||
const struct sway_view_child_impl *impl;
|
|
||||||
struct wl_list link;
|
|
||||||
|
|
||||||
|
struct sway_popup_desc {
|
||||||
|
struct wlr_scene_node *relative;
|
||||||
struct sway_view *view;
|
struct sway_view *view;
|
||||||
struct sway_view_child *parent;
|
|
||||||
struct wl_list children; // sway_view_child::link
|
|
||||||
struct wlr_surface *surface;
|
|
||||||
bool mapped;
|
|
||||||
|
|
||||||
struct wl_listener surface_commit;
|
|
||||||
struct wl_listener surface_new_subsurface;
|
|
||||||
struct wl_listener surface_map;
|
|
||||||
struct wl_listener surface_unmap;
|
|
||||||
struct wl_listener surface_destroy;
|
|
||||||
struct wl_listener view_unmap;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct sway_subsurface {
|
|
||||||
struct sway_view_child child;
|
|
||||||
|
|
||||||
struct wl_listener destroy;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct sway_xdg_popup {
|
struct sway_xdg_popup {
|
||||||
struct sway_view_child child;
|
struct sway_view *view;
|
||||||
|
|
||||||
|
struct wlr_scene_tree *scene_tree;
|
||||||
|
struct wlr_scene_tree *xdg_surface_tree;
|
||||||
struct wlr_xdg_popup *wlr_xdg_popup;
|
struct wlr_xdg_popup *wlr_xdg_popup;
|
||||||
|
|
||||||
|
struct sway_popup_desc desc;
|
||||||
|
|
||||||
|
struct wl_listener surface_commit;
|
||||||
struct wl_listener new_popup;
|
struct wl_listener new_popup;
|
||||||
|
struct wl_listener reposition;
|
||||||
struct wl_listener destroy;
|
struct wl_listener destroy;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -277,6 +244,11 @@ void view_set_activated(struct sway_view *view, bool activated);
|
||||||
*/
|
*/
|
||||||
void view_request_activate(struct sway_view *view, struct sway_seat *seat);
|
void view_request_activate(struct sway_view *view, struct sway_seat *seat);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Called when the view requests urgent state
|
||||||
|
*/
|
||||||
|
void view_request_urgent(struct sway_view *view);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* If possible, instructs the client to change their decoration mode.
|
* If possible, instructs the client to change their decoration mode.
|
||||||
*/
|
*/
|
||||||
|
@ -294,23 +266,9 @@ void view_close(struct sway_view *view);
|
||||||
|
|
||||||
void view_close_popups(struct sway_view *view);
|
void view_close_popups(struct sway_view *view);
|
||||||
|
|
||||||
void view_damage_from(struct sway_view *view);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Iterate all surfaces of a view (toplevels + popups).
|
|
||||||
*/
|
|
||||||
void view_for_each_surface(struct sway_view *view,
|
|
||||||
wlr_surface_iterator_func_t iterator, void *user_data);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Iterate all popup surfaces of a view.
|
|
||||||
*/
|
|
||||||
void view_for_each_popup_surface(struct sway_view *view,
|
|
||||||
wlr_surface_iterator_func_t iterator, void *user_data);
|
|
||||||
|
|
||||||
// view implementation
|
// view implementation
|
||||||
|
|
||||||
void view_init(struct sway_view *view, enum sway_view_type type,
|
bool view_init(struct sway_view *view, enum sway_view_type type,
|
||||||
const struct sway_view_impl *impl);
|
const struct sway_view_impl *impl);
|
||||||
|
|
||||||
void view_destroy(struct sway_view *view);
|
void view_destroy(struct sway_view *view);
|
||||||
|
@ -332,23 +290,18 @@ void view_map(struct sway_view *view, struct wlr_surface *wlr_surface,
|
||||||
void view_unmap(struct sway_view *view);
|
void view_unmap(struct sway_view *view);
|
||||||
|
|
||||||
void view_update_size(struct sway_view *view);
|
void view_update_size(struct sway_view *view);
|
||||||
void view_center_surface(struct sway_view *view);
|
void view_center_and_clip_surface(struct sway_view *view);
|
||||||
|
|
||||||
void view_child_init(struct sway_view_child *child,
|
|
||||||
const struct sway_view_child_impl *impl, struct sway_view *view,
|
|
||||||
struct wlr_surface *surface);
|
|
||||||
|
|
||||||
void view_child_destroy(struct sway_view_child *child);
|
|
||||||
|
|
||||||
|
|
||||||
struct sway_view *view_from_wlr_xdg_surface(
|
struct sway_view *view_from_wlr_xdg_surface(
|
||||||
struct wlr_xdg_surface *xdg_surface);
|
struct wlr_xdg_surface *xdg_surface);
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
struct sway_view *view_from_wlr_xwayland_surface(
|
struct sway_view *view_from_wlr_xwayland_surface(
|
||||||
struct wlr_xwayland_surface *xsurface);
|
struct wlr_xwayland_surface *xsurface);
|
||||||
#endif
|
#endif
|
||||||
struct sway_view *view_from_wlr_surface(struct wlr_surface *surface);
|
struct sway_view *view_from_wlr_surface(struct wlr_surface *surface);
|
||||||
|
|
||||||
|
void view_update_app_id(struct sway_view *view);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Re-read the view's title property and update any relevant title bars.
|
* Re-read the view's title property and update any relevant title bars.
|
||||||
* The force argument makes it recreate the title bars even if the title hasn't
|
* The force argument makes it recreate the title bars even if the title hasn't
|
||||||
|
@ -380,4 +333,6 @@ bool view_is_transient_for(struct sway_view *child, struct sway_view *ancestor);
|
||||||
|
|
||||||
void view_assign_ctx(struct sway_view *view, struct launcher_ctx *ctx);
|
void view_assign_ctx(struct sway_view *view, struct launcher_ctx *ctx);
|
||||||
|
|
||||||
|
void view_send_frame_done(struct sway_view *view);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
#define _SWAY_WORKSPACE_H
|
#define _SWAY_WORKSPACE_H
|
||||||
|
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
#include <wlr/types/wlr_scene.h>
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/tree/container.h"
|
#include "sway/tree/container.h"
|
||||||
#include "sway/tree/node.h"
|
#include "sway/tree/node.h"
|
||||||
|
@ -23,6 +24,12 @@ struct sway_workspace_state {
|
||||||
|
|
||||||
struct sway_workspace {
|
struct sway_workspace {
|
||||||
struct sway_node node;
|
struct sway_node node;
|
||||||
|
|
||||||
|
struct {
|
||||||
|
struct wlr_scene_tree *tiling;
|
||||||
|
struct wlr_scene_tree *fullscreen;
|
||||||
|
} layers;
|
||||||
|
|
||||||
struct sway_container *fullscreen;
|
struct sway_container *fullscreen;
|
||||||
|
|
||||||
char *name;
|
char *name;
|
||||||
|
|
|
@ -16,4 +16,6 @@ struct sway_xdg_decoration {
|
||||||
struct sway_xdg_decoration *xdg_decoration_from_surface(
|
struct sway_xdg_decoration *xdg_decoration_from_surface(
|
||||||
struct wlr_surface *surface);
|
struct wlr_surface *surface);
|
||||||
|
|
||||||
|
void set_xdg_decoration_mode(struct sway_xdg_decoration *deco);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
#ifndef _SWAYBAR_IMAGE_H
|
||||||
|
#define _SWAYBAR_IMAGE_H
|
||||||
|
#include <cairo.h>
|
||||||
|
|
||||||
|
cairo_surface_t *load_image(const char *path);
|
||||||
|
|
||||||
|
#endif
|
24
meson.build
24
meson.build
|
@ -1,7 +1,7 @@
|
||||||
project(
|
project(
|
||||||
'sway',
|
'sway',
|
||||||
'c',
|
'c',
|
||||||
version: '1.9-dev',
|
version: '1.10-dev',
|
||||||
license: 'MIT',
|
license: 'MIT',
|
||||||
meson_version: '>=0.60.0',
|
meson_version: '>=0.60.0',
|
||||||
default_options: [
|
default_options: [
|
||||||
|
@ -14,6 +14,7 @@ project(
|
||||||
add_project_arguments(
|
add_project_arguments(
|
||||||
[
|
[
|
||||||
'-DWLR_USE_UNSTABLE',
|
'-DWLR_USE_UNSTABLE',
|
||||||
|
'-D_POSIX_C_SOURCE=200809L',
|
||||||
|
|
||||||
'-Wno-unused-parameter',
|
'-Wno-unused-parameter',
|
||||||
'-Wno-unused-result',
|
'-Wno-unused-result',
|
||||||
|
@ -37,14 +38,14 @@ if is_freebsd
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Execute the wlroots subproject, if any
|
# Execute the wlroots subproject, if any
|
||||||
wlroots_version = ['>=0.17.0', '<0.18.0']
|
wlroots_version = ['>=0.18.0', '<0.19.0']
|
||||||
subproject(
|
subproject(
|
||||||
'wlroots',
|
'wlroots',
|
||||||
default_options: ['examples=false'],
|
default_options: ['examples=false'],
|
||||||
required: false,
|
required: false,
|
||||||
version: wlroots_version,
|
version: wlroots_version,
|
||||||
)
|
)
|
||||||
wlroots = dependency('wlroots', version: wlroots_version)
|
wlroots = dependency('wlroots-0.18', version: wlroots_version, fallback: 'wlroots')
|
||||||
wlroots_features = {
|
wlroots_features = {
|
||||||
'xwayland': false,
|
'xwayland': false,
|
||||||
'libinput_backend': false,
|
'libinput_backend': false,
|
||||||
|
@ -56,10 +57,6 @@ foreach name, _ : wlroots_features
|
||||||
wlroots_features += { name: have }
|
wlroots_features += { name: have }
|
||||||
endforeach
|
endforeach
|
||||||
|
|
||||||
if get_option('xwayland').enabled() and not wlroots_features['xwayland']
|
|
||||||
error('Cannot enable Xwayland in sway: wlroots has been built without Xwayland support')
|
|
||||||
endif
|
|
||||||
|
|
||||||
null_dep = dependency('', required: false)
|
null_dep = dependency('', required: false)
|
||||||
|
|
||||||
jsonc = dependency('json-c', version: '>=0.13')
|
jsonc = dependency('json-c', version: '>=0.13')
|
||||||
|
@ -67,7 +64,7 @@ pcre2 = dependency('libpcre2-8')
|
||||||
wayland_server = dependency('wayland-server', version: '>=1.21.0')
|
wayland_server = dependency('wayland-server', version: '>=1.21.0')
|
||||||
wayland_client = dependency('wayland-client')
|
wayland_client = dependency('wayland-client')
|
||||||
wayland_cursor = dependency('wayland-cursor')
|
wayland_cursor = dependency('wayland-cursor')
|
||||||
wayland_protos = dependency('wayland-protocols', version: '>=1.24')
|
wayland_protos = dependency('wayland-protocols', version: '>=1.24', default_options: ['tests=false'])
|
||||||
xkbcommon = dependency('xkbcommon', version: '>=1.5.0')
|
xkbcommon = dependency('xkbcommon', version: '>=1.5.0')
|
||||||
cairo = dependency('cairo')
|
cairo = dependency('cairo')
|
||||||
pango = dependency('pango')
|
pango = dependency('pango')
|
||||||
|
@ -76,17 +73,14 @@ gdk_pixbuf = dependency('gdk-pixbuf-2.0', required: get_option('gdk-pixbuf'))
|
||||||
pixman = dependency('pixman-1')
|
pixman = dependency('pixman-1')
|
||||||
libevdev = dependency('libevdev')
|
libevdev = dependency('libevdev')
|
||||||
libinput = wlroots_features['libinput_backend'] ? dependency('libinput', version: '>=1.21.0') : null_dep
|
libinput = wlroots_features['libinput_backend'] ? dependency('libinput', version: '>=1.21.0') : null_dep
|
||||||
xcb = dependency('xcb', required: get_option('xwayland'))
|
xcb = wlroots_features['xwayland'] ? dependency('xcb') : null_dep
|
||||||
drm_full = dependency('libdrm') # only needed for drm_fourcc.h
|
drm = dependency('libdrm')
|
||||||
drm = drm_full.partial_dependency(compile_args: true, includes: true)
|
|
||||||
libudev = wlroots_features['libinput_backend'] ? dependency('libudev') : null_dep
|
libudev = wlroots_features['libinput_backend'] ? dependency('libudev') : null_dep
|
||||||
math = cc.find_library('m')
|
math = cc.find_library('m')
|
||||||
rt = cc.find_library('rt')
|
rt = cc.find_library('rt')
|
||||||
xcb_icccm = dependency('xcb-icccm', required: get_option('xwayland'))
|
xcb_icccm = wlroots_features['xwayland'] ? dependency('xcb-icccm') : null_dep
|
||||||
threads = dependency('threads') # for pthread_setschedparam
|
threads = dependency('threads') # for pthread_setschedparam
|
||||||
|
|
||||||
have_xwayland = xcb.found() and xcb_icccm.found() and wlroots_features['xwayland']
|
|
||||||
|
|
||||||
if get_option('sd-bus-provider') == 'auto'
|
if get_option('sd-bus-provider') == 'auto'
|
||||||
if not get_option('tray').disabled()
|
if not get_option('tray').disabled()
|
||||||
assert(get_option('auto_features').auto(), 'sd-bus-provider must not be set to auto since auto_features != auto')
|
assert(get_option('auto_features').auto(), 'sd-bus-provider must not be set to auto since auto_features != auto')
|
||||||
|
@ -110,7 +104,6 @@ have_tray = (not get_option('tray').disabled()) and tray_deps_found
|
||||||
|
|
||||||
conf_data = configuration_data()
|
conf_data = configuration_data()
|
||||||
|
|
||||||
conf_data.set10('HAVE_XWAYLAND', have_xwayland)
|
|
||||||
conf_data.set10('HAVE_GDK_PIXBUF', gdk_pixbuf.found())
|
conf_data.set10('HAVE_GDK_PIXBUF', gdk_pixbuf.found())
|
||||||
conf_data.set10('HAVE_LIBSYSTEMD', sdbus.found() and sdbus.name() == 'libsystemd')
|
conf_data.set10('HAVE_LIBSYSTEMD', sdbus.found() and sdbus.name() == 'libsystemd')
|
||||||
conf_data.set10('HAVE_LIBELOGIND', sdbus.found() and sdbus.name() == 'libelogind')
|
conf_data.set10('HAVE_LIBELOGIND', sdbus.found() and sdbus.name() == 'libelogind')
|
||||||
|
@ -271,7 +264,6 @@ endif
|
||||||
subdir('completions')
|
subdir('completions')
|
||||||
|
|
||||||
summary({
|
summary({
|
||||||
'xwayland': have_xwayland,
|
|
||||||
'gdk-pixbuf': gdk_pixbuf.found(),
|
'gdk-pixbuf': gdk_pixbuf.found(),
|
||||||
'tray': have_tray,
|
'tray': have_tray,
|
||||||
'man-pages': scdoc.found(),
|
'man-pages': scdoc.found(),
|
||||||
|
|
|
@ -4,8 +4,7 @@ option('bash-completions', type: 'boolean', value: true, description: 'Install b
|
||||||
option('fish-completions', type: 'boolean', value: true, description: 'Install fish shell completions.')
|
option('fish-completions', type: 'boolean', value: true, description: 'Install fish shell completions.')
|
||||||
option('swaybar', type: 'boolean', value: true, description: 'Enable support for swaybar')
|
option('swaybar', type: 'boolean', value: true, description: 'Enable support for swaybar')
|
||||||
option('swaynag', type: 'boolean', value: true, description: 'Enable support for swaynag')
|
option('swaynag', type: 'boolean', value: true, description: 'Enable support for swaynag')
|
||||||
option('xwayland', type: 'feature', value: 'auto', description: 'Enable support for X11 applications')
|
|
||||||
option('tray', type: 'feature', value: 'auto', description: 'Enable support for swaybar tray')
|
option('tray', type: 'feature', value: 'auto', description: 'Enable support for swaybar tray')
|
||||||
option('gdk-pixbuf', type: 'feature', value: 'auto', description: 'Enable support for more image formats in swaybg')
|
option('gdk-pixbuf', type: 'feature', value: 'auto', description: 'Enable support for more image formats in swaybar tray')
|
||||||
option('man-pages', type: 'feature', value: 'auto', description: 'Generate and install man pages')
|
option('man-pages', type: 'feature', value: 'auto', description: 'Generate and install man pages')
|
||||||
option('sd-bus-provider', type: 'combo', choices: ['auto', 'libsystemd', 'libelogind', 'basu'], value: 'auto', description: 'Provider of the sd-bus library')
|
option('sd-bus-provider', type: 'combo', choices: ['auto', 'libsystemd', 'libelogind', 'basu'], value: 'auto', description: 'Provider of the sd-bus library')
|
||||||
|
|
|
@ -16,7 +16,6 @@ protocols = [
|
||||||
wl_protocol_dir / 'staging/cursor-shape/cursor-shape-v1.xml',
|
wl_protocol_dir / 'staging/cursor-shape/cursor-shape-v1.xml',
|
||||||
'wlr-layer-shell-unstable-v1.xml',
|
'wlr-layer-shell-unstable-v1.xml',
|
||||||
'idle.xml',
|
'idle.xml',
|
||||||
'wlr-input-inhibitor-unstable-v1.xml',
|
|
||||||
'wlr-output-power-management-unstable-v1.xml',
|
'wlr-output-power-management-unstable-v1.xml',
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
|
@ -1,67 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<protocol name="wlr_input_inhibit_unstable_v1">
|
|
||||||
<copyright>
|
|
||||||
Copyright © 2018 Drew DeVault
|
|
||||||
|
|
||||||
Permission to use, copy, modify, distribute, and sell this
|
|
||||||
software and its documentation for any purpose is hereby granted
|
|
||||||
without fee, provided that the above copyright notice appear in
|
|
||||||
all copies and that both that copyright notice and this permission
|
|
||||||
notice appear in supporting documentation, and that the name of
|
|
||||||
the copyright holders not be used in advertising or publicity
|
|
||||||
pertaining to distribution of the software without specific,
|
|
||||||
written prior permission. The copyright holders make no
|
|
||||||
representations about the suitability of this software for any
|
|
||||||
purpose. It is provided "as is" without express or implied
|
|
||||||
warranty.
|
|
||||||
|
|
||||||
THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
|
|
||||||
SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
||||||
FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
||||||
SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
||||||
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
|
|
||||||
AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
|
|
||||||
ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF
|
|
||||||
THIS SOFTWARE.
|
|
||||||
</copyright>
|
|
||||||
|
|
||||||
<interface name="zwlr_input_inhibit_manager_v1" version="1">
|
|
||||||
<description summary="inhibits input events to other clients">
|
|
||||||
Clients can use this interface to prevent input events from being sent to
|
|
||||||
any surfaces but its own, which is useful for example in lock screen
|
|
||||||
software. It is assumed that access to this interface will be locked down
|
|
||||||
to whitelisted clients by the compositor.
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<request name="get_inhibitor">
|
|
||||||
<description summary="inhibit input to other clients">
|
|
||||||
Activates the input inhibitor. As long as the inhibitor is active, the
|
|
||||||
compositor will not send input events to other clients.
|
|
||||||
</description>
|
|
||||||
<arg name="id" type="new_id" interface="zwlr_input_inhibitor_v1"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<enum name="error">
|
|
||||||
<entry name="already_inhibited" value="0" summary="an input inhibitor is already in use on the compositor"/>
|
|
||||||
</enum>
|
|
||||||
</interface>
|
|
||||||
|
|
||||||
<interface name="zwlr_input_inhibitor_v1" version="1">
|
|
||||||
<description summary="inhibits input to other clients">
|
|
||||||
While this resource exists, input to clients other than the owner of the
|
|
||||||
inhibitor resource will not receive input events. The client that owns
|
|
||||||
this resource will receive all input events normally. The compositor will
|
|
||||||
also disable all of its own input processing (such as keyboard shortcuts)
|
|
||||||
while the inhibitor is active.
|
|
||||||
|
|
||||||
The compositor may continue to send input events to selected clients,
|
|
||||||
such as an on-screen keyboard (via the input-method protocol).
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<request name="destroy" type="destructor">
|
|
||||||
<description summary="destroy the input inhibitor object">
|
|
||||||
Destroy the inhibitor and allow other clients to receive input.
|
|
||||||
</description>
|
|
||||||
</request>
|
|
||||||
</interface>
|
|
||||||
</protocol>
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
#!/bin/sh -eu
|
||||||
|
|
||||||
|
prev=$(git describe --tags --abbrev=0)
|
||||||
|
next=$(meson rewrite kwargs info project / 2>&1 >/dev/null | jq -r '.kwargs["project#/"].version')
|
||||||
|
|
||||||
|
case "$next" in
|
||||||
|
*-dev)
|
||||||
|
echo "This is a development version"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ "$prev" = "$next" ]; then
|
||||||
|
echo "Version not bumped in meson.build"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! git diff-index --quiet HEAD -- meson.build; then
|
||||||
|
echo "meson.build not committed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
shortlog="$(git shortlog --no-merges "$prev..")"
|
||||||
|
(echo "sway $next"; echo ""; echo "$shortlog") | git tag "$next" -ase -F -
|
||||||
|
|
||||||
|
prefix=sway-$next
|
||||||
|
archive=$prefix.tar.gz
|
||||||
|
git archive --prefix="$prefix/" -o "$archive" "$next"
|
||||||
|
gpg --output "$archive".sig --detach-sig "$archive"
|
||||||
|
|
||||||
|
gh release create "sway $next" -t "$next" -n "" -d "$archive" "$archive.sig"
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
@ -82,7 +81,6 @@ static const struct cmd_handler handlers[] = {
|
||||||
{ "no_focus", cmd_no_focus },
|
{ "no_focus", cmd_no_focus },
|
||||||
{ "output", cmd_output },
|
{ "output", cmd_output },
|
||||||
{ "popup_during_fullscreen", cmd_popup_during_fullscreen },
|
{ "popup_during_fullscreen", cmd_popup_during_fullscreen },
|
||||||
{ "primary_selection", cmd_primary_selection },
|
|
||||||
{ "seat", cmd_seat },
|
{ "seat", cmd_seat },
|
||||||
{ "set", cmd_set },
|
{ "set", cmd_set },
|
||||||
{ "show_marks", cmd_show_marks },
|
{ "show_marks", cmd_show_marks },
|
||||||
|
@ -105,6 +103,7 @@ static const struct cmd_handler handlers[] = {
|
||||||
static const struct cmd_handler config_handlers[] = {
|
static const struct cmd_handler config_handlers[] = {
|
||||||
{ "default_orientation", cmd_default_orientation },
|
{ "default_orientation", cmd_default_orientation },
|
||||||
{ "include", cmd_include },
|
{ "include", cmd_include },
|
||||||
|
{ "primary_selection", cmd_primary_selection },
|
||||||
{ "swaybg_command", cmd_swaybg_command },
|
{ "swaybg_command", cmd_swaybg_command },
|
||||||
{ "swaynag_command", cmd_swaynag_command },
|
{ "swaynag_command", cmd_swaynag_command },
|
||||||
{ "workspace_layout", cmd_workspace_layout },
|
{ "workspace_layout", cmd_workspace_layout },
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <libevdev/libevdev.h>
|
#include <libevdev/libevdev.h>
|
||||||
#include <linux/input-event-codes.h>
|
#include <linux/input-event-codes.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
|
@ -5,9 +5,8 @@
|
||||||
#include "sway/tree/container.h"
|
#include "sway/tree/container.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
static void rebuild_textures_iterator(struct sway_container *con, void *data) {
|
static void container_update_iterator(struct sway_container *con, void *data) {
|
||||||
container_update_marks_textures(con);
|
container_update(con);
|
||||||
container_update_title_textures(con);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct cmd_results *handle_command(int argc, char **argv, char *cmd_name,
|
static struct cmd_results *handle_command(int argc, char **argv, char *cmd_name,
|
||||||
|
@ -51,12 +50,7 @@ static struct cmd_results *handle_command(int argc, char **argv, char *cmd_name,
|
||||||
memcpy(class, &colors, sizeof(struct border_colors));
|
memcpy(class, &colors, sizeof(struct border_colors));
|
||||||
|
|
||||||
if (config->active) {
|
if (config->active) {
|
||||||
root_for_each_container(rebuild_textures_iterator, NULL);
|
root_for_each_container(container_update_iterator, NULL);
|
||||||
|
|
||||||
for (int i = 0; i < root->outputs->length; ++i) {
|
|
||||||
struct sway_output *output = root->outputs->items[i];
|
|
||||||
output_damage_whole(output);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
|
||||||
#include "gesture.h"
|
#include "gesture.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/input/input-manager.h"
|
#include "sway/input/input-manager.h"
|
||||||
|
#include "sway/server.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
||||||
#if WLR_HAS_LIBINPUT_BACKEND
|
#if WLR_HAS_LIBINPUT_BACKEND
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <wlr/interfaces/wlr_keyboard.h>
|
#include <wlr/interfaces/wlr_keyboard.h>
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/input/input-manager.h"
|
#include "sway/input/input-manager.h"
|
||||||
|
#include "sway/server.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
||||||
struct xkb_switch_layout_action {
|
struct xkb_switch_layout_action {
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
@ -59,7 +58,7 @@ struct cmd_results *cmd_mark(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
|
|
||||||
free(mark);
|
free(mark);
|
||||||
container_update_marks_textures(container);
|
container_update_marks(container);
|
||||||
if (container->view) {
|
if (container->view) {
|
||||||
view_execute_criteria(container->view);
|
view_execute_criteria(container->view);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
@ -12,6 +11,7 @@
|
||||||
#include "sway/input/seat.h"
|
#include "sway/input/seat.h"
|
||||||
#include "sway/ipc-server.h"
|
#include "sway/ipc-server.h"
|
||||||
#include "sway/output.h"
|
#include "sway/output.h"
|
||||||
|
#include "sway/server.h"
|
||||||
#include "sway/tree/arrange.h"
|
#include "sway/tree/arrange.h"
|
||||||
#include "sway/tree/container.h"
|
#include "sway/tree/container.h"
|
||||||
#include "sway/tree/root.h"
|
#include "sway/tree/root.h"
|
||||||
|
@ -770,15 +770,6 @@ static struct cmd_results *cmd_move_in_direction(
|
||||||
ipc_event_window(container, "move");
|
ipc_event_window(container, "move");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Hack to re-focus container
|
|
||||||
seat_set_raw_focus(config->handler_context.seat, &new_ws->node);
|
|
||||||
seat_set_focus_container(config->handler_context.seat, container);
|
|
||||||
|
|
||||||
if (old_ws != new_ws) {
|
|
||||||
ipc_event_workspace(old_ws, new_ws, "focus");
|
|
||||||
workspace_detect_urgent(old_ws);
|
|
||||||
workspace_detect_urgent(new_ws);
|
|
||||||
}
|
|
||||||
container_end_mouse_operation(container);
|
container_end_mouse_operation(container);
|
||||||
|
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
||||||
|
|
|
@ -37,6 +37,7 @@ struct cmd_results *cmd_opacity(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
|
|
||||||
con->alpha = val;
|
con->alpha = val;
|
||||||
container_damage_whole(con);
|
container_update(con);
|
||||||
|
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
||||||
}
|
}
|
||||||
|
|
|
@ -103,15 +103,18 @@ struct cmd_results *cmd_output(int argc, char **argv) {
|
||||||
|
|
||||||
bool background = output->background;
|
bool background = output->background;
|
||||||
|
|
||||||
output = store_output_config(output);
|
store_output_config(output);
|
||||||
|
|
||||||
// If reloading, the output configs will be applied after reading the
|
// If reloading, the output configs will be applied after reading the
|
||||||
// entire config and before the deferred commands so that an auto generated
|
// entire config and before the deferred commands so that an auto generated
|
||||||
// workspace name is not given to re-enabled outputs.
|
// workspace name is not given to re-enabled outputs.
|
||||||
if (!config->reloading && !config->validating) {
|
if (!config->reloading && !config->validating) {
|
||||||
apply_output_config_to_outputs(output);
|
apply_all_output_configs();
|
||||||
if (background) {
|
if (background) {
|
||||||
spawn_swaybg();
|
if (!spawn_swaybg()) {
|
||||||
|
return cmd_results_new(CMD_FAILURE,
|
||||||
|
"Failed to apply background configuration");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <libgen.h>
|
#include <libgen.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -123,7 +122,10 @@ struct cmd_results *output_cmd_background(int argc, char **argv) {
|
||||||
src);
|
src);
|
||||||
config_add_swaynag_warning("Unable to access background file '%s'",
|
config_add_swaynag_warning("Unable to access background file '%s'",
|
||||||
src);
|
src);
|
||||||
|
struct cmd_results *result = cmd_results_new(CMD_FAILURE,
|
||||||
|
"unable to access background file '%s'", src);
|
||||||
free(src);
|
free(src);
|
||||||
|
return result;
|
||||||
} else {
|
} else {
|
||||||
output->background = src;
|
output->background = src;
|
||||||
output->background_option = strdup(mode);
|
output->background_option = strdup(mode);
|
||||||
|
|
|
@ -29,7 +29,7 @@ struct cmd_results *output_cmd_toggle(int argc, char **argv) {
|
||||||
config->handler_context.output_config->enabled = 1;
|
config->handler_context.output_config->enabled = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
free(oc);
|
free_output_config(oc);
|
||||||
config->handler_context.leftovers.argc = argc;
|
config->handler_context.leftovers.argc = argc;
|
||||||
config->handler_context.leftovers.argv = argv;
|
config->handler_context.leftovers.argv = argv;
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <wlr/util/transform.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -12,12 +12,14 @@ struct cmd_results *cmd_primary_selection(int argc, char **argv) {
|
||||||
|
|
||||||
bool primary_selection = parse_boolean(argv[0], true);
|
bool primary_selection = parse_boolean(argv[0], true);
|
||||||
|
|
||||||
|
// config->primary_selection is reset to the previous value on reload in
|
||||||
|
// load_main_config()
|
||||||
if (config->reloading && config->primary_selection != primary_selection) {
|
if (config->reloading && config->primary_selection != primary_selection) {
|
||||||
return cmd_results_new(CMD_FAILURE,
|
return cmd_results_new(CMD_FAILURE,
|
||||||
"primary_selection can only be enabled/disabled at launch");
|
"primary_selection can only be enabled/disabled at launch");
|
||||||
}
|
}
|
||||||
|
|
||||||
config->primary_selection = parse_boolean(argv[0], true);
|
config->primary_selection = primary_selection;
|
||||||
|
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
@ -9,9 +8,8 @@
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
||||||
static void rebuild_textures_iterator(struct sway_container *con, void *data) {
|
static void title_bar_update_iterator(struct sway_container *con, void *data) {
|
||||||
container_update_marks_textures(con);
|
container_update_title_bar(con);
|
||||||
container_update_title_textures(con);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_reload(void *data) {
|
static void do_reload(void *data) {
|
||||||
|
@ -48,7 +46,7 @@ static void do_reload(void *data) {
|
||||||
}
|
}
|
||||||
list_free_items_and_destroy(bar_ids);
|
list_free_items_and_destroy(bar_ids);
|
||||||
|
|
||||||
root_for_each_container(rebuild_textures_iterator, NULL);
|
root_for_each_container(title_bar_update_iterator, NULL);
|
||||||
|
|
||||||
arrange_root();
|
arrange_root();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <linux/input-event-codes.h>
|
#include <linux/input-event-codes.h>
|
||||||
|
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
|
@ -6,6 +5,7 @@
|
||||||
#include <wlr/types/wlr_pointer.h>
|
#include <wlr/types/wlr_pointer.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/input/cursor.h"
|
#include "sway/input/cursor.h"
|
||||||
|
#include "sway/server.h"
|
||||||
|
|
||||||
static struct cmd_results *press_or_release(struct sway_cursor *cursor,
|
static struct cmd_results *press_or_release(struct sway_cursor *cursor,
|
||||||
char *action, char *button_str);
|
char *action, char *button_str);
|
||||||
|
@ -85,12 +85,12 @@ struct cmd_results *seat_cmd_cursor(int argc, char **argv) {
|
||||||
|
|
||||||
static struct cmd_results *press_or_release(struct sway_cursor *cursor,
|
static struct cmd_results *press_or_release(struct sway_cursor *cursor,
|
||||||
char *action, char *button_str) {
|
char *action, char *button_str) {
|
||||||
enum wlr_button_state state;
|
enum wl_pointer_button_state state;
|
||||||
uint32_t button;
|
uint32_t button;
|
||||||
if (strcasecmp(action, "press") == 0) {
|
if (strcasecmp(action, "press") == 0) {
|
||||||
state = WLR_BUTTON_PRESSED;
|
state = WL_POINTER_BUTTON_STATE_PRESSED;
|
||||||
} else if (strcasecmp(action, "release") == 0) {
|
} else if (strcasecmp(action, "release") == 0) {
|
||||||
state = WLR_BUTTON_RELEASED;
|
state = WL_POINTER_BUTTON_STATE_RELEASED;
|
||||||
} else {
|
} else {
|
||||||
return cmd_results_new(CMD_INVALID, "%s", expected_syntax);
|
return cmd_results_new(CMD_INVALID, "%s", expected_syntax);
|
||||||
}
|
}
|
||||||
|
@ -105,16 +105,16 @@ static struct cmd_results *press_or_release(struct sway_cursor *cursor,
|
||||||
} else if (button == SWAY_SCROLL_UP || button == SWAY_SCROLL_DOWN
|
} else if (button == SWAY_SCROLL_UP || button == SWAY_SCROLL_DOWN
|
||||||
|| button == SWAY_SCROLL_LEFT || button == SWAY_SCROLL_RIGHT) {
|
|| button == SWAY_SCROLL_LEFT || button == SWAY_SCROLL_RIGHT) {
|
||||||
// Dispatch axis event
|
// Dispatch axis event
|
||||||
enum wlr_axis_orientation orientation =
|
enum wl_pointer_axis orientation =
|
||||||
(button == SWAY_SCROLL_UP || button == SWAY_SCROLL_DOWN)
|
(button == SWAY_SCROLL_UP || button == SWAY_SCROLL_DOWN)
|
||||||
? WLR_AXIS_ORIENTATION_VERTICAL
|
? WL_POINTER_AXIS_VERTICAL_SCROLL
|
||||||
: WLR_AXIS_ORIENTATION_HORIZONTAL;
|
: WL_POINTER_AXIS_HORIZONTAL_SCROLL;
|
||||||
double delta = (button == SWAY_SCROLL_UP || button == SWAY_SCROLL_LEFT)
|
double delta = (button == SWAY_SCROLL_UP || button == SWAY_SCROLL_LEFT)
|
||||||
? -1 : 1;
|
? -1 : 1;
|
||||||
struct wlr_pointer_axis_event event = {
|
struct wlr_pointer_axis_event event = {
|
||||||
.pointer = NULL,
|
.pointer = NULL,
|
||||||
.time_msec = 0,
|
.time_msec = 0,
|
||||||
.source = WLR_AXIS_SOURCE_WHEEL,
|
.source = WL_POINTER_AXIS_SOURCE_WHEEL,
|
||||||
.orientation = orientation,
|
.orientation = orientation,
|
||||||
.delta = delta * 15,
|
.delta = delta * 15,
|
||||||
.delta_discrete = delta
|
.delta_discrete = delta
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/input/cursor.h"
|
#include "sway/input/cursor.h"
|
||||||
#include "sway/input/seat.h"
|
#include "sway/input/seat.h"
|
||||||
|
#include "sway/server.h"
|
||||||
|
|
||||||
enum operation {
|
enum operation {
|
||||||
OP_ENABLE,
|
OP_ENABLE,
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/input/seat.h"
|
#include "sway/input/seat.h"
|
||||||
#include "sway/input/input-manager.h"
|
#include "sway/input/input-manager.h"
|
||||||
|
#include "sway/server.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
static struct cmd_results *handle_action(struct seat_config *sc,
|
static struct cmd_results *handle_action(struct seat_config *sc,
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/input/seat.h"
|
#include "sway/input/seat.h"
|
||||||
|
#include "sway/server.h"
|
||||||
#include "sway/tree/container.h"
|
#include "sway/tree/container.h"
|
||||||
#include "sway/tree/view.h"
|
#include "sway/tree/view.h"
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
@ -10,8 +9,8 @@
|
||||||
#include "stringop.h"
|
#include "stringop.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
static void rebuild_marks_iterator(struct sway_container *con, void *data) {
|
static void title_bar_update_iterator(struct sway_container *con, void *data) {
|
||||||
container_update_marks_textures(con);
|
container_update_marks(con);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct cmd_results *cmd_show_marks(int argc, char **argv) {
|
struct cmd_results *cmd_show_marks(int argc, char **argv) {
|
||||||
|
@ -23,12 +22,7 @@ struct cmd_results *cmd_show_marks(int argc, char **argv) {
|
||||||
config->show_marks = parse_boolean(argv[0], config->show_marks);
|
config->show_marks = parse_boolean(argv[0], config->show_marks);
|
||||||
|
|
||||||
if (config->show_marks) {
|
if (config->show_marks) {
|
||||||
root_for_each_container(rebuild_marks_iterator, NULL);
|
root_for_each_container(title_bar_update_iterator, NULL);
|
||||||
}
|
|
||||||
|
|
||||||
for (int i = 0; i < root->outputs->length; ++i) {
|
|
||||||
struct sway_output *output = root->outputs->items[i];
|
|
||||||
output_damage_whole(output);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
@ -19,7 +18,7 @@ static bool test_con_id(struct sway_container *container, void *data) {
|
||||||
return container->node.id == *con_id;
|
return container->node.id == *con_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
static bool test_id(struct sway_container *container, void *data) {
|
static bool test_id(struct sway_container *container, void *data) {
|
||||||
xcb_window_t *wid = data;
|
xcb_window_t *wid = data;
|
||||||
return (container->view && container->view->type == SWAY_VIEW_XWAYLAND
|
return (container->view && container->view->type == SWAY_VIEW_XWAYLAND
|
||||||
|
@ -54,7 +53,7 @@ struct cmd_results *cmd_swap(int argc, char **argv) {
|
||||||
|
|
||||||
char *value = join_args(argv + 3, argc - 3);
|
char *value = join_args(argv + 3, argc - 3);
|
||||||
if (strcasecmp(argv[2], "id") == 0) {
|
if (strcasecmp(argv[2], "id") == 0) {
|
||||||
#if HAVE_XWAYLAND
|
#if WLR_HAS_XWAYLAND
|
||||||
xcb_window_t id = strtol(value, NULL, 0);
|
xcb_window_t id = strtol(value, NULL, 0);
|
||||||
other = root_find_container(test_id, &id);
|
other = root_find_container(test_id, &id);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -4,6 +4,10 @@
|
||||||
#include "sway/tree/container.h"
|
#include "sway/tree/container.h"
|
||||||
#include "sway/tree/root.h"
|
#include "sway/tree/root.h"
|
||||||
|
|
||||||
|
static void arrange_title_bar_iterator(struct sway_container *con, void *data) {
|
||||||
|
container_arrange_title_bar(con);
|
||||||
|
}
|
||||||
|
|
||||||
struct cmd_results *cmd_title_align(int argc, char **argv) {
|
struct cmd_results *cmd_title_align(int argc, char **argv) {
|
||||||
struct cmd_results *error = NULL;
|
struct cmd_results *error = NULL;
|
||||||
if ((error = checkarg(argc, "title_align", EXPECTED_AT_LEAST, 1))) {
|
if ((error = checkarg(argc, "title_align", EXPECTED_AT_LEAST, 1))) {
|
||||||
|
@ -21,10 +25,7 @@ struct cmd_results *cmd_title_align(int argc, char **argv) {
|
||||||
"Expected 'title_align left|center|right'");
|
"Expected 'title_align left|center|right'");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < root->outputs->length; ++i) {
|
root_for_each_container(arrange_title_bar_iterator, NULL);
|
||||||
struct sway_output *output = root->outputs->items[i];
|
|
||||||
output_damage_whole(output);
|
|
||||||
}
|
|
||||||
|
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
|
|
@ -27,7 +27,6 @@ struct cmd_results *cmd_titlebar_border_thickness(int argc, char **argv) {
|
||||||
"Expected output to have a workspace");
|
"Expected output to have a workspace");
|
||||||
}
|
}
|
||||||
arrange_workspace(ws);
|
arrange_workspace(ws);
|
||||||
output_damage_whole(output);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
||||||
|
|
|
@ -33,7 +33,6 @@ struct cmd_results *cmd_titlebar_padding(int argc, char **argv) {
|
||||||
for (int i = 0; i < root->outputs->length; ++i) {
|
for (int i = 0; i < root->outputs->length; ++i) {
|
||||||
struct sway_output *output = root->outputs->items[i];
|
struct sway_output *output = root->outputs->items[i];
|
||||||
arrange_workspace(output_get_active_workspace(output));
|
arrange_workspace(output_get_active_workspace(output));
|
||||||
output_damage_whole(output);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return cmd_results_new(CMD_SUCCESS, NULL);
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "sway/commands.h"
|
#include "sway/commands.h"
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
|
@ -8,9 +7,13 @@
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "stringop.h"
|
#include "stringop.h"
|
||||||
|
|
||||||
static void remove_all_marks_iterator(struct sway_container *con, void *data) {
|
static void remove_mark(struct sway_container *con) {
|
||||||
container_clear_marks(con);
|
container_clear_marks(con);
|
||||||
container_update_marks_textures(con);
|
container_update_marks(con);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void remove_all_marks_iterator(struct sway_container *con, void *data) {
|
||||||
|
remove_mark(con);
|
||||||
}
|
}
|
||||||
|
|
||||||
// unmark Remove all marks from all views
|
// unmark Remove all marks from all views
|
||||||
|
@ -38,8 +41,7 @@ struct cmd_results *cmd_unmark(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
} else if (con && !mark) {
|
} else if (con && !mark) {
|
||||||
// Clear all marks from the given container
|
// Clear all marks from the given container
|
||||||
container_clear_marks(con);
|
remove_mark(con);
|
||||||
container_update_marks_textures(con);
|
|
||||||
} else if (!con && mark) {
|
} else if (!con && mark) {
|
||||||
// Remove mark from whichever container has it
|
// Remove mark from whichever container has it
|
||||||
container_find_and_unmark(mark);
|
container_find_and_unmark(mark);
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
#define _POSIX_C_SOURCE 200809L
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
|
@ -10,7 +10,7 @@ struct cmd_results *cmd_xwayland(int argc, char **argv) {
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HAVE_XWAYLAND
|
#ifdef WLR_HAS_XWAYLAND
|
||||||
enum xwayland_mode xwayland;
|
enum xwayland_mode xwayland;
|
||||||
if (strcmp(argv[0], "force") == 0) {
|
if (strcmp(argv[0], "force") == 0) {
|
||||||
xwayland = XWAYLAND_MODE_IMMEDIATE;
|
xwayland = XWAYLAND_MODE_IMMEDIATE;
|
||||||
|
@ -20,6 +20,8 @@ struct cmd_results *cmd_xwayland(int argc, char **argv) {
|
||||||
xwayland = XWAYLAND_MODE_DISABLED;
|
xwayland = XWAYLAND_MODE_DISABLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// config->xwayland is reset to the previous value on reload in
|
||||||
|
// load_main_config()
|
||||||
if (config->reloading && config->xwayland != xwayland) {
|
if (config->reloading && config->xwayland != xwayland) {
|
||||||
return cmd_results_new(CMD_FAILURE,
|
return cmd_results_new(CMD_FAILURE,
|
||||||
"xwayland can only be enabled/disabled at launch");
|
"xwayland can only be enabled/disabled at launch");
|
||||||
|
|
106
sway/config.c
106
sway/config.c
|
@ -1,3 +1,4 @@
|
||||||
|
#undef _POSIX_C_SOURCE
|
||||||
#define _XOPEN_SOURCE 700 // for realpath
|
#define _XOPEN_SOURCE 700 // for realpath
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
@ -22,6 +23,7 @@
|
||||||
#include "sway/config.h"
|
#include "sway/config.h"
|
||||||
#include "sway/criteria.h"
|
#include "sway/criteria.h"
|
||||||
#include "sway/desktop/transaction.h"
|
#include "sway/desktop/transaction.h"
|
||||||
|
#include "sway/server.h"
|
||||||
#include "sway/swaynag.h"
|
#include "sway/swaynag.h"
|
||||||
#include "sway/tree/arrange.h"
|
#include "sway/tree/arrange.h"
|
||||||
#include "sway/tree/root.h"
|
#include "sway/tree/root.h"
|
||||||
|
@ -36,19 +38,26 @@
|
||||||
struct sway_config *config = NULL;
|
struct sway_config *config = NULL;
|
||||||
|
|
||||||
static struct xkb_state *keysym_translation_state_create(
|
static struct xkb_state *keysym_translation_state_create(
|
||||||
struct xkb_rule_names rules) {
|
struct xkb_rule_names rules, uint32_t context_flags) {
|
||||||
struct xkb_context *context = xkb_context_new(XKB_CONTEXT_NO_SECURE_GETENV);
|
struct xkb_context *context = xkb_context_new(context_flags | XKB_CONTEXT_NO_SECURE_GETENV);
|
||||||
struct xkb_keymap *xkb_keymap = xkb_keymap_new_from_names(
|
struct xkb_keymap *xkb_keymap = xkb_keymap_new_from_names(
|
||||||
context,
|
context,
|
||||||
&rules,
|
&rules,
|
||||||
XKB_KEYMAP_COMPILE_NO_FLAGS);
|
XKB_KEYMAP_COMPILE_NO_FLAGS);
|
||||||
|
|
||||||
xkb_context_unref(context);
|
xkb_context_unref(context);
|
||||||
|
if (xkb_keymap == NULL) {
|
||||||
|
sway_log(SWAY_ERROR, "Failed to compile keysym translation XKB keymap");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
return xkb_state_new(xkb_keymap);
|
return xkb_state_new(xkb_keymap);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void keysym_translation_state_destroy(
|
static void keysym_translation_state_destroy(
|
||||||
struct xkb_state *state) {
|
struct xkb_state *state) {
|
||||||
|
if (state == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
xkb_keymap_unref(xkb_state_get_keymap(state));
|
xkb_keymap_unref(xkb_state_get_keymap(state));
|
||||||
xkb_state_unref(state);
|
xkb_state_unref(state);
|
||||||
}
|
}
|
||||||
|
@ -336,8 +345,14 @@ static void config_defaults(struct sway_config *config) {
|
||||||
|
|
||||||
// The keysym to keycode translation
|
// The keysym to keycode translation
|
||||||
struct xkb_rule_names rules = {0};
|
struct xkb_rule_names rules = {0};
|
||||||
config->keysym_translation_state =
|
config->keysym_translation_state = keysym_translation_state_create(rules, 0);
|
||||||
keysym_translation_state_create(rules);
|
if (config->keysym_translation_state == NULL) {
|
||||||
|
config->keysym_translation_state = keysym_translation_state_create(rules,
|
||||||
|
XKB_CONTEXT_NO_ENVIRONMENT_NAMES);
|
||||||
|
}
|
||||||
|
if (config->keysym_translation_state == NULL) {
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
return;
|
return;
|
||||||
cleanup:
|
cleanup:
|
||||||
|
@ -352,13 +367,7 @@ static char *config_path(const char *prefix, const char *config_folder) {
|
||||||
if (!prefix || !prefix[0] || !config_folder || !config_folder[0]) {
|
if (!prefix || !prefix[0] || !config_folder || !config_folder[0]) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
return format_str("%s/%s/config", prefix, config_folder);
|
||||||
const char *filename = "config";
|
|
||||||
|
|
||||||
size_t size = 3 + strlen(prefix) + strlen(config_folder) + strlen(filename);
|
|
||||||
char *path = calloc(size, sizeof(char));
|
|
||||||
snprintf(path, size, "%s/%s/%s", prefix, config_folder, filename);
|
|
||||||
return path;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *get_config_path(void) {
|
static char *get_config_path(void) {
|
||||||
|
@ -368,10 +377,7 @@ static char *get_config_path(void) {
|
||||||
|
|
||||||
const char *config_home = getenv("XDG_CONFIG_HOME");
|
const char *config_home = getenv("XDG_CONFIG_HOME");
|
||||||
if ((config_home == NULL || config_home[0] == '\0') && home != NULL) {
|
if ((config_home == NULL || config_home[0] == '\0') && home != NULL) {
|
||||||
size_t size_fallback = 1 + strlen(home) + strlen("/.config");
|
config_home_fallback = format_str("%s/.config", home);
|
||||||
config_home_fallback = calloc(size_fallback, sizeof(char));
|
|
||||||
if (config_home_fallback != NULL)
|
|
||||||
snprintf(config_home_fallback, size_fallback, "%s/.config", home);
|
|
||||||
config_home = config_home_fallback;
|
config_home = config_home_fallback;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -475,6 +481,11 @@ bool load_main_config(const char *file, bool is_active, bool validating) {
|
||||||
old_config->xwayland ? "enabled" : "disabled");
|
old_config->xwayland ? "enabled" : "disabled");
|
||||||
config->xwayland = old_config->xwayland;
|
config->xwayland = old_config->xwayland;
|
||||||
|
|
||||||
|
// primary_selection can only be enabled/disabled at launch
|
||||||
|
sway_log(SWAY_DEBUG, "primary_selection will remain %s",
|
||||||
|
old_config->primary_selection ? "enabled" : "disabled");
|
||||||
|
config->primary_selection = old_config->primary_selection;
|
||||||
|
|
||||||
if (!config->validating) {
|
if (!config->validating) {
|
||||||
if (old_config->swaybg_client != NULL) {
|
if (old_config->swaybg_client != NULL) {
|
||||||
wl_client_destroy(old_config->swaybg_client);
|
wl_client_destroy(old_config->swaybg_client);
|
||||||
|
@ -494,56 +505,7 @@ bool load_main_config(const char *file, bool is_active, bool validating) {
|
||||||
|
|
||||||
config->reading = true;
|
config->reading = true;
|
||||||
|
|
||||||
// Read security configs
|
bool success = load_config(path, config, &config->swaynag_config_errors);
|
||||||
// TODO: Security
|
|
||||||
bool success = true;
|
|
||||||
/*
|
|
||||||
DIR *dir = opendir(SYSCONFDIR "/sway/security.d");
|
|
||||||
if (!dir) {
|
|
||||||
sway_log(SWAY_ERROR,
|
|
||||||
"%s does not exist, sway will have no security configuration"
|
|
||||||
" and will probably be broken", SYSCONFDIR "/sway/security.d");
|
|
||||||
} else {
|
|
||||||
list_t *secconfigs = create_list();
|
|
||||||
char *base = SYSCONFDIR "/sway/security.d/";
|
|
||||||
struct dirent *ent = readdir(dir);
|
|
||||||
struct stat s;
|
|
||||||
while (ent != NULL) {
|
|
||||||
char *_path = malloc(strlen(ent->d_name) + strlen(base) + 1);
|
|
||||||
strcpy(_path, base);
|
|
||||||
strcat(_path, ent->d_name);
|
|
||||||
lstat(_path, &s);
|
|
||||||
if (S_ISREG(s.st_mode) && ent->d_name[0] != '.') {
|
|
||||||
list_add(secconfigs, _path);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
free(_path);
|
|
||||||
}
|
|
||||||
ent = readdir(dir);
|
|
||||||
}
|
|
||||||
closedir(dir);
|
|
||||||
|
|
||||||
list_qsort(secconfigs, qstrcmp);
|
|
||||||
for (int i = 0; i < secconfigs->length; ++i) {
|
|
||||||
char *_path = secconfigs->items[i];
|
|
||||||
if (stat(_path, &s) || s.st_uid != 0 || s.st_gid != 0 ||
|
|
||||||
(((s.st_mode & 0777) != 0644) &&
|
|
||||||
(s.st_mode & 0777) != 0444)) {
|
|
||||||
sway_log(SWAY_ERROR,
|
|
||||||
"Refusing to load %s - it must be owned by root "
|
|
||||||
"and mode 644 or 444", _path);
|
|
||||||
success = false;
|
|
||||||
} else {
|
|
||||||
success = success && load_config(_path, config);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
list_free_items_and_destroy(secconfigs);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
success = success && load_config(path, config,
|
|
||||||
&config->swaynag_config_errors);
|
|
||||||
|
|
||||||
if (validating) {
|
if (validating) {
|
||||||
free_config(config);
|
free_config(config);
|
||||||
|
@ -571,7 +533,7 @@ bool load_main_config(const char *file, bool is_active, bool validating) {
|
||||||
}
|
}
|
||||||
sway_switch_retrigger_bindings_for_all();
|
sway_switch_retrigger_bindings_for_all();
|
||||||
|
|
||||||
reset_outputs();
|
apply_all_output_configs();
|
||||||
spawn_swaybg();
|
spawn_swaybg();
|
||||||
|
|
||||||
config->reloading = false;
|
config->reloading = false;
|
||||||
|
@ -975,7 +937,7 @@ char *do_var_replacement(char *str) {
|
||||||
int offset = find - str;
|
int offset = find - str;
|
||||||
strncpy(newptr, str, offset);
|
strncpy(newptr, str, offset);
|
||||||
newptr += offset;
|
newptr += offset;
|
||||||
strncpy(newptr, var->value, vvlen);
|
memcpy(newptr, var->value, vvlen);
|
||||||
newptr += vvlen;
|
newptr += vvlen;
|
||||||
strcpy(newptr, find + vnlen);
|
strcpy(newptr, find + vnlen);
|
||||||
free(str);
|
free(str);
|
||||||
|
@ -1037,8 +999,12 @@ void translate_keysyms(struct input_config *input_config) {
|
||||||
|
|
||||||
struct xkb_rule_names rules = {0};
|
struct xkb_rule_names rules = {0};
|
||||||
input_config_fill_rule_names(input_config, &rules);
|
input_config_fill_rule_names(input_config, &rules);
|
||||||
config->keysym_translation_state =
|
config->keysym_translation_state = keysym_translation_state_create(rules, 0);
|
||||||
keysym_translation_state_create(rules);
|
if (config->keysym_translation_state == NULL) {
|
||||||
|
sway_log(SWAY_ERROR, "Failed to create keysym translation XKB state "
|
||||||
|
"for device '%s'", input_config->identifier);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
for (int i = 0; i < config->modes->length; ++i) {
|
for (int i = 0; i < config->modes->length; ++i) {
|
||||||
struct sway_mode *mode = config->modes->items[i];
|
struct sway_mode *mode = config->modes->items[i];
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue