Merge remote-tracking branch 'queezythegreat/master'

Conflicts:
	Makefile
This commit is contained in:
Phillip Berndt 2013-12-02 10:50:40 +01:00
commit 43bb98c613
3 changed files with 57 additions and 1 deletions

View File

@ -11,4 +11,4 @@ install:
hotplug:
install -m 755 pm-utils/40autorandr /etc/pm/sleep.d/
install -m 644 udev/40-monitor-hotplug.rules /etc/udev/rules.d/
udevadm control --reload-rules
udevadm control --reload-rules

View File

@ -0,0 +1,3 @@
# -*- sh -*-
/usr/bin/autorandr_monitor &> /tmp/autorandr_monitor &

View File

@ -0,0 +1,53 @@
#!/usr/bin/env python
""""
Author: Tomasz Bogdal (a.k.a. QueezyTheGreat)
Home: https://github.com/queezythegreat/autorandr
License: This Source Code Form is subject to the terms of the
Mozilla Public License, v. 2.0
"""
import os
import pyinotify
from pyinotify import ProcessEvent
#TODO: Fork off when started
#TODO: Add configuration file
#TODO: Add command line options
SYS_VIDEO_OUTPUTS='/sys/class/drm/'
DEFAULT_PROFILE='default'
AUTORANDR_CMD='autorandr --change --default %s' % DEFAULT_PROFILE
class VideoOutputMonitor(ProcessEvent):
""" Launch autorandr when video card output status is changed. """
def process_IN_ACCESS(self, event):
""" Handle IN_ACCESS events to `status` file. """
if event.name == 'status':
print 'Change status of %s' % os.path.basename(event.path)
os.system(AUTORANDR_CMD)
def register_video_cards(manager):
""" Register all video card ouptus for monitoring. """
if not os.path.exists(SYS_VIDEO_OUTPUTS):
return
for directory in os.listdir(SYS_VIDEO_OUTPUTS):
path = os.path.join(SYS_VIDEO_OUTPUTS, directory)
status = os.path.join(path, 'status')
if os.path.exists(status):
print 'Monitoring %s' % path
manager.add_watch(path, pyinotify.ALL_EVENTS)
def main():
# pyinotify.log.setLevel(10)
manager = pyinotify.WatchManager()
handler = VideoOutputMonitor()
notifier = pyinotify.Notifier(manager, default_proc_fun=handler)
register_video_cards(manager)
notifier.loop()
if __name__ == '__main__':
main()