getting display and layout state for populating menu
This commit is contained in:
parent
1b34993fa9
commit
de00f9bdce
1 changed files with 69 additions and 1 deletions
|
@ -7,8 +7,10 @@ Requires the following executable:
|
||||||
* xrandr
|
* xrandr
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
import fnmatch
|
||||||
from functools import partial
|
from functools import partial
|
||||||
import logging
|
import logging
|
||||||
|
import os
|
||||||
|
|
||||||
import core.module
|
import core.module
|
||||||
import core.widget
|
import core.widget
|
||||||
|
@ -21,6 +23,7 @@ from util.cli import execute
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
__screenlayout_dir__ = os.path.expanduser("~/.screenlayout")
|
||||||
|
|
||||||
class Module(core.module.Module):
|
class Module(core.module.Module):
|
||||||
@core.decorators.never
|
@core.decorators.never
|
||||||
|
@ -42,12 +45,77 @@ class Module(core.module.Module):
|
||||||
of three ways: launch arandr, select a pre-set screenlayout, toggle a
|
of three ways: launch arandr, select a pre-set screenlayout, toggle a
|
||||||
display.
|
display.
|
||||||
"""
|
"""
|
||||||
log.info("arandr showing popup")
|
|
||||||
menu = popup.menu()
|
menu = popup.menu()
|
||||||
menu.add_menuitem("arandr",
|
menu.add_menuitem("arandr",
|
||||||
callback=partial(execute, self.manager)
|
callback=partial(execute, self.manager)
|
||||||
)
|
)
|
||||||
|
menu.add_separator()
|
||||||
|
|
||||||
|
displays = Module._get_displays()
|
||||||
|
layouts = Module._get_layouts()
|
||||||
|
available_layouts = Module._prune_layouts(layouts, displays)
|
||||||
|
|
||||||
menu.show(widget, 0, 0)
|
menu.show(widget, 0, 0)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _get_displays():
|
||||||
|
"""Queries xrandr and builds a dict of the displays and their state.
|
||||||
|
|
||||||
|
The dict entries are key by the display and are bools (True if
|
||||||
|
connected).
|
||||||
|
"""
|
||||||
|
displays = {}
|
||||||
|
for line in execute("xrandr -q").split("\n"):
|
||||||
|
if not "connected" in line:
|
||||||
|
continue
|
||||||
|
parts = line.split(" ", 2)
|
||||||
|
display = parts[0]
|
||||||
|
displays[display] = True if parts[1] == "connected" else False
|
||||||
|
|
||||||
|
return displays
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _get_layouts():
|
||||||
|
"""Loads and parses the arandr screen layout scripts."""
|
||||||
|
layouts = {}
|
||||||
|
for filename in os.listdir(__screenlayout_dir__):
|
||||||
|
if fnmatch.fnmatch(filename, '*.sh'):
|
||||||
|
fullpath = os.path.join(__screenlayout_dir__, filename)
|
||||||
|
with open(fullpath, "r") as file:
|
||||||
|
for line in file:
|
||||||
|
s_line = line.strip()
|
||||||
|
if not "xrandr" in s_line:
|
||||||
|
continue
|
||||||
|
displays_in_file = Module._parse_layout(line)
|
||||||
|
layouts[filename] = displays_in_file
|
||||||
|
return layouts
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _parse_layout(line):
|
||||||
|
"""Parses a single xrandr line to find what displays are active in the
|
||||||
|
command. Returns them as a list.
|
||||||
|
"""
|
||||||
|
active_displays = []
|
||||||
|
to_check = line[7:].split("--output ")
|
||||||
|
for check in to_check:
|
||||||
|
if not check or "off" in check:
|
||||||
|
continue
|
||||||
|
active_displays.append(check.split(" ")[0])
|
||||||
|
return active_displays
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _prune_layouts(layouts, displays):
|
||||||
|
"""Return a list of layouts whose displays are actually connected."""
|
||||||
|
available = []
|
||||||
|
for layout, needs in layouts.items():
|
||||||
|
still_valid = True
|
||||||
|
for need in needs:
|
||||||
|
if need not in displays or not displays[need]:
|
||||||
|
still_valid = False
|
||||||
|
break
|
||||||
|
if still_valid:
|
||||||
|
available.append(layout)
|
||||||
|
return available
|
||||||
|
|
||||||
|
|
||||||
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
|
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
|
||||||
|
|
Loading…
Reference in a new issue