diff options
author | Florent Le Coz <louiz@louiz.org> | 2011-11-09 01:23:35 +0100 |
---|---|---|
committer | Florent Le Coz <louiz@louiz.org> | 2011-11-09 01:23:35 +0100 |
commit | ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f (patch) | |
tree | 3f2bbf1be7f753f1c7495f0a60833f469e7f10a7 /plugins/screen_detach.py | |
parent | 7fadb35fe2e7932a0a4aa6a8184ab6b186669edc (diff) | |
parent | 03999f1ef08036b7ea25e2239cf7b6bcdb4d76cc (diff) | |
download | poezio-ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f.tar.gz poezio-ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f.tar.bz2 poezio-ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f.tar.xz poezio-ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f.zip |
Merge branch 'plugins'
Conflicts:
README
src/core.py
src/tabs.py
Diffstat (limited to 'plugins/screen_detach.py')
-rw-r--r-- | plugins/screen_detach.py | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/plugins/screen_detach.py b/plugins/screen_detach.py new file mode 100644 index 00000000..6ee96896 --- /dev/null +++ b/plugins/screen_detach.py @@ -0,0 +1,46 @@ +from plugin import BasePlugin +import os +import stat +import pyinotify + +SCREEN_DIR = '/var/run/screen/S-%s' % (os.getlogin(),) + +class Plugin(BasePlugin): + def init(self): + self.timed_event = None + sock_path = None + self.thread = None + for f in os.listdir(SCREEN_DIR): + path = os.path.join(SCREEN_DIR, f) + if screen_attached(path): + sock_path = path + self.attached = True + break + + # Only actually do something if we found an attached screen (assuming only one) + if sock_path: + wm = pyinotify.WatchManager() + wm.add_watch(sock_path, pyinotify.EventsCodes.ALL_FLAGS['IN_ATTRIB']) + self.thread = pyinotify.ThreadedNotifier(wm, default_proc_fun=HandleScreen(plugin=self)) + self.thread.start() + + def cleanup(self): + if self.thread: + self.thread.stop() + + def update_screen_state(self, socket): + attached = screen_attached(socket) + if attached != self.attached: + self.attached = attached + status = 'available' if self.attached else 'away' + self.core.command_status(status) + +def screen_attached(socket): + return (os.stat(socket).st_mode & stat.S_IXUSR) != 0 + +class HandleScreen(pyinotify.ProcessEvent): + def my_init(self, **kwargs): + self.plugin = kwargs['plugin'] + + def process_IN_ATTRIB(self, event): + self.plugin.update_screen_state(event.path) |