A private fork of the Sway Wayland compositor.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Drew DeVault 200d0360ea
Merge branch 'master' of github.com:swaywm/sway
7 years ago
assets Recompressed PNG files 8 years ago
client Handle output removal on swaybar 7 years ago
common R E N D E R I N G 7 years ago
completions/zsh remove relevant CMakeLists.txt 7 years ago
contrib Move awesome config to contrib/ 8 years ago
include Clean up cursor simulation code. 7 years ago
protocols Implement input-inhibit in sway, swaylock 7 years ago
security.d add meson install files 7 years ago
sway Add documentation for seat cursor command. 7 years ago
swaybar Fix separator height calculation 7 years ago
swaybg Initial swaylock port 7 years ago
swaygrab remove the rest of cmake 7 years ago
swaylock Error handling in swaylock daemonize() 7 years ago
swaymsg ipc: add output modes 7 years ago
.build.yml Remove wlc-git from .build.yml 7 years ago
.clang-format Update .clang-format - not entirely usable yet 8 years ago
.editorconfig Create .editorconfig 9 years ago
.gitignore Add subprojects to gitignore 7 years ago
CONTRIBUTING.md Update README et al with new links 7 years ago
HACKING.md update hacking for meson 7 years ago
LICENSE MIT license 8 years ago
README.de.md Merge branch 'master' of github.com:swaywm/sway 7 years ago
README.el.md Fix json-c version dependency 7 years ago
README.fr.md Fix json-c version dependency 7 years ago
README.it.md Fix json-c version dependency 7 years ago
README.ja.md Fix json-c version dependency 7 years ago
README.md Add README.md 7 years ago
README.pt.md Fix json-c version dependency 7 years ago
README.ru.md Merge branch 'wlroots' 7 years ago
README.uk.md Fix json-c version dependency 7 years ago
config.in Implement resize command 7 years ago
meson.build Improve dependency checks 7 years ago
meson_options.txt meson zsh completions install 7 years ago
sway.desktop Add Wayland and Xorg session files 9 years ago

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
  • asciidoc
  • pcre
  • json-c >= 0.13
  • pango
  • cairo
  • gdk-pixbuf2 *
  • pam **
  • dbus >= 1.10 ***
  • imagemagick (required for image capture with swaygrab)
  • ffmpeg (required for video capture with swaygrab)

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