Commit Graph

1275 Commits

Author SHA1 Message Date
fac47ffb5d Merge branch 'master' of https://codeberg.org/river/river 2024-06-08 16:25:41 -07:00
8da69699e9 build: update to Zig 0.13.0 2024-06-07 14:01:30 +02:00
c5b1d1de4e ci: cleanup messy tar invocations 2024-05-23 16:21:02 +02:00
4d44ca6d5d ci: Check the formatting of build.zig.zon 2024-05-20 13:13:05 +02:00
7fdba05b82 ci: drop FreeBSD CI for now
There is no FreeBSD tarball from ziglang.org and FreeBSD itself has not
yet updated their Zig package to 0.12.0. This commit should be reverted
when a good way is found to obtain Zig 0.12.0 for the FreeBSD CI.
2024-05-20 11:45:09 +02:00
958f8798b6 build: switch to the Zig package manager
No more git submodules!
2024-05-20 11:44:08 +02:00
045ee7bd25 build: add -Dno-llvm build option 2024-05-20 11:35:36 +02:00
033cad47bf build: update to Zig 0.12 2024-05-20 11:35:36 +02:00
680cb8ef69 PointerConstraint: remove overly tight assert 2
This is a second copy of the same assert that was removed in the last
commit. It should have been removed by that commit as well but was
overlooked.
2024-05-18 16:28:28 +02:00
5d1fc034bc PointerConstraint: remove overly tight assert
This assert is incorrect if Xwayland is enabled and an Override Redirect
window steals the keyboard focus from the parent surface.

It also seems likely to be hit if a Wayland client attempts to use a
pointer constraint on a subsurface. I don't think a pointer constraint
on a subsurface is likely to work entirely correctly and I don't know of
any Wayland clients that try such a thing. We can't let them crash river
by trying though.
2024-05-18 14:40:20 +02:00
c75d32c88b InputPopup: fix minor issues, simplify code 2024-05-16 11:40:41 +02:00
ed9e9c4d16 Remove assert that was causing crashes 2024-05-16 00:55:37 -07:00
930dcb7dcd Fix current view tags status 2024-05-15 19:20:48 -07:00
929db0098a Merge branch 'master' of https://codeberg.org/river/river 2024-05-15 04:36:26 -07:00
b35a40b9df TextInput: ignore enable requests without focus 2024-05-15 12:21:22 +02:00
ba6023e38a InputPopup: fix naming 2024-05-15 11:50:58 +02:00
74baf7225a input-method-v2: Implement popups 2024-05-15 11:23:41 +02:00
b5a80c7b9b Server: fix filtering of newly created globals
Fixes: https://codeberg.org/river/river/issues/1068
2024-05-15 09:48:55 +02:00
bed50f0dd2 command/swap: fix cursor warp on focus change 2024-05-14 23:37:10 +02:00
ad0b71c310 github: automatically close prs 2024-05-14 13:02:29 +02:00
1e3ef88bd5 Keyboard: fix redundant leave/enter on creation
Currently if a second keyboard input device is created river will send
a wl_keyboard.leave event immediately followed by a wl_keyboard.enter
event. This serves no purpose and can confuse clients, in particular due
to fctix creating/destroying virtual keyboards on focus change.

Fixes: https://codeberg.org/river/river/issues/1062
References: https://github.com/fcitx/fcitx5/issues/1044
2024-05-12 16:16:04 +02:00
f66eec9248 Cursor: don't hide while pointer constraint active
Fixes: https://codeberg.org/river/river/issues/1053
2024-05-12 10:42:19 +02:00
16d76ae86c Add tags field to focused_view event 2024-05-03 03:02:41 -07:00
e29d66f1de Xwayland: disallow negative output coordinates
Xwayland clients on outputs at negative positions don't currently
receive mouse events due to a bug in Xwayland. As a workaround, we
disallow negative output positions when Xwayland is enabled.

References: https://gitlab.freedesktop.org/xorg/xserver/-/issues/899
Closes: 
2024-05-02 14:08:34 +02:00
5262a4c5a6 input: change ScrollFactor and MapToOutput to align with other options 2024-04-24 23:59:54 +10:00
bd5da261eb input: fix scroll-factor resetting if unspecified 2024-04-23 23:28:42 +10:00
5fbf174c36 input: prevent duplicate input configs 2024-04-23 22:38:18 +10:00
9bbd34a0e3 XdgToplevel: update clip on geometry x/y change
Currently if a client commits a geometry with a different x/y value but
does not change the width/height we might not update the clip
coordinates of the surface tree, potentially causing part of the surface
to be unintentionally clipped off.

To fix this, check for change in geometry x/y as well as width/height on
commit if the client is not currently part of an ongoing transaction.

Firefox for example it seems may respond to a configure non-atomically
with multiple commits:

1. commit new buffer and new geometry of a new width/height.
2. commit again with the same width/height but a new geometry x/y.

I don't think this is technically a bug but it doesn't seem like the
most efficient way to do things. I think this may also cause imperfect
frames. In any case, this should no longer cause river to crop off part
of firefox's surface.
2024-04-19 13:46:08 +02:00
d1dc873408 XdgToplevel: don't update geometry if configure inflight 2024-04-18 10:48:59 +02:00
6b86af4f85 build: bump version to 0.4.0-dev 2024-04-17 14:39:55 +02:00
d3178ae13f build: bump version to 0.3.0 2024-04-16 14:03:17 +02:00
f9e52f32bf docs: remove website url at top of readme
Codeberg lets me put this by the repository description.
2024-04-16 13:51:46 +02:00
6bae8efe01 docs: freshen up readme with text from website 2024-04-16 13:48:39 +02:00
df5cb5dfe8 input: minor fixes and cleanups for scroll-factor 2024-04-16 13:26:01 +02:00
8a3018a311 input: add scroll-factor configuration 2024-04-16 13:25:40 +02:00
4a019142be layer-surface: close if exclusive zones too large
It seems layer-shell clients such as waybar can commit bogus exclusive
zones larger than the width/height of the output. While this client
behavior is questionable at best, it must not cause river to crash or
otherwise misbehave.

Therefore, close layer surfaces causing the usable (not exclusive zone)
area of an output to be reduced below half of the width/height.
2024-04-16 12:18:39 +02:00
70ad2af8f4 docs: update URL in man pages
Also remove the redundant URL in the footer and the redundant
"General Commands Manual" text (scdoc adds that by default based on the
section it seems).
2024-04-15 11:23:05 +02:00
14e941bae1 docs: redefine Code of Conduct scope 2024-04-09 14:18:47 +02:00
86d142aa47 logo: make readme logo bigger on small displays
The correct way to do this would be to use the max-width css attribute,
but codeberg seems to strip that when converting markdown to html.

The new value of 600em looks almost identical to 50% on large screens
and looks a lot better on small (mobile) screens.
2024-04-09 10:41:34 +02:00
7974bfdb7d docs: fix another broken link in the coc
The markdown generation of the upstream Contributor Covenant page seems
to have some issues.
2024-04-09 09:43:02 +02:00
9a04462cdf docs: fix broken link in coc 2024-04-09 09:41:38 +02:00
06c13197bb docs: add Code of Conduct 2024-04-09 08:57:17 +02:00
3e306ecfbf river: raise the file descriptor limit 2024-04-08 16:24:51 +02:00
94828474b0 View: add more assertions around destruction
This should make leaks like the one fixed by the previous commit harder
to write.
2024-04-08 15:19:12 +02:00
a374c6ab84 Root: fix leak on view destroy
This leaks memory and possibly an fd currently whenever a view is
destroyed.
2024-04-08 15:02:55 +02:00
b0e54c6396 Output: fix possible assertion failure on enable
Currently if we disable an output due to a wlr-output-power-management
protocol request we do not update Output.lock_render_state properly.

This is fine if the output is also re-enabled using the
wlr-output-power-management protocol but causes an assertion failure
if it is re-enabled using wlr-output-management instead.
2024-04-08 13:34:47 +02:00
3594fe501e View: fix assertion failure if focused while destroying
Also clean up this code a bit, it's no longer necessary to split these
one line functions out into separate files as Zig's conditional
compilation support has improved since these functions were originally
written.
2024-04-08 12:54:05 +02:00
93f9eb8e5e logo: use adaptive color/no background for readme
This looks nicer with dark themes. Light themes should be effectively
unchanged.
2024-04-08 12:28:46 +02:00
36d8e90a54 View: always check if current.output is null
This field being nullable at all is code smell. I think what needs to
happen here long term is for a proper separation of "window management
output" and "physical output" as concepts and integration outputs into
the transaction system.

That's a much larger change and I don't want to cause that amount of
code churn just before a release though.
2024-04-03 17:18:54 +02:00
8b8ac27c45 ci: migrate to codeberg 2024-04-01 22:28:23 +02:00