Humm
ebfefa84ba
-s: close unused fds
...
dup2 doesn’t close fds, it only duplicates them. The old ones weren’t
closed, causing problems (like dwl blocking due to the child process
never reading from the reading end, even if stdin has been closed).
2021-10-13 23:11:40 +02:00
Leonardo Hernandez Hernandez
2c9423d1b7
wlr_xdg_surface.configure_serial
has been moved into wlr_xdg_surface_state
...
as seen in swaywm/wlroots@0e34208
2021-10-03 22:08:00 -05:00
Leonardo Hernandez Hernandez
df332de9d2
send frame_done also to all layer surfaces
...
this fixes an issue when bemenu don't update his surface when typing
2021-10-02 22:24:04 -05:00
ARDiDo
99fbebcae3
Remove redundant xcursor manager
2021-09-26 20:19:36 -04:00
Leonardo Hernandez Hernandez
1e1482adcb
client_pending has been renamed as pending in wlr_layer_surface_v1
...
as seen in swaywm/wlroots@59fa363
2021-09-24 16:12:12 -05:00
Devin J. Pohly
7de6920bd7
send frame_done to all visible surfaces
2021-09-21 14:42:36 -05:00
Devin J. Pohly
c8bf457c0f
fixup: follow name change on surface_tree_create
2021-09-21 10:42:43 -05:00
Devin J. Pohly
0146a9954b
use scene_output for damage-tracked rendering
2021-09-08 23:24:11 -05:00
Devin J. Pohly
be6f573b4e
use scene to keep track of LayerSurfaces' layers
2021-09-08 23:24:11 -05:00
Devin J. Pohly
1b38801eef
use scene-graph API for Client/LayerSurface
2021-09-08 23:24:11 -05:00
Devin J. Pohly
929d3d9569
use type enum to distinguish Client from LayerSurface
2021-09-08 23:24:11 -05:00
Devin J. Pohly
40e45a336a
Merge branch 'main' into wlroots-next
2021-09-08 23:21:51 -05:00
Devin J. Pohly
0c1e621b82
simplify fullscreen expression
2021-09-08 23:21:28 -05:00
Tobias Bengfort
79dcc0d327
reset cursor mode when grabc is unmapped
2021-09-04 13:47:49 +02:00
Devin J. Pohly
55bbbc3dcb
Merge branch 'main' into wlroots-next
2021-08-23 21:08:27 -05:00
Devin J. Pohly
d4e08c0762
update deprecated xkb function name
2021-08-23 18:59:31 -05:00
Palanix
3273f749ea
wlr_layer_surface_v1_close has been replaced by wlr_layer_surface_v1_destroy
2021-08-21 01:53:38 +02:00
Devin J. Pohly
1183a319a0
Merge pull request #136 from guidocella/presentation-time
...
implement the presentation time protocol
2021-08-14 07:53:26 -04:00
Guido Cella
d175a58d73
implement the presentation time protocol
...
This lets applications, such as mpv with --video-sync=display-resample,
know accurately when frames are displayed and ensure smooth video
playback.
2021-08-02 16:33:38 +02:00
David Donahue
52e6bf4735
Moved printstatus() call in focusclient() to prevent printstatus being called on every frame when things like dmenu are up
2021-07-01 15:20:30 -05:00
Devin J. Pohly
f9f3f3432b
Merge branch 'xdg-activation' into wlroots-next
2021-06-30 14:09:02 -05:00
Devin J. Pohly
d4ce92a7b5
Merge branch 'xdg-activation' into wlroots-next
2021-06-03 01:44:36 -05:00
Devin J. Pohly
bd2f7fbb40
exit cleanly on INT/TERM
2021-05-26 23:30:49 -05:00
Devin J. Pohly
823cefd292
handle ephemeral pageflip failures
...
If a transient failure occurs in wlr_output_commit, re-render until it
doesn't happen. This could possibly be removed if we decide to
implement damage tracking in the future.
2021-05-25 02:52:33 -05:00
Devin J. Pohly
60c40c0989
print status on output create
...
Along with starting the -s command earlier, this will allow the initial
monitor setup to generate printstatus info.
2021-05-24 22:31:36 -05:00
Devin J. Pohly
06ca860092
factor xwayland hackiness out into client.h
2021-05-23 18:28:13 -05:00
Sevz17
9ab5e01d5b
before set tiled verify if client is xdg-shell, then set tile
2021-05-23 11:44:56 -05:00
Devin J. Pohly
d8cf65c74f
implement urgency hint
2021-05-22 21:21:53 -05:00
Devin J. Pohly
93a58abf29
Wait until map to set window's tiled state
...
Workaround for a bug in Chromium where it fails to attach a buffer to
the surface. Fixes #119 .
2021-05-22 14:24:18 -05:00
Devin J. Pohly
3f86336bad
Merge branch 'main' into pipe-status
2021-04-15 13:06:06 -05:00
Devin J. Pohly
3727f4a7b3
update status info if focused client changes title
...
Fixes #108 .
2021-04-15 13:05:05 -05:00
Devin J. Pohly
b372d4b55e
pipe status info into -s command
...
Unlike with X window managers, the display socket in Wayland isn't set
up prior to starting the compositor. Because of this, you can't pipe
the compositor's output directly into a program which needs access to
$WAYLAND_DISPLAY, which is a typical setup for this purpose. Existing
scripts have been forced to create a pipe/FIFO or a temporary file as an
intermediary.
Instead, send the status info directly to stdin of the -s command, which
*does* have access to $WAYLAND_DISPLAY.
Fixes #103 .
2021-04-14 11:23:23 -05:00
Devin J. Pohly
9071ce6c84
nuke CSDs, hopefully for good!
2021-04-09 12:37:49 -05:00
Devin J. Pohly
2a9404ac2a
Merge branch 'main' into wlroots-next
2021-03-30 13:57:34 -05:00
Devin J. Pohly
3c83e0cfb8
don't move/resize if already moving/resizing
...
Fixes #102 . The "ideal" behavior might be to ignore buttons other than
the one being used for the action, but this is super-simple and still
seems reasonable.
2021-03-30 13:56:04 -05:00
Devin J. Pohly
cd3d0a102f
Merge branch 'main' into wlroots-next
2021-03-25 10:09:58 -05:00
Stivvo
38ba6d2277
Fullscreen: simplifications and fixes
...
Merges #69 .
2021-03-25 10:05:12 -05:00
Devin J. Pohly
c2b53c2d8d
Merge pull request #91 from drdonahue/wip-tag-status-interface
...
Interface to display tag information on status bar
2021-03-25 09:58:17 -05:00
David Donahue
ecc60878b3
changed fprintf(stdout) instances to printf(), changed function name from statusbar to printstatus
2021-03-13 11:20:33 -06:00
Devin J. Pohly
43b6e804cf
Revert "remove sigchld function"
...
This reverts commit 1fa72b0772
.
Fixes #97 .
2021-03-13 10:42:42 -06:00
Devin J. Pohly
fba820d5f6
Merge branch 'main' into wlroots-next
2021-03-10 09:53:09 -06:00
Devin J. Pohly
1fa72b0772
remove sigchld function
...
Explicitly setting the handler for SIGCHLD to SIG_IGN tells the OS to
reap zombie processes automatically, which is what we wanted anyway.
2021-03-10 09:50:09 -06:00
David Donahue
7cee5060bc
added redirect from stdout to stderr for spawned processes to prevent conflicts with the statusbar outputs
2021-03-06 12:20:56 -06:00
David Donahue
5b51bb82e2
Fixed tab formatting in 6 locations where statusbar() is called
2021-03-01 14:38:00 -06:00
David Donahue
f5e7caac00
Changed output to stdout instead of a file
2021-03-01 13:49:29 -06:00
David Donahue
593b7eec3c
updated output format for better expansibility and easier parsing
2021-03-01 13:19:25 -06:00
Devin J. Pohly
c1eb2b49cd
Revert "Revert "remove EGL parameter from backend_autocreate""
...
This reverts commit 8ed88822ca
.
2021-02-16 13:13:49 -06:00
Devin J. Pohly
e8192b4fc9
Revert "Revert "fix undeclared WLR_KEY_PRESSED""
...
This reverts commit a11f2bbc7a
.
2021-02-16 13:13:48 -06:00
Devin J. Pohly
a11f2bbc7a
Revert "fix undeclared WLR_KEY_PRESSED"
...
This reverts commit 67896e9d8b
.
2021-02-16 13:09:00 -06:00
Devin J. Pohly
8ed88822ca
Revert "remove EGL parameter from backend_autocreate"
...
This reverts commit 0ff13cf216
.
2021-02-16 13:08:58 -06:00
Devin J. Pohly
3e82fad9c4
fix style on space-indented function
2021-02-14 12:43:10 -06:00
David Donahue
a1e24075d8
Removed unused variable from statusbar
2021-02-08 18:12:24 -06:00
David Donahue
27598bd04a
added statusbar update when tags are updated
2021-02-07 01:03:04 -06:00
David Donahue
3868217466
Added interface to output information about tags, the currently selected monitor, and the focused client to a file for use by a status bar
2021-02-07 00:31:01 -06:00
Devin J. Pohly
9c1943ade5
add some explanation of output reconfiguration
...
Hopefully this will help "future us" understand what's going on.
2021-01-18 15:51:32 -06:00
Devin J. Pohly
a9e1cd4201
remove hacky code from output-management handler
...
This functionality belongs in updatemons(), where it can hopefully be
written a bit more elegantly.
2021-01-18 15:38:25 -06:00
Devin J. Pohly
ab03282295
commit entire output config, or fail and rollback
...
The wlr-output-management protocol requires that either all of the
changes from an apply request be applied successfully, in which case a
"succeeded" event is sent, or all of the changes are reverted and a
"failed" event is sent. As written, this could partially commit
changes, then fail.
Test the changes first (even for an "apply" event), then commit or
rollback as appropriate.
2021-01-18 15:02:15 -06:00
Devin J. Pohly
5eefb51fea
use updatemons as handler for output_layout.change
...
This should end up firing precisely when we need to adjust our geometry,
rather than us guessing about it based on requests.
2021-01-18 14:34:05 -06:00
Devin J. Pohly
c63d4c41ab
unify increment style while we're here
2021-01-18 14:14:37 -06:00
Devin J. Pohly
81d35aaccf
remove unnecessary variable
2021-01-18 14:12:38 -06:00
Devin J. Pohly
a5210f7d77
cleanup on aisle createmon()
2021-01-18 14:12:00 -06:00
Devin J. Pohly
264be4ebba
Merge pull request #80 from sam-barr/dwl_upstream
...
Fix Initialization of NetWM Atoms
2021-01-14 20:29:17 -06:00
sam-barr
3d696dfb7d
Fix Initialization of NetWM Atoms
...
Additionally, variables xcursor and xcursor_mgr are only used
when xwayland is defined, so I make the variables declaration
contingent on whether xwayland is being used
2021-01-11 07:47:04 -05:00
Devin J. Pohly
6267593cc2
remove now-unneeded monitor position field
2021-01-06 17:23:35 -05:00
Devin J. Pohly
e8ca8a8ac7
use output layout for dirtomon
...
No need to track our own order; wlroots has a reasonable default for us
already.
2021-01-06 17:19:44 -05:00
Devin J. Pohly
4bf2923f4e
Merge pull request #72 from Stivvo/output-compile-set
...
Define monitor's x,y at compile time
2021-01-06 16:44:31 -05:00
Devin J. Pohly
0ff13cf216
remove EGL parameter from backend_autocreate
...
Tracking with breaking change in swaywm/wlroots#2593 .
2021-01-04 13:55:24 -05:00
Stivvo
fa782896f8
Define monitor's x,y at compile time
...
Replaces the outputOrder patch.
This avoids recalculating positions and allows to arrange monitors in
any order, not just from left to right.
The order in which monitors are defined in config.h still matters but
it's just the order in the list, not the actual position.
2020-12-30 17:07:48 +01:00
Devin J. Pohly
33c36be2fc
Revert "Allow toggling the layout before selecting a different one"
...
This reverts commit 90cc3b1e2c
. Didn't
mean to merge this change.
2020-12-28 15:51:04 -05:00
Devin J. Pohly
313d1f7ecc
flesh out cleanup
...
This is the order of *_destroy calls which resulted in the fewest
errors/leaks detected by Valgrind. Most of the errors come from the
gbm_allocator code - will have to figure out which destroy call is still
missing.
2020-12-27 20:04:05 -05:00
Devin J. Pohly
7b1b5c75e9
fix segfault in xwayland cursor manager
2020-12-27 14:00:07 -05:00
Devin J. Pohly
7b320a195c
macroize event handlers
...
This was a prime candidate for reducing the verbosity of some of our
code
2020-12-27 13:28:37 -05:00
Devin J. Pohly
ef76c921ed
no need to cast NULL to void *
2020-12-25 01:41:09 -05:00
Devin J. Pohly
388c5580cb
consolidate some of the ugliness into a separate file
...
Similar to Linux kernel approach, encapsulate some of the uglier
conditional compilation into inline functions in header files.
The goal is to make dwl.c more attractive to people who embrace the
suckless philosophy - simple, short, hackable, and easy to understand.
We want dwm users to feel comfortable here, not scare them off. Plus,
if we do this right, the main dwl.c code should require only minimal
changes once XWayland is no longer a necessary evil.
According to `cloc`, this also brings dwl.c down below 2000 lines of
non-blank, non-comment code.
2020-12-25 01:39:07 -05:00
Devin J. Pohly
efe2a97bcf
fix build with -DXWAYLAND
2020-12-24 22:39:45 -05:00
Devin J. Pohly
1678b05905
don't call applyexclusive just to return
2020-12-24 22:36:32 -05:00
Devin J. Pohly
57d0760635
let's not alienate the dwm folks
...
Fix style.
2020-12-24 22:21:00 -05:00
Devin J. Pohly
206427537a
Merge updates from guidocella
...
Thanks so much for helping to keep the project running while life was
crazy!
2020-12-24 21:56:41 -05:00
Devin J. Pohly
cfe7815903
Merge pull request #32 from alex-courtis/24-xwayland-cursor
...
#24 ensure that xwayland cursor defaults to left_ptr
2020-12-24 21:37:48 -05:00
Devin J. Pohly
7803022d33
simplify ROUND macro
2020-12-24 21:37:21 -05:00
Devin J. Pohly
128c2926e1
Merge pull request #54 from Bonicgamer/swayscalebox
...
Sway scale_box (rounding)
2020-12-24 21:36:38 -05:00
Devin J. Pohly
c5087d413f
Merge pull request #53 from Stivvo/fullscreen
...
Fullscreen support
2020-12-24 21:35:57 -05:00
Devin J. Pohly
d94266df91
fix crash on non-libinput pointers (e.g. X11 backend)
2020-12-24 21:15:40 -05:00
Devin J. Pohly
62529e251d
Merge pull request #49 from guidocella/layer-shell
...
Layer shell
2020-12-24 20:24:14 -05:00
Devin J. Pohly
b6a3891ce6
Merge pull request #62 from Java-boi/master
...
Added basic tap-to-click for touchpad users
2020-12-24 18:55:06 -05:00
Stivvo
d21d5ee262
Change fullscreen policies
...
When a new client is spawned, fullscreen isn't disabled for all clients
in that monitor any more.
Instead, all fullscreen clients are kept fullscreen, while other clients
spawn in the background.
When fullscreen is disabled, all clients are rearranged.
This is made to make dwl more flexible allowing multiple fullscreen
clients at the same time, have floating clients on top of a fullscreen
one and let stuff happen without quitting fullscreen, like many other
WMs and DEs.
2020-12-24 21:05:34 +01:00
Stivvo
707c1710b7
quitallfullscreen() even when enabling fullscreen
...
Disable fullscreen on all visible clients in that monitor also before
enabling it on another client.
quitallfullscreen() is reintroduced becouse is now more useful
set c->isfullscreen later to avoid making quitallfullscreen() disable
fullscreen on the current client
2020-12-24 12:29:44 +01:00
Stivvo
86ba4c8526
Remove goto render (easier merge)
2020-12-24 00:34:33 +01:00
Guido Cella
33e8a3f1f3
update comments and remove debugging printf
2020-12-21 11:22:04 +01:00
Stivvo
5668c61616
Define monitor order with monrules[]
...
The order in which monitors are defined in monrules[] actually matters.
Monotors that aren't configured in monrules[], it will always be the
leftmost.
2020-12-21 11:12:44 +01:00
Guido Cella
cf7c5eae21
don't reset the cursor image
...
...in internal calls to restore pointer focus. Necessary for the
unclutter patch, and there's no harm in avoiding this call even in
mainline; might prevents issues in same edge cases.
2020-12-21 10:28:09 +01:00
Guido Cella
499cb2c2b6
say TODO
...
just wtf is XXX supposed to be? It sounds like a pornographic thing.
2020-12-20 18:19:49 +01:00
Guido Cella
5ed227384b
rename drw
...
It's impossible to understand that this stands from drawable if you're
not familiar with dwm's code.
2020-12-20 18:19:43 +01:00
Guido Cella
b161b5d8f4
don't notify of activity
...
...or update selmon when we just want to restore pointer focus.
2020-12-20 16:04:13 +01:00
Guido Cella
13c7e039bb
deactivate the focused client on overlay focus
2020-12-20 15:55:52 +01:00
Guido Cella
a571ea465c
replace shouldfocusclients with checking old
...
And don't activate clients while an overlay is focused.
2020-12-20 15:46:31 +01:00
Guido Cella
39946e07f2
fix keyboard focus with overlays
...
Don't let internal calls to motionnotify(0) meant to update the pointer
focus from maplayersurfacenotify and destroylayersurfacenotify also
shift the keyboard focus to the surface under the cursor with
sloppyfocus.
2020-12-20 15:46:31 +01:00
Guido Cella
f80f08848b
ensure that xwayland cursor defaults to left_ptr
...
Don't show an X cursor when closing an Xwayland window or with certain
dropdowns.
Based on https://github.com/djpohly/dwl/pull/32
2020-12-20 14:57:41 +01:00
Guido Cella
444a5f9dec
enable adaptive sync
...
The comment in this function's declaration says the backend is free to
ignore this setting, so maybe there's no need to make it configurable?
2020-12-20 14:57:41 +01:00
Guido Cella
6b47e2bb62
use bool
...
Because it's 2020. Passing integers to wlroots variables and functions
with bool in their signature is silly.
2020-12-20 14:57:39 +01:00