i3-compatible Wayland compositor
Find a file
Tudor Brindus 47f1f9b63e swaybar: use INT_MAX max JSON depth when parsing IPC response
There's no inherent limit on the nesting Sway can generate, and the
default used by `json_tokener_new`, 32, can plausibly be hit during
regular usage.

Fixes #6115.
2021-03-21 23:34:07 +01:00
.builds ci: Update alpine xwayland package name 2021-03-20 13:25:14 +01:00
.github/ISSUE_TEMPLATE Fix typo in bug reporting template 2021-01-26 09:08:00 +01:00
assets License wallpapers as CC-0 2019-12-16 14:35:58 -05:00
client Rename symbol set_cloexec to sway_set_cloexec, remove duplicates. 2019-11-01 12:41:08 -04:00
common common/log: write log importance 2020-12-10 09:26:02 +01:00
completions i3-compat: add GET_BINDING_STATE IPC command 2020-06-14 00:55:14 -04:00
contrib grimshot: document support for piping to STDOUT. 2021-02-23 17:07:53 +01:00
include idle_inhibit: Store wlr inhibitor instead of view 2021-03-21 12:27:29 +01:00
protocols protocols: update layer-shell-unstable-v1 to v4 2021-01-12 22:38:45 +01:00
sway idle_inhibit: Store wlr inhibitor instead of view 2021-03-21 12:27:29 +01:00
swaybar swaybar: use INT_MAX max JSON depth when parsing IPC response 2021-03-21 23:34:07 +01:00
swaymsg Make command line option lists const 2021-02-04 09:49:06 +01:00
swaynag swaynag: Use position from wl_pointer.enter 2021-02-07 20:18:53 -05: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 Allocate minimum size necessary in pango text functions. (#3473) 2019-01-20 15:03:30 +01:00
config.in rephrase swayidle-timout example to improve readability 2020-07-12 14:29:49 +02:00
CONTRIBUTING.md CONTRIBUTING.md: Add note on sway's scope 2021-01-04 09:18:13 -05:00
LICENSE MIT license 2017-01-06 13:45:48 -05:00
meson.build build: update version to v1.6-rc1 2021-03-16 18:04:39 +01:00
meson_options.txt build: add basu as sd-bus provider 2020-12-09 17:39:20 -05:00
README.de.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.dk.md Fix typo in README.dk.md 2021-02-18 12:47:14 +01:00
README.es.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.fr.md readme: update French translation 2021-02-10 09:44:38 +01:00
README.ja.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.ko.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.md readme: remove unused ref 2021-01-08 09:32:28 +01:00
README.nl.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.pl.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.pt.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.ro.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.ru.md Update Russian translation 2021-02-17 09:21:08 +01:00
README.uk.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.zh-CN.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
README.zh-TW.md Remove Patreon links from README.*.md 2020-12-26 20:14:24 -05:00
sway.desktop Update language in sway.desktop & sway(1) 2019-03-10 15:09:52 -04:00

sway

English - 日本語 - Français - Українська - Español - Polski - 中文-简体 - Deutsch - Nederlands - Русский - 中文-繁體 - Português - Danish - 한국어 - Română

sway is an i3-compatible Wayland compositor. Read the FAQ. Join the IRC channel (#sway on irc.freenode.net).

Release Signatures

Releases are signed with E88F5E48 and published on GitHub.

Installation

From Packages

Sway is available in many distributions. Try installing the "sway" package for yours.

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

Check out this wiki page if you want to build the HEAD of sway and wlroots for testing or development.

Install dependencies:

  • meson *
  • wlroots
  • wayland
  • wayland-protocols *
  • pcre
  • json-c
  • pango
  • cairo
  • gdk-pixbuf2 (optional: system tray)
  • scdoc (optional: man pages) *
  • git (optional: version info) *

*Compile-time dep

Run these commands:

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

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

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

Sway will drop root permissions shortly after startup.

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).