summaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAge
* Add xkb_numlock/xkb_capslock commands (#2311)Libravatar ProgAndy2018-07-25
|
* Implement setting NumLock and CapsLock statusLibravatar ProgAndy2018-07-25
| | | | | | After setting the keymap, try to enable NumLock and disable CapsLock. This only works if sway has the xkb master state and controls the keyboard. Prepare configuration settings for later use as well.
* Merge pull request #2358 from CedricCabessa/fix-2355-move-workspace-crashesLibravatar emersion2018-07-25
|\ | | | | fix #2355: "move workspace to output up" crashes
| * fix #2355: "move workspace to output up" crashesLibravatar Cédric Cabessa2018-07-25
|/ | | | | | | | | when using 2 display, if scaling is different `container_update_textures_recursive` is called when moving workspace on different display. We need to call `container_update_title_textures` only for container of type "CONTAINER" or "VIEW" in order to be consistent with the assert in `update_title_texture`.
* Merge pull request #2353 from emersion/render-opaque-overlayLibravatar Drew DeVault2018-07-25
|\ | | | | Improve rendering with a fullscreen opaque overlay surface
| * Improve rendering with a fullscreen opaque overlay surfaceLibravatar emersion2018-07-25
| | | | | | | | | | | | | | | | | | | | | | | | The rendering code doesn't use the exclusive input surface at all anymore to decide to skip rendering of shell surfaces. This fixes a weird situation in which a client requests exclusive input but isn't an overlay layer surface. The renderer also renders all overlay surfaces in this situation, not just one. This simplifies the code and fixes rendering when there are more than one overlay surfaces (e.g. for a virtual keyboard to type the lockscreen password).
* | Merge pull request #2350 from ppascher/xwayland-optionalLibravatar Drew DeVault2018-07-25
|\ \ | | | | | | Added meson option to allow building sway without xwayland support
| * | more style fixes, reorder config.h includeLibravatar Pascal Pascher2018-07-25
| | |
| * | reverted includes of "sway/config.h" and replaced with "config.h" from meson ↵Libravatar Pascal Pascher2018-07-25
| | | | | | | | | | | | build
| * | more style fixes, included "sway/config.h" where neededLibravatar Pascal Pascher2018-07-25
| | |
| * | style fixes, exclude sway/desctop/xwayland.c when enable_xwayland: falseLibravatar Pascal Pascher2018-07-24
| | |
| * | Added meson option "enable_xwayland" (default: true) to enable/disable ↵Libravatar Pascal Pascher2018-07-24
| | | | | | | | | | | | xwayland support
* | | Merge pull request #2354 from RyanDwyer/fix-crash-on-tab-reapLibravatar emersion2018-07-25
|\ \ \ | | | | | | | | Fix crash when closing last child of a tabbed container
| * | | Fix crash when closing last child of a tabbed containerLibravatar Ryan Dwyer2018-07-25
|/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The crash only occurs if the mouse cursor is above the tabbed container when the last child is closed. Introduced in 03d49490ccff3c5c81bea73622c8616fa61eb3dd, over a week ago and unnoticed until now :O The above commit changes the behaviour of a focus change. When you change focus, it sends pointer motion which makes the client set a new cursor image. We already had this behaviour for workspace switching, but this commit adds it for view switching too, such as in a tabbed container or when closing a view. The sequence of events that leads to the crash is: * The last child of a tabbed container unmaps, which triggers a `destroy` event before we've cleaned up the child or reaped the tabbed container. * The seat code listens to the `destroy` event and removes the seat container from the focus stack. As part of this, it decides to set focus to the parent (my fix alters this decision). * When setting focus to the new parent, the container motion is sent as per the previously mentioned commit. * The motion code uses `container_at`, which encounters the tabbed container and its child in a half destroyed state, and everything blows up from there. `con->parent` is needed because scratchpad containers don't have parents if they're hidden, so this probably fixes a crash when a hidden scratchpad container closes too. The `con->parent->children->length > 1` check should catch any cases where the parent is about to be reaped.
* | | Merge pull request #2352 from RedSoxFan/implement-2335Libravatar emersion2018-07-25
|\ \ \ | |/ / |/| | Implement floating_modifier <mod> [inverse|normal]
| * | Change button var passed to seat_begin_moveLibravatar Brian Ashworth2018-07-24
| | |
| * | Implement floating_modifier <mod> [inverse|normal]Libravatar Brian Ashworth2018-07-24
|/ /
* | Merge pull request #2165 from swaywm/pid-workspacesLibravatar Drew DeVault2018-07-24
|\ \ | | | | | | Implement pid->workspace tracking
| * | Address @emersion's review commentsLibravatar Drew DeVault2018-07-24
| | |
| * | Merge branch 'master' into pid-workspacesLibravatar Drew DeVault2018-07-23
| |\|
| * | Implement pid->workspace trackingLibravatar Drew DeVault2018-07-01
| | | | | | | | | | | | | | | | | | | | | | | | | | | When you spawn a process with the exec command, sway now notes the workspace you had focused and the pid of the child process, then assigns that workspace to the child when its window appears. Some of this is carried over from sway 0.15, but with some major refactoring and centralization of state.
* | | Merge pull request #2346 from RyanDwyer/fix-crash-on-clickLibravatar Drew DeVault2018-07-24
|\ \ \ | | | | | | | | Fix crash when clicking certain surfaces
| * | | Fix crash when clicking certain surfacesLibravatar Ryan Dwyer2018-07-24
|/ / / | | | | | | | | | cont was NULL.
* | | Merge pull request #2344 from RyanDwyer/mod-resize-any-directionLibravatar emersion2018-07-24
|\ \ \ | | | | | | | | Make mod+resize work in any direction
| * | | Make mod+resize work in any directionLibravatar Ryan Dwyer2018-07-24
|/ / / | | | | | | | | | | | | | | | | | | This makes it so if you hold mod and right click on a surface to resize it, the resize direction is chosen based on which quarter of the surface you've clicked. The previous implementation only resized towards the bottom right.
* | | Merge pull request #2303 from frsfnrrg/mouse-bindingsLibravatar Ryan Dwyer2018-07-24
|\ \ \ | | | | | | | | Implement mouse bindings
| * \ \ Merge branch 'master' into mouse-bindingsLibravatar Ryan Dwyer2018-07-24
| |\ \ \ | |/ / / |/| | |
* | | | Merge pull request #2284 from frsfnrrg/resolve-workspace-name-todoLibravatar Brian Ashworth2018-07-23
|\ \ \ \ | | | | | | | | | | Also extract first workspace name from bindcodes
| * | | | Also extract first workspace name from bindcodesLibravatar frsfnrrg2018-07-23
|/ / / /
* | | | Merge pull request #2340 from RedSoxFan/parse_booleanLibravatar Drew DeVault2018-07-23
|\ \ \ \ | |_|_|/ |/| | | Switch to using a function to parse booleans
| * | | Address review comments on parse_booleanLibravatar Brian Ashworth2018-07-23
| | | |
| * | | Remove unneeded constLibravatar Brian Ashworth2018-07-23
| | | |
| * | | Switch to using a function to parse booleansLibravatar Brian Ashworth2018-07-23
|/ / /
| * | Invoke mouse bindingsLibravatar frsfnrrg2018-07-23
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The mouse binding logic is inspired/copied from the keyboard binding logic; we store a sorted list of the currently pressed buttons, and trigger a binding when the currently pressed (or just recently pressed, in the case of a release binding) buttons, as well as modifiers/container region, match those of a given binding. As the code to execute a binding is not very keyboard specific, keyboard_execute_command is renamed to seat_execute_command and moved to where the other binding handling functions are. The call to transaction_commit_dirty has been lifted out.
| * | Parse mouse binding optionsLibravatar frsfnrrg2018-07-23
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | First, the existing sway_binding structure is given an enumerated type code. As all flags to bindsym/bindcode are boolean, a single uint32 is used to hold all flags. The _BORDER, _CONTENTS, _TITLEBAR flags, when active, indicate in which part of a container the binding can trigger; to localize complexity, they do not overlap with the command line arguments, which center around _TITLEBAR being set by default. The keyboard handling code is adjusted for this change, as is binding_key_compare; note that BINDING_LOCKED is *not* part of the key portion of the binding. Next, list of mouse bindings is introduced and cleaned up. Finally, the binding command parsing code is extended to handle the case where bindsym is used to describe a mouse binding rather than a keysym binding; the difference between the two may be detected as late as when the first key/button is parsed, or as early as the first flag. As bindings can have multiple keycodes/keysyms/buttons, mixed keysym/button sequences are prohibited.
* | Merge pull request #2342 from RyanDwyer/update-cursorLibravatar emersion2018-07-24
|\ \ | | | | | | Fix some cases where the cursor doesn't update
| * | Fix some cases where the cursor doesn't updateLibravatar Ryan Dwyer2018-07-24
|/ / | | | | | | | | | | | | cursor_set_image only uploads the named image if it doesn't match the previous named image. This means when setting the cursor image to a surface as given by a client, we have to clear the currently stored image.
* | Merge pull request #2341 from RedSoxFan/fix-2339Libravatar Drew DeVault2018-07-23
|\ \ | | | | | | Add missing checks to fix 2339
| * | Add missing checks to fix 2339Libravatar Brian Ashworth2018-07-23
|/ /
* | Merge pull request #2338 from somdoron/masterLibravatar emersion2018-07-23
|\ \ | | | | | | fix crash on new output while swaylock is running
| * | fix crash on new output while swaylock is runningLibravatar somdoron2018-07-23
|/ /
* | Merge pull request #2323 from RyanDwyer/scratchpadLibravatar Drew DeVault2018-07-23
|\ \ | | | | | | Implement scratchpad
| * | Store scratchpad list in sway_root instead of serverLibravatar Ryan Dwyer2018-07-23
| | |
| * | Implement scratchpadLibravatar Ryan Dwyer2018-07-23
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | Implements the following commands: * move scratchpad * scratchpad show * [criteria] scratchpad show Also fixes these: * Fix memory leak when executing command with criteria (use `list_free(views)` instead of `free(views)`) * Fix crash when running `move to` with no further arguments
* | Merge pull request #2328 from emersion/xdg-shell-set-titleLibravatar Ryan Dwyer2018-07-23
|\ \ | | | | | | Handle set_{title,app_id} for xdg-shell and zxdg-shell-v6
| * | Handle set_{title,app_id} for xdg-shell and zxdg-shell-v6Libravatar emersion2018-07-22
|/ / | | | | | | | | | | This allows to update the title even if the view doesn't commit. This is useful e.g. when a terminal sets its toplevel title to the currently running command and when the view isn't visible.
* | Merge pull request #2296 from RyanDwyer/floating-modifierLibravatar emersion2018-07-22
|\ \ | | | | | | Implement floating_modifier and mouse operations for floating views
| * | Set cursor when beginning resize and move operationsLibravatar Ryan Dwyer2018-07-22
| | |
| * | Fix damage when shrinking a floating view using cursorLibravatar Ryan Dwyer2018-07-22
| | |
| * | Implement request_move and request_resize for xwayland viewsLibravatar Ryan Dwyer2018-07-22
| | | | | | | | | | | | | | | I discovered we have to send a click event when ending the move or resize operation to make xwayland's requests work correctly.