Summary: | Monitor dropdown can not be enabled | ||
---|---|---|---|
Product: | [Applications] systemsettings | Reporter: | Lorenz Hoffmann <hoffmann_lorenz> |
Component: | kcm_kgamma | Assignee: | Unassigned bugs mailing-list <unassigned-bugs> |
Status: | CONFIRMED --- | ||
Severity: | normal | CC: | nascentsoul13, nate, plasma-bugs |
Priority: | NOR | Keywords: | junior-jobs |
Version: | 5.21.4 | ||
Target Milestone: | --- | ||
Platform: | Manjaro | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: | |||
Attachments: | The settings page that I'm talking about |
Description
Lorenz Hoffmann
2021-04-29 10:41:53 UTC
Can you share a screenshot that shows the problem? I'm having a hard time understanding what exactly is going on. Thanks! Created attachment 138030 [details]
The settings page that I'm talking about
I've added a screenshot to the attachments, I hope that's the right place. This dropdown menu in the bottom right corner should be enabled if more than one screen are connected, used and "sync screens" is turned off. Ah that thing! I can the bug by simple code inspection. Will fix it at some point soon. I tried fixing this as it is tagged as a junior job but couldn't, here are my findings though. It seems like the problem lies in a function XVidExtWrap::_ScreenCount(). It gets called from KGamma constructor and then the returned count value is used to configure screens combobox in a function KGamma::setupUI(). When configuring combobox, if screen count <=1 checkbox. From my observation XVidExtWrap::_ScreenCount() always returns 1 no matter if I plug\unplug my second monitor thus creating bug in question. Looking at XVidExtWrap::_ScreenCount() implementation it uses class XF86ConfigPath to get count of screens. In XF86ConfigPath constructor there is defined a list of magic string paths that it tries to access all sorts of configs and fails at all of them (I also checked each path manually on my system and didn't find any of them). As it can't find any configs screen count is 0, but in the end of function it gets set to 1 after !count check. Sibling setting category "Display Configuration" somehow has "Device" combobox that correctly identifies current available screens. After looking into it's implementation for awhile I kinda gave up as this issue is too hard for me now. (In reply to Roman Azami from comment #5) > I tried fixing this as it is tagged as a junior job but couldn't, here are > my findings though. > > It seems like the problem lies in a function XVidExtWrap::_ScreenCount(). It > gets called from KGamma constructor and then the returned count value is > used to configure screens combobox in a function KGamma::setupUI(). When > configuring combobox, if screen count <=1 checkbox. From my observation > XVidExtWrap::_ScreenCount() always returns 1 no matter if I plug\unplug my > second monitor thus creating bug in question. > > Looking at XVidExtWrap::_ScreenCount() implementation it uses class > XF86ConfigPath to get count of screens. In XF86ConfigPath constructor there > is defined a list of magic string paths that it tries to access all sorts of > configs and fails at all of them (I also checked each path manually on my > system and didn't find any of them). As it can't find any configs screen > count is 0, but in the end of function it gets set to 1 after !count check. > > Sibling setting category "Display Configuration" somehow has "Device" > combobox that correctly identifies current available screens. After looking > into it's implementation for awhile I kinda gave up as this issue is too > hard for me now. Cant edit previous comment, little change: "if screen count <=1 checkbox" to "if screen count <=1 then combobox is disabled I am unable to find that settings page in Plasma 6. If it's removed, this can be closed, I guess. This KCM is X11-only, and you're probably using the Wayland session now in Plasma 6. I think there has been UI redesign here, so this might be resolved? Nah, KGamma hasn't been touch in years. Ok, sorry for the noise then. I switched from arch to kinoite and can't switch to x11 anymore. I found a color profile section in the system settings this was a replacement for kgamma. |