view lib/localdisplay.py @ 1573:d68e20c831f7 dependabot/pip/service/wifi/lxml-4.6.2

Bump lxml from 4.3.3 to 4.6.2 in /service/wifi Bumps [lxml](https://github.com/lxml/lxml) from 4.3.3 to 4.6.2. - [Release notes](https://github.com/lxml/lxml/releases) - [Changelog](https://github.com/lxml/lxml/blob/master/CHANGES.txt) - [Commits](https://github.com/lxml/lxml/compare/lxml-4.3.3...lxml-4.6.2) Signed-off-by: dependabot[bot] <support@github.com>
author dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
date Thu, 07 Jan 2021 22:55:33 +0000
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")