i3-compatible Wayland compositor
Go to file
Marien Zwart 7d8413d962 Reset signal mask after fork
wlroots uses wl_event_loop_add_signal to handle SIGUSR1 from Xwayland.
wl_event_loop_add_signal works by masking the signal and receiving it from a
signalfd. The signal mask is preserved across fork and exec, so subprocesses
spawned by Sway start with SIGUSR1 masked. Most subprocesses do not expect this
and never unmask the signal, resulting in missing functionality or unexpected
behavior for processes that use SIGUSR1 (such as i3status).

Fix this by unmasking all signals between fork and exec.
2018-08-02 21:31:34 +10:00
assets Recompressed PNG files 2017-01-05 21:49:28 -05:00
client Set pool_buffers busy when handing them out 2018-06-17 17:34:12 -04:00
common Address review comments on parse_boolean 2018-07-23 21:37:53 -04:00
completions ipc: add tick event 2018-08-01 16:57:15 +01:00
contrib Move awesome config to contrib/ 2017-01-14 16:03:41 -05:00
include Merge branch 'master' into fix-resize-wiggle 2018-08-02 08:11:10 +01:00
protocols Swaylock: Allow per-output images 2018-05-20 22:54:09 +10:00
security.d delete references to swaygrab 2018-07-30 16:24:46 +01:00
sway Reset signal mask after fork 2018-08-02 21:31:34 +10:00
swaybar swaybar: Fix scroll handling on workspace buttons 2018-07-19 21:15:01 +02:00
swaybg swaybar/bg: Fix crash on DPMS off 2018-07-14 00:04:02 +02:00
swayidle delete references to swaygrab 2018-07-30 16:24:46 +01:00
swaylock Fix swaylock arguments 2018-07-17 21:50:15 -04:00
swaymsg ipc: add tick event 2018-08-01 16:57:15 +01:00
.build.yml Add scdoc to .build.yml 2018-05-11 21:40:52 -04:00
.clang-format Update .clang-format - not entirely usable yet 2017-01-10 23:30:34 -05:00
.editorconfig Create .editorconfig 2016-07-04 14:12:32 +02:00
.gitignore Add subprojects to gitignore 2018-03-28 12:22:28 -04:00
CONTRIBUTING.md Update for swaywm/wlroots#1126 2018-07-09 22:54:30 +01:00
HACKING.md Update for swaywm/wlroots#1126 2018-07-09 22:54:30 +01:00
LICENSE MIT license 2017-01-06 13:45:48 -05:00
README.de.md delete references to swaygrab 2018-07-30 16:24:46 +01:00
README.el.md delete references to swaygrab 2018-07-30 16:24:46 +01:00
README.fr.md delete references to swaygrab 2018-07-30 16:24:46 +01:00
README.it.md delete references to swaygrab 2018-07-30 16:24:46 +01:00
README.ja.md delete references to swaygrab 2018-07-30 16:24:46 +01:00
README.md delete references to swaygrab 2018-07-30 16:24:46 +01:00
README.pt.md delete references to swaygrab 2018-07-30 16:24:46 +01:00
README.ru.md delete references to swaygrab 2018-07-30 16:24:46 +01:00
README.uk.md delete references to swaygrab 2018-07-30 16:24:46 +01:00
config.in Implement pid->workspace tracking 2018-07-01 09:58:18 -04:00
meson.build Link xcb dependency to meson options "enable_xwayland" (#2393) 2018-08-02 08:36:47 +01:00
meson_options.txt meson: install bash completion 2018-07-30 15:56:50 +01:00
sway.desktop Add Wayland and Xorg session files 2015-08-20 23:12:34 +02:00

README.md

sway

English - 日本語 - Deutsch - Ελληνικά - Français - Українська - Italiano - Português - Русский

"SirCmpwn's Wayland compositor" is a work in progress i3-compatible Wayland compositor. Read the FAQ. Join the IRC channel (#sway on irc.freenode.net).

Notice: You are viewing the unstable and unsupported master branch of sway, where work is ongoing to port it to wlroots. The supported branch is the 0.15 branch, and end users are encouraged to use the stable releases cut from it.

If you'd like to support sway development, please contribute to SirCmpwn's Patreon page.

Release Signatures

Releases are signed with B22DA89A and published on GitHub.

Status

Installation

From Packages

Sway is available in many distributions. Try installing the "sway" package for yours. If it's not available, check out this wiki page for information on installation for your distributions.

If you're interested in packaging sway for your distribution, stop by the IRC channel or shoot an email to sir@cmpwn.com for advice.

Compiling from Source

Install dependencies:

  • meson
  • wlroots
  • wayland
  • xwayland
  • libinput >= 1.6.0
  • libcap
  • pcre
  • json-c >= 0.13
  • pango
  • cairo
  • gdk-pixbuf2 *
  • pam **
  • dbus >= 1.10 ***
  • scdoc (required for man pages)

*Only required for swaybar, swaybg, and swaylock

**Only required for swaylock

***Only required for tray support

Run these commands:

meson build
ninja -C build
sudo ninja -C build install

On systems with logind, you need to set a few caps on the binary:

sudo setcap "cap_sys_ptrace,cap_sys_tty_config=eip" /usr/local/bin/sway

On systems without logind, you need to suid the sway binary:

sudo chmod a+s /usr/local/bin/sway

Configuration

If you already use i3, then copy your i3 config to ~/.config/sway/config and it'll work out of the box. Otherwise, copy the sample configuration file to ~/.config/sway/config. It is usually located at /etc/sway/config. Run man 5 sway for information on the configuration.

Running

Run sway from a TTY. Some display managers may work but are not supported by sway (gdm is known to work fairly well).