From: Phillip Berndt Date: Mon, 2 Dec 2013 09:50:40 +0000 (+0100) Subject: Merge remote-tracking branch 'queezythegreat/master' X-Git-Tag: 1.0~149 X-Git-Url: https://git.donarmstrong.com/?p=deb_pkgs%2Fautorandr.git;a=commitdiff_plain;h=43bb98c613862cdf8cb81a49a03b30f70c706816 Merge remote-tracking branch 'queezythegreat/master' Conflicts: Makefile --- 43bb98c613862cdf8cb81a49a03b30f70c706816 diff --cc Makefile index 41494fa,49d598e..a22a058 --- a/Makefile +++ b/Makefile @@@ -1,14 -1,8 +1,14 @@@ +all: + @echo "Call \"make install\" to install this program." + @echo "Call \"make hotplug\" to install matching hotplug events." +INSTALL_PATH=/usr/local/bin install: - install -m 775 autorandr /usr/bin/ - install -m 775 autorandr_monitor /usr/bin/ + install auto-disper ${INSTALL_PATH} + install -m 755 autorandr ${INSTALL_PATH} install -m 644 bash_completion/autorandr /etc/bash_completion.d/ - ln -sf /usr/bin/autorandr /usr/bin/auto-disper - install -m 644 Xsession.d/autorandr /etc/X11/Xsession.d/99zautorandr - #install -m 644 pm-utils/40autorandr /etc/pm/power.d/ + +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 diff --cc contrib/autorandr_monitor/Xsession.d/autorandr index 0000000,0000000..d0b568a new file mode 100644 --- /dev/null +++ b/contrib/autorandr_monitor/Xsession.d/autorandr @@@ -1,0 -1,0 +1,3 @@@ ++# -*- sh -*- ++ ++/usr/bin/autorandr_monitor &> /tmp/autorandr_monitor & diff --cc contrib/autorandr_monitor/autorandr_monitor index 0000000,0000000..6f369bb new file mode 100755 --- /dev/null +++ b/contrib/autorandr_monitor/autorandr_monitor @@@ -1,0 -1,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()