| Age | Commit message (Collapse) | Author | 
|---|
|  | When an xwayland view is mapped, the IPC urgent event was being sent on
every surface commit.
I had intentionally ommitted the check because I figured an urgent
surface could update its urgent timestamp by sending urgent a second
time. But that's not how it works in xwayland's case, and it makes for
more complicated code. | 
|  | Implement urgency base functionality | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Introduces a command to manually set urgency, as well as rendering of
urgent views, sending the IPC event, removing urgency after focused for
one second, and matching urgent views via criteria. | 
|  | This PR changes the way we handle transactions to a more simple method.
The new method is to mark containers as dirty from low level code
(eg. arranging, or container_destroy, and eventually seat_set_focus),
then call transaction_commit_dirty which picks up those containers and
runs them through a transaction. The old methods of using transactions
(arrange_and_commit, or creating one manually) are now no longer
possible.
The highest-level code (execute_command and view implementation
handlers) will call transaction_commit_dirty, so most other code just
needs to set containers as dirty. This is done by arranging, but can
also be done by calling container_set_dirty. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Implement some floating move commands | 
|  |  | 
|  | This implements the following for floating containers:
* move <direction> <amount>
* move [absolute] position <x> <y>
* move [absolute] position mouse | 
|  |  | 
|  |  | 
|  |  | 
|  | The title and marks textures would have their height set from the
config's computed max font height, but the textures were not regenerated
when the config's max font height changed which made a gap appear.
Rather than making it regenerate the title textures every time the
config font height was changed, I've changed it to just make the
textures the height of the title itself and fill any gap when rendering.
Also, the title_width and marks_width variables have been renamed to
make it more obvious that they are in output-buffer-local coordinates.
Fixes #1936. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Fixes #2209. | 
|  |  | 
|  | Otherwise it repeatedly sets the view's border to the config's default. | 
|  | The check didn't include && ws_num < 100 so l would always be 1 or 2
Instead of fixing logic it's simpler to just call snprintf twice to get
length and use that.
Also change malloc failure check to sway_assert because both callers of
this function do not do null check and would segfault...
Found through static analysis. | 
|  | These could be called with NULL if there is no focus
Found through static analysis. | 
|  |  | 
|  |  | 
|  | Fixes floating window input offsets. As discussed on IRC with emersion,
this shouldn't have been done in the first place. | 
|  | This reverts commit 97672295ed50d1d6272876c4a3b6b5607cab05c6. | 
|  | That happened when they were in tabbed or stacked containers.
Fixes #2161 | 
|  |  | 
|  | Rather than allocate a structure and expect callers to free it, take a
pointer to an existing struct as an argument.
This function is no longer called anywhere though. | 
|  | Instead, damage each container when applying the transaction. | 
|  |  | 
|  | Children can exist when destroying a container, such as when destroying
the last output. Sway is not terminating in that case. | 
|  | Emitting the close event needs to happen before
container_output_destroy, because container_output_destroy sets the
sway_output to NULL and sway_output is used in IPC. | 
|  | We were freeing the sway_output immediately upon disconnect which left
a dangling pointer in the output's container. It then tried to use the
pointer when the container is freed.
We don't need to store the sway_output in an output's container which is
destroying, so the fix is to set the pointer to NULL and remove the use
in container_free.
Also added an arrange when the output is disconnected for good measure. | 
|  |  | 
|  | Also moved the arranging into view_unmap to avoid excessive code
duplication. | 
|  | It happened when a view is a grandchild or deeper of the workspace, is
fullscreen, and unmaps. The workspace would not be included in the
transaction and its pointer to the fullscreen view was left dangling. | 
|  |  | 
|  | container_destroy was calling container_reap_empty, which calls
container_destroy and so on. Eventually the original container_destroy
would return a NULL pointer to the caller which caused a crash.
This also fixes an arrange on the wrong container when moving views in
and out of stacks. | 
|  | This implements atomic layout updates for when views map, reparent or
unmap. | 
|  | * Also fix parts of the rendering where it was rendering the pending
state instead of current. |