Mercurial > code > home > repos > homeauto
view lib/localdisplay.py @ 1416:201090b9c725
just reindent, i think
Ignore-this: 519383817f24612419191d79e14bfb5c
darcs-hash:9573fbb16b44da29f3d4f3b1c429595a13e51532
author | drewp <drewp@bigasterisk.com> |
---|---|
date | Sat, 03 Aug 2019 17:02:16 -0700 |
parents | 6d67b23f3a75 |
children |
line wrap: on
line source
import psutil, os def setDisplayToLocalX(): """ set DISPLAY env var in this process to the id of the X process on localhost I might need something like xauth merge /run/gdm/auth-for-gdm-xxxxxx/database too and this isn't automated yet """ for pid in psutil.get_pid_list(): try: proc = psutil.Process(pid) if proc.exe not in ['/usr/bin/Xorg', '/usr/bin/X', '/usr/bin/X11/X', '/usr/lib/xorg/Xorg']: continue except (psutil.error.AccessDenied, psutil.error.NoSuchProcess): continue argIter = iter(proc.cmdline) while True: arg = argIter.next() if arg in ['-background']: argIter.next() continue if arg in ['-nolisten']: continue if arg.startswith(':'): display = arg break if arg == 'tcp': display = ':0.0' break assert display.startswith(':'), display os.environ['DISPLAY'] = display os.environ['XAUTHORITY'] = os.path.expanduser('~/.Xauthority') break else: raise ValueError("didn't find an Xorg process")