i3-compatible Wayland compositor
Go to file
Brian Ashworth 6f6a9af60e Add helpers for improved mouse button parsing
The following helper functions have been added to aid with parsing mouse
buttons from a string:

1. `get_mouse_bindsym`: attempts to parse the string as an x11 button
(button[1-9]) or as an event name (ex BTN_LEFT or BTN_SIDE)
2. `get_mouse_bindcode`: attempts to parse the string as an event code
and validates that the event code is a button (starts with `BTN_`).
3. `get_mouse_button`: this is a conveniency function for callers that
do not care whether a bindsym or bindcode are used and attempts to parse
the string as a bindsym and then bindcode.

None of these functions are used in this commit. The sole purpose of
this commit is to make the larger set more granular and easier to
review/manipulate. There will be a series of commits following this one
that will modify any command which uses a mouse button to use these
helpers.
2019-01-09 11:29:04 -05:00
assets Recompressed PNG files 2017-01-05 21:49:28 -05:00
client Change _XOPEN_SOURCE defines to _POSIX_C_SOURCE 2018-09-03 09:08:49 +02:00
common fixup! stringop.c: rewrite strip_whitespace 2019-01-02 18:47:22 +00:00
completions completion: use jq instead of sed for swaybar completion 2019-01-02 21:38:32 -05:00
contrib A script to make inactive windows transparent 2018-10-20 21:58:00 +03:00
include Add helpers for improved mouse button parsing 2019-01-09 11:29:04 -05:00
protocols Update for swaywm/wlroots#1243 2018-09-14 19:21:44 +02:00
security.d delete references to swaygrab 2018-07-30 16:24:46 +01:00
sway Add helpers for improved mouse button parsing 2019-01-09 11:29:04 -05:00
swaybar Simplify evdev includes on FreeBSD by relying on up-to-date package 2019-01-09 11:02:05 +00:00
swaybg Sway clients: Exit gracefully when compositor is unavailable 2018-10-15 21:57:59 +10:00
swayidle swayidle: Fix sleep inhibitor not being acquired 2019-01-07 22:55:42 +11:00
swaylock Merge pull request #3275 from ianyfan/remove-readline 2019-01-08 10:05:37 +01:00
swaymsg Remove readline.c 2019-01-01 09:01:25 +00:00
swaynag Remove readline.c 2019-01-01 09:01:25 +00: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
config.in fix typo in config.in 2018-11-19 22:32:08 +01:00
CONTRIBUTING.md Update CONTRIBUTING.md 2018-10-06 11:52:28 -04:00
ISSUE_TEMPLATE.md issue template: add instructions for stack traces 2018-12-17 18:38:15 +01:00
LICENSE MIT license 2017-01-06 13:45:48 -05:00
meson.build bash: add completion for swaybar 2018-12-31 22:35:57 -05:00
meson_options.txt swaybar: add tray interface 2018-12-31 20:40:18 +00:00
README.bg.md Update README.md 2019-01-05 15:21:11 -05:00
README.de.md Update README.md 2019-01-05 15:21:11 -05:00
README.el.md Update README.md 2019-01-05 15:21:11 -05:00
README.fr.md Update README.md 2019-01-05 15:21:11 -05:00
README.it.md Update README.md 2019-01-05 15:21:11 -05:00
README.ja.md Update README.md 2019-01-05 15:21:11 -05:00
README.md Update README.md 2019-01-05 15:21:11 -05:00
README.pt.md Update README.md 2019-01-05 15:21:11 -05:00
README.ru.md Update README.md 2019-01-05 15:21:11 -05:00
README.uk.md Update README.md 2019-01-05 15:21:11 -05:00
sway.desktop Add Wayland and Xorg session files 2015-08-20 23:12:34 +02:00

sway

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

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

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.

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
  • wayland-protocols *
  • pcre
  • json-c
  • pango
  • cairo
  • gdk-pixbuf2 **
  • pam (optional: PAM support for swaylock)
  • scdoc (optional: man pages) *
  • git *

*Compile-time dep

**optional: required for swaybg and swaylock

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