-
-
Notifications
You must be signed in to change notification settings - Fork 150
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
dbus: DisplayConfig: support monitor configuration #912
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hey, thanks, this is pretty cool! Left some comments, also prepare to upgrade to zbus 5 since I'll be merging that PR soon.
src/dbus/mutter_display_config.rs
Outdated
@@ -45,6 +82,137 @@ pub struct LogicalMonitor { | |||
|
|||
#[dbus_interface(name = "org.gnome.Mutter.DisplayConfig")] | |||
impl DisplayConfig { | |||
async fn get_resources( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this method actually needed? The panel shows up as is for me, and I cannot actually find any calls to GetResources
in gnome-control-center: https://gitlab.gnome.org/search?search=GetResources&nav_source=navbar&project_id=660&group_id=8&search_code=true&repository_ref=main
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The thing that calls it is gnome-rr but I forgot where I encountered usage of that API… ah. Not for Settings, but it's required for gsd-color. I'd like to get Night Light working, at least via an external client that would read g-s-d's temperature output and do wlr-gamma-control-unstable-v1
based on it, but for that gsd-color
must actually work
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe in a separate PR then?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Bumping. Could you remove this change from this PR?
d0f738b
to
9291b91
Compare
Fixed commit descriptions, improved style according to discussions above, rebased on top of the zbus 5 changes, added fractional scales 🚀 |
src/dbus/mutter_display_config.rs
Outdated
@@ -45,6 +82,137 @@ pub struct LogicalMonitor { | |||
|
|||
#[dbus_interface(name = "org.gnome.Mutter.DisplayConfig")] | |||
impl DisplayConfig { | |||
async fn get_resources( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Bumping. Could you remove this change from this PR?
niri-ipc/src/lib.rs
Outdated
@@ -800,6 +800,22 @@ pub enum Transform { | |||
Flipped270, | |||
} | |||
|
|||
impl Transform { | |||
/// Return numeric identifier matching the `transform` enum of the `wl_output` interface. | |||
pub fn to_wayland_id(self) -> u32 { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is not a "to wayland id", this is a "to mutter-specific private dbus interface id". So it should be left inside mutter_display_config.rs.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The actual numbers do match wayland.xml, not sure why you think mutter could ever switch to different numbers 🙄
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It couldn't. But this code was written specifically to convert according to the mutter xml, and isn't used anywhere else
src/dbus/mutter_display_config.rs
Outdated
connector | ||
))); | ||
} | ||
let msgs = vec![ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In comparison, the wlr-output-management impl creates and sets a complete new output configuration from scratch. Wouldn't that also be more appropriate here?
As far as I understand, the functional difference is that it is applied all at once, without repositioning outputs every step. That said, I think your approach should result in the same outcome anyway? So I guess this code can stay as is.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh, that's possible? Right, I'm not restricted to ipc related API now that I'm using the channels..
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Had to extract the find-or-create-config-by-name part from apply_transient_output_config
but I think it does look better this way, creating the niri_config::Output
from scratch.
Actually the outcome wasn't exactly the same: apply_transient_output_config
was calling reload_output_config
after every action…
8c22145
to
2b56418
Compare
This is required for gnome-control-center to be able to turn monitors back on.
This enables gnome-control-center to apply display configuration changes. Only temporarily, persistence is ignored currently.
2b56418
to
5c17d22
Compare
Thanks, seems to work fine, and the new apply config looks good. I changed the night light property to |
happy new year 🎉 this here PR extends the org.gnome.Mutter.DisplayConfig implementation enough to make the GNOME display settings work
niri-gnome-monitor-settings.webm
(
XDG_CURRENT_DESKTOP=gnome gnome-control-center
)