i3-compatible Wayland compositor
Find a file
Ryan Dwyer b6058703fa Refactor destroy functions and save workspaces when there's no outputs
This changes the destroy functions to the following:

* output_begin_destroy
* output_destroy
* workspace_begin_destroy
* workspace_destroy
* container_begin_destroy
* container_destroy
* view_begin_destroy
* view_destroy

The terminology was `destroy` and `free`, and it has been changed to
`begin_destroy` and `destroy` respectively.

When the last output is disconnected, its workspaces will now be stashed
in the root. Upon connection of a new output they will be restored.

There is a new function `workspace_consider_destroy` which decides
whether the given workspace should be destroyed or not (ie. empty and
not visible).

Calling container_begin_destroy will no longer automatically reap the
parents. In some places we want to reap the parents and in some we
don't, so this is left to the caller.

container_reap_empty_recursive and container_reap_empty have been
combined into one function and it will recurse up the tree.
2018-08-24 22:17:28 +10:00
assets
client
common Use list_find in more places and refactor/fix workspace prev_next functions 2018-08-15 15:14:35 +10:00
completions Fix swaylock zsh completions 2018-08-16 23:21:30 +01:00
contrib
include Refactor destroy functions and save workspaces when there's no outputs 2018-08-24 22:17:28 +10:00
protocols
security.d
sway Refactor destroy functions and save workspaces when there's no outputs 2018-08-24 22:17:28 +10:00
swaybar
swaybg Allow a fallback color to be specified for swaybg 2018-08-08 15:37:06 -04:00
swayidle
swaylock
swaymsg
swaynag Fix bad-free in swaynag 2018-08-20 15:06:12 -04:00
.build.yml
.clang-format
.editorconfig
.gitignore
config.in config.in: nag user on exit 2018-08-02 15:42:43 +01:00
CONTRIBUTING.md
HACKING.md
LICENSE
meson.build Merge branch 'master' into nagbar 2018-08-02 23:05:49 +10:00
meson_options.txt
README.de.md Remove setcap instructions 2018-08-08 11:40:33 -04:00
README.el.md Remove setcap instructions 2018-08-08 11:40:33 -04:00
README.fr.md Remove setcap instructions 2018-08-08 11:40:33 -04:00
README.it.md Remove setcap instructions 2018-08-08 11:40:33 -04:00
README.ja.md 私の日本語が上手じゃないですね 2018-08-08 11:53:11 -04:00
README.md Remove setcap instructions 2018-08-08 11:40:33 -04:00
README.pt.md
README.ru.md
README.uk.md
sway.desktop

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