Mercurial > code > home > repos > homeauto
annotate lib/localdisplay.py @ 173:0daa8cbbd8f6
handle compact/full uris better, but still not always right
Ignore-this: 10d98f16a659f899528eb86411473b18
author | drewp@bigasterisk.com |
---|---|
date | Fri, 17 Apr 2015 02:00:15 -0700 |
parents | 9155e9a605ec |
children | 2f8ba398f958 |
rev | line source |
---|---|
81
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
1 import psutil, os |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
2 |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
3 def setDisplayToLocalX(): |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
4 """ |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
5 set DISPLAY env var in this process to the id of the X process on localhost |
119 | 6 |
7 I might need something like xauth merge /run/gdm/auth-for-gdm-xxxxxx/database too | |
8 and this isn't automated yet | |
81
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
9 """ |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
10 for pid in psutil.get_pid_list(): |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
11 try: |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
12 proc = psutil.Process(pid) |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
13 if proc.exe not in ['/usr/bin/Xorg', '/usr/bin/X']: |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
14 continue |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
15 except (psutil.error.AccessDenied, psutil.error.NoSuchProcess): |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
16 continue |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
17 display = proc.cmdline[1] |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
18 assert display.startswith(':'), display |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
19 os.environ['DISPLAY'] = display |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
20 break |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
21 else: |
ef639d892e77
Xorg display number fetcher for use by xidle and dpms
drewp@bigasterisk.com
parents:
diff
changeset
|
22 raise ValueError("didn't find an Xorg process") |