projects
/
lilass.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add an option to force disabling external and enabling internal screens
[lilass.git]
/
dsl.py
diff --git
a/dsl.py
b/dsl.py
index d13d0a0f8dc058c008fe2e12dbc7393624cb242b..d05c4704fbd6c769247bee20973795775a37414b 100755
(executable)
--- a/
dsl.py
+++ b/
dsl.py
@@
-1,4
+1,4
@@
-#!/usr/bin/python
+#!/usr/bin/python
3
# DSL - easy Display Setup for Laptops
# Copyright (C) 2012 Ralf Jung <post@ralfj.de>
#
# DSL - easy Display Setup for Laptops
# Copyright (C) 2012 Ralf Jung <post@ralfj.de>
#
@@
-17,7
+17,8
@@
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
import argparse, sys, os, re, subprocess
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
import argparse, sys, os, re, subprocess
-import gui
+from gui import getFrontend
+frontend = getFrontend("cli") # the fallback, until we got a proper frontend. This is guaranteed to be available.
# for auto-config: common names of internal connectors
commonInternalConnectorNames = ['LVDS', 'LVDS0', 'LVDS1', 'LVDS-0', 'LVDS-1']
# for auto-config: common names of internal connectors
commonInternalConnectorNames = ['LVDS', 'LVDS0', 'LVDS1', 'LVDS-0', 'LVDS-1']
@@
-56,15
+57,15
@@
class ScreenSetup:
return args
# Load a section-less config file: maps parameter names to space-separated lists of strings (with shell quotation)
return args
# Load a section-less config file: maps parameter names to space-separated lists of strings (with shell quotation)
-def loadConfigFile(file):
+def loadConfigFile(file
name
):
import shlex
result = {}
import shlex
result = {}
- if not os.path.exists(file):
+ if not os.path.exists(file
name
):
return result # no config file
# read config file
linenr = 0
return result # no config file
# read config file
linenr = 0
- with open(file
) as file
:
- for line in f
ile
:
+ with open(file
name) as f
:
+ for line in f:
linenr += 1
line = line.strip()
if not len(line) or line.startswith("#"): continue # skip empty and comment lines
linenr += 1
line = line.strip()
if not len(line) or line.startswith("#"): continue # skip empty and comment lines
@@
-81,10
+82,9
@@
def loadConfigFile(file):
# helper function: execute a process, return output as iterator, throw exception if there was an error
# you *must* iterate to the end if you use this!
def processOutputGen(*args):
# helper function: execute a process, return output as iterator, throw exception if there was an error
# you *must* iterate to the end if you use this!
def processOutputGen(*args):
- p = subprocess.Popen(args, stdout=subprocess.PIPE)
- for line in p.stdout:
- yield line
- p.wait() # wait for process to exit (it closed stdout, so it can't block anymore)
+ with subprocess.Popen(args, stdout=subprocess.PIPE) as p:
+ for line in p.stdout:
+ yield line.decode("utf-8")
if p.returncode != 0:
raise Exception("Error executing "+str(args))
def processOutputIt(*args):
if p.returncode != 0:
raise Exception("Error executing "+str(args))
def processOutputIt(*args):
@@
-117,7
+117,7
@@
def getXrandrInformation():
# unknown line
# not fatal as my xrandr shows strange stuff when a display is enabled, but not connected
#raise Exception("Unknown line in xrandr output:\n"+line)
# unknown line
# not fatal as my xrandr shows strange stuff when a display is enabled, but not connected
#raise Exception("Unknown line in xrandr output:\n"+line)
- print
"Warning: Unknown xrandr line %s" % line
+ print
("Warning: Unknown xrandr line %s" % line)
return connectors
# convert a (width, height) pair into a string accepted by xrandr as argument for --mode
return connectors
# convert a (width, height) pair into a string accepted by xrandr as argument for --mode
@@
-170,7
+170,7
@@
def classifyConnectors(allConnectors):
if connector == internalConnector:
raise Exception("%s is both internal and external, that doesn't make sense." % connector)
else:
if connector == internalConnector:
raise Exception("%s is both internal and external, that doesn't make sense." % connector)
else:
- externalConnectors =
allConnectors.keys(
)
+ externalConnectors =
list(allConnectors.keys()
)
externalConnectors.remove(internalConnector)
if not externalConnectors:
raise Exception("No external connector found - either your config is wrong, or your machine has only one connector.")
externalConnectors.remove(internalConnector)
if not externalConnectors:
raise Exception("No external connector found - either your config is wrong, or your machine has only one connector.")
@@
-182,11
+182,20
@@
if __name__ == "__main__":
try:
# parse command-line arguments
parser = argparse.ArgumentParser(description='easy Display Setup for Laptops')
try:
# parse command-line arguments
parser = argparse.ArgumentParser(description='easy Display Setup for Laptops')
+ parser.add_argument("-f, --frontend",
+ dest="frontend",
+ help="The frontend to be used for user interaction")
parser.add_argument("-r, --relative-position",
dest="rel_position", choices=('left', 'right', 'external-only'),
help="Position of external screen relative to internal one")
parser.add_argument("-r, --relative-position",
dest="rel_position", choices=('left', 'right', 'external-only'),
help="Position of external screen relative to internal one")
+ parser.add_argument("-i,--internal-only",
+ dest="internal_only", action='store_true',
+ help="Enable internal screen, disable all the others (as if no external screen was connected")
cmdArgs = parser.parse_args()
cmdArgs = parser.parse_args()
+ # load frontend
+ frontend = getFrontend(cmdArgs.frontend)
+
# load connectors and classify them
connectors = getXrandrInformation()
(internalConnector, externalConnectors) = classifyConnectors(connectors)
# load connectors and classify them
connectors = getXrandrInformation()
(internalConnector, externalConnectors) = classifyConnectors(connectors)
@@
-199,7
+208,7
@@
if __name__ == "__main__":
# check whether we got an external screen or not
# Check what to do
usedExternalConnector = findAvailableConnector(externalConnectors, connectors) # *the* external connector which is actually used
# check whether we got an external screen or not
# Check what to do
usedExternalConnector = findAvailableConnector(externalConnectors, connectors) # *the* external connector which is actually used
- if usedExternalConnector is not None:
+ if
not cmdArgs.internal_only and
usedExternalConnector is not None:
# there's an external screen connected, we need to get a setup
if cmdArgs.rel_position is not None:
# use command-line arguments (can we do this relPosition stuff more elegant?)
# there's an external screen connected, we need to get a setup
if cmdArgs.rel_position is not None:
# use command-line arguments (can we do this relPosition stuff more elegant?)
@@
-212,7
+221,7
@@
if __name__ == "__main__":
setup = ScreenSetup(relPosition, connectors[internalConnector][0], connectors[usedExternalConnector][0]) # use default resolutions
else:
# use GUI
setup = ScreenSetup(relPosition, connectors[internalConnector][0], connectors[usedExternalConnector][0]) # use default resolutions
else:
# use GUI
- setup =
gui
.setup(connectors[internalConnector], connectors[usedExternalConnector])
+ setup =
frontend
.setup(connectors[internalConnector], connectors[usedExternalConnector])
if setup is None: sys.exit(1) # the user canceled
# apply it
connectorArgs[internalConnector] = setup.getInternalArgs()
if setup is None: sys.exit(1) # the user canceled
# apply it
connectorArgs[internalConnector] = setup.getInternalArgs()
@@
-225,8
+234,8
@@
if __name__ == "__main__":
call = ["xrandr"]
for name in connectorArgs:
call += ["--output", name] + connectorArgs[name]
call = ["xrandr"]
for name in connectorArgs:
call += ["--output", name] + connectorArgs[name]
- print
"Call that will be made:",call
+ print
("Call that will be made:",call)
subprocess.check_call(call)
except Exception as e:
subprocess.check_call(call)
except Exception as e:
-
gui
.error(str(e))
+
frontend
.error(str(e))
raise
raise