Mercurial > code > home > repos > homeauto
view lib/localdisplay.py @ 1407:6c86c6a87eab
update standardservice. add --dns to all docker runs
Ignore-this: 7439dab992e614fa8fa562f4f750e57b
darcs-hash:f765086ee3524d876864142fc6c37d971ec970ac
author | drewp <drewp@bigasterisk.com> |
---|---|
date | Tue, 23 Jul 2019 10:29:31 -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")