aboutsummaryrefslogtreecommitdiff
AgeCommit message (Collapse)AuthorFilesLines
2023-10-18completions/zsh: Fix incomplete input namesHugo Machet1-1/+1
Input name with ':' in it were not suggested entirely.
2023-10-18completions: Rewrite zshHugo Machet1-98/+98
- Fix some completions that never really worked correctly, e.g `riverctl input` didn't take the input name into account. Same with rule that didn't take into account glob. - Add a lot of documentation to help people adding new commands. - Add new rule-[add|del] order. - `riverctl input` now autocomplete input name from `riverctl list-inputs`
2023-10-17Cursor: use total delta for resize calculationIsaac Freund1-46/+53
This means that interactive resize speed is no longer throttled by the speed at which the client commits new buffers. Interactive resize speed is now determined entirely by how fast the pointer input device is moved by the user. This may result in more subjectively "choppy" resizes for clients that commit very slowly, but it should be less sluggish at least.
2023-10-16riverctl: rule-{add,del}: reorder parameterstiosgz4-17/+35
Previous order was (action, conditions, action argument), current is (conditions, action, action argument). The old one was an expansion of (action, conditions), which itself most likely came from the separate <action>-filter-add commands. On the other hand, the new order keeps action and its argument together and is in line with the logical flow (check conditions, apply action). On shell completions: only bash absolutely needed to be updated. fish and zsh slightly misbehave regardless of the order.
2023-10-16View: clean up after Zig updateIsaac Freund1-21/+11
2023-10-16build: update to Zig 0.11.0Isaac Freund54-359/+329
2023-09-05Cursor: keep focus_follows_cursor_target updatedtiosgz1-17/+33
This goes as close as possible to the behavior before this state was introduced (keeping the improvement which needed it, 931405ab), fixing various mis-interactions of keyboard and focus_follows_cursor focus changes. The following text is irrelevant to restoring correct basic FFC behavior and talks about less common scenarios with regards to FFC clashing with views' input region beyond their geometry, continuing the work done in 931405ab. Scenario 1: the cursor traveling along a view's border in a "dead zone", never initiating a focus change. If the focused view has an extended input region, that area has some functionality (such as client-initiated resizing); therefore it should be respected and even if another view's geometry is also under the cursor, focus shouldn't change. In case of unfocused views, it is a matter of consistency with the focused-view case. This outcome is also easier to implement, as it doesn't require any additional code. Scenario 2: *clicking* such a dead zone, i.e. extended input region (of an unfocused view). In question is not whether to focus the view (yes), but whether the focus_follows_cursor_target should be set to the view as well. Only one case seems relevant to me here, which is when ffc_target is another view whose geometry is under the cursor, but covered by this newly-focused view's input region. The most likely action following the click is resizing the newly-focused view, where a touchpad or faulty mouse could make the cursor move a bit farther after the button has been released. I believe that ffc_target shouldn't have been updated, in order to now prevent focus from skipping away. (Another variant is me, wondering why the wrong view got focused and trying to focus the right one using FFC. In that case, however, one could ask if it's river that misbehaves and whether the application is really well-integrated into the user's desktop when it provides a feature they don't desire.)
2023-08-13Root: fix inflight_layout_demands countingtiosgz1-6/+7
Not decreasing the counter caused a weird bug where disabling/removing an output (curiously, it seems to apply only to last active output being removed) would lock the user out of the session, not letting the transaction to complete (therefore hiding all views on a newly added output) and messing up focus. Fixes https://github.com/riverwm/river/issues/830
2023-08-13Root: migrate {all,active}_outputs to wl.listtiosgz8-85/+88
As discussed with ifreund on irc. This avoids extra allocation in case of all_outputs and confusion in case of active_outputs (because with the Output embedded in the Node, i thought its value was copied instead of its pointer).
2023-08-13Root: make 'fallback output empty' assertion strictertiosgz1-2/+2
2023-08-13Root: rename field outputs to active_outputstiosgz6-30/+30
Although this list only including active outputs was already documented, making this explicit in its name reduces confusion and debugging overhead.
2023-08-03river: update some commentstiosgz2-8/+9
Mostly stuff not reflecting renames, plus a few if-then comma errors i noticed.
2023-07-11river: fix spatial direction focusing / swappingLeon Henrik Plickat1-0/+1
2023-07-09river: focus-view and swap by spatial directionLeon Henrik Plickat9-172/+205
2023-07-02river: fix crash when trying to add tag rule without tag argumentLeon Henrik Plickat1-0/+1
2023-06-28river: add tags ruleLeon Henrik Plickat7-13/+54
2023-06-27river: change order of colums in list-rules commandLeon Henrik Plickat3-33/+33
This will make it easier to extend the command later for new rules
2023-06-27river: allow settings child type of RuleListLeon Henrik Plickat4-112/+127
2023-06-20river-layout: Remove incorrect assertionIsaac Freund1-1/+2
This assertion is not correct since removing transaction preemption.
2023-06-05riverctl: Add error messages for failed connectionsLeon Henrik Plickat1-2/+8
2023-06-05XdgToplevel: store scene node in wlr_surface dataIsaac Freund1-0/+1
This was accidentally removed in 05eac54b077, which broke SceneNodeData.fromSurface() for xdg_toplevels. This means that thing such as xdg-activation and idle inhibit didn't work since that commit and should work again starting from this commit.
2023-05-11XdgToplevel: keep wlroots updated on view sizesVäinö Mäkelä1-1/+6
When sending a configure, wlroots will send the same size that was sent on the previous configure unless a new size is set. If a client resizes their window itself, the size wlroots has in XdgToplevel.scheduled will be obsolete and needs to be updated by river.
2023-05-02editorconfig: fix typoSage Hane1-1/+1
2023-03-25command/send-to-output: add -current-tags flagPablo Ovelleiro Corral2-4/+18
2023-03-24Server: remove debug leftovertiosgz1-2/+0
2023-03-24session-lock: fix assertion failures and clean upIsaac Freund3-21/+21
The removed assertions aren't possible to guarantee due to the fact that the lock render state is updated asynchronously as the output is rendered.
2023-03-16LayerSurface: fix surfaces on multiple outputs at onceIsaac Freund1-5/+10
The previous commit broke handling of keyboard interactive layer surfaces being created on multiple outputs at once. This new approach reverts part of the logic change in the previous commit while keeping the fix for the crash and the new assertion.
2023-03-16LayerSurface: handle focus when switching outputsIsaac Freund2-3/+1
Currently if a layer surface is focused and the user focuses a different output the layer surface remains focused. However, updating focus on layer surface unmap only considers seats that have the layer surface's output focused. To fix this there are 3 approaches I see: 1. Unfocus all layer surfaces on the old output when switching output focus, focus any layer surfaces on the new output. 2. Disallow switching output focus while a layer surface is focused. 3. Stop caring about output focus when determining which layer surface should gain/lose focus. I've taken the 3rd option here as it is significantly simpler to implement and maintain but still feels reasonably intuitive.
2023-03-15build: work around zig 0.10.0 bug to fix CIIsaac Freund1-10/+15
2023-03-15Cursor: apply x/y change during resize on commitIsaac Freund4-68/+139
This fixes issues with resizing clients that stick to a fixed aspect ratio during resize such as mpv.
2023-03-14Cursor: lock to current geometry during move/resizeIsaac Freund2-50/+47
This eliminates cursor jitter entirely during interactive resize. This also fixes a bug where the xdg-toplevel resizing state was not cleared if a resize operation was aborted due to a change in view tags or similar.
2023-03-14XdgToplevel: ensure view dimensions match geometryIsaac Freund2-6/+26
Some clients (e.g. mpv) do not respond to configures by committing buffers of the exact size requested. Instead they may commit a buffer of a smaller size in order to maintain an aspect ratio or not commit a buffer at all.
2023-03-14Cursor: fix warp on output change with no viewsIsaac Freund1-0/+4
2023-03-14Root: separate fallback list to handle 0 outputsIsaac Freund1-10/+40
Mixing views that are currently being mapped/unmapped with views that are stashed during hotplug down to 0 outputs is error-prone and almost certainly has a bug or two hiding currently.
2023-03-14Root: remove incorrect assertions in addOutput()Isaac Freund1-2/+0
2023-03-14Output: reinitialize output_status, cleanupIsaac Freund2-7/+13
If a output is removed and added back without being destroyed this must be reinitialized. This commit also cleans up the Root.applyPending() calls related to output hotplug and adds some more logging.
2023-03-13doc: fix typo in riverctl man pageIsaac Freund1-1/+1
2023-03-12example/init: update for rules systemIsaac Freund1-5/+4
2023-03-12docs: fix typo in riverctl man pageIsaac Freund1-4/+4
2023-03-12river: add rules systemIsaac Freund17-271/+662
This is a breaking change and replaces the previous csd-filter-add/remove and float-filter-add/remove commands. See the riverctl(1) man page for documentation on the new system.
2023-03-10xdg-decoration: clean up implementationIsaac Freund11-153/+156
We now send some protocol errors that wlroots 0.16 is missing [1]. This also allows us to access the xdg decoration from a view, which will be necessary for some future changes. [1]: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4051
2023-03-10View: add `none` impl tag for better safety checksIsaac Freund3-2/+22
2023-03-10xdg-shell: determine tiled state by float stateIsaac Freund1-8/+12
How river currently sets this isn't really in accordance with the spirit of the protocol. It was originally done this way to get gtk3 windows to look a little bit better with borders drawn around them. However, I've come to believe that river shouldn't just ignore standards like this. The right way to do things would be to either implement the xdg-decoration protocol for gtk properly or to be pragmatic and accept some programs are intended to be used with CSD and that's OK.
2023-03-09example/init: Fix confusing commentsIsaac Freund1-2/+2
River does not currently recognize Ctrl as a modifier, only Control.
2023-03-09river-status: only send layout name if changedIsaac Freund1-7/+12
2023-03-08XdgToplevel: clean up wlr_surface data on destroyIsaac Freund1-0/+3
2023-03-08Xwayland: eliminate unneeded user data usageIsaac Freund2-3/+0
This is some dead code that is left over from before the scene graph changes.
2023-03-07layer-shell: apply exclusive zones in separate passIsaac Freund1-7/+23
This brings the behavior closer to what we had before the scene graph refactor. The main difference now is that the order has changed from background to overlay instead of from overlay to background. This ordering seems to make more sense in the cases I've tested and the old ordering was just cargo-cult anyways.
2023-03-06Seat: fix potential assertion failureIsaac Freund1-1/+3
2023-03-06river: improve comments on pending/inflight/currentIsaac Freund2-4/+15