-
Notifications
You must be signed in to change notification settings - Fork 10
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
Fix allow_duplicates
behavior in set_brightness()
for relative string values
#37
Conversation
The index is not "global" but is scoped to the OS specific method that controls that monitor. The test displays are configured to represent different sets of monitors that can be controlled in different ways. In the real world, this might look like this: # first laptop display detected
sbc.windows.WMI.get_brightness(display=0)
# first desktop monitor detected. Same index but definitely not the same as WMI[0]
sbc.windows.VCP.get_brightness(display=0) This means that using the index as the identifier inside import screen_brightness_control as sbc
monitors = [
{'method': sbc.windows.WMI, 'index': 0, 'name': 'Display A'},
{'method': sbc.windows.VCP, 'index': 0, 'name': 'Display B'},
]
for monitor in sbc.filter_monitors(haystack=monitors):
# will call with `display=0` twice, only setting the laptop display
sbc.set_brightness(100, display=monitor['index']) We could either use the for monitor in sbc.filter_monitors(haystack=monitors):
# option 1:
display_instance = Display.from_dict(monitor)
# calls the OS method directly with the method-scoped index
display.set_brightness(100)
# option 2
# includes all the error handling from __brightness
set_brightness(100, display=monitor['index'], method=monitor['method']) Option 1 is probably more efficient but I don't really mind which way it goes |
I'm also starting to wonder if, for your monitors, there may be more information in the EDID extension blocks. The following code should get the full edid for each of your monitors: import screen_brightness_control as sbc
import struct
from pprint import pprint
wmi = sbc.windows._wmi_init()
edids = {}
for monitor in wmi.WmiMonitorDescriptorMethods():
base = ''.join(f'{char:02x}' for char in monitor.WmiGetMonitorRawEEdidV1Block(0)[0])
following_blocks = struct.unpack(sbc.helpers.EDID.EDID_FORMAT, bytes.fromhex(base))[-2]
blocks = [base] + [
''.join(f'{char:02x}' for char in monitor.WmiGetMonitorRawEEdidV1Block(i)[0])
for i in range(1, following_blocks + 1)
]
edids[monitor.InstanceName] = ''.join(blocks)
pprint(edids)
print('All EDIDs identical:', len(set(edids.values())) == 1) If they're not all identical, it may be worth figuring out how to add parsing for EDID extension blocks. I haven't up until now since most displays seem to store all the identifying info in the first edid block |
|
LGTM. Thanks for this. |
This PR addresses a bug related to the
allow_duplicates
in theset_brightness()
when thevalue
is a relative string value (e.g., "+20" or "-10").During the process of adding pytest cases for this scenario, I noticed a discrepancy in the definition of "duplicates". In the current implementation, it is supposed that duplicates could occur in two scenarios:
In both scenarios, the
list_monitors_info()
function returns the same output: different indices but identical other fields. This behavior was observed on a Windows 11 system.However, in the mock modules (
helpers_mock.py
andos_module_mock.py
), the first and third displays share the same index but have many different other fields.Do you suggest any modifications around
allow_duplicates
?