# DSL - easy Display Setup for Laptops
-# Copyright (C) 2012 Ralf Jung <post@ralfj.de>
+# Copyright (C) 2012-2015 Ralf Jung <post@ralfj.de>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
'''
import subprocess, collections
+from cli_frontend import CLIFrontend
+from zenity_frontend import ZenityFrontend
+from screen import processOutputIt
+
# Qt frontend
class QtFrontend:
def __init__(self):
from PyQt4 import QtGui
QtGui.QMessageBox.critical(None, 'Fatal error', message)
- def setup(self, internalResolutions, externalResolutions, commonRes):
+ def setup(self, situation):
from qt_dialogue import PositionSelection
- return PositionSelection(internalResolutions, externalResolutions, commonRes).run()
+ return PositionSelection(situation).run()
@staticmethod
def isAvailable():
except ImportError:
return False
-
-# Zenity frontend
-class ZenityFrontend:
- def error(message):
- '''Displays a fatal error to the user'''
- subprocess.check_call(["zenity", "--error", "--text="+message])
-
- def setup(self, internalResolutions, externalResolutions, commonRes):
- from zenity_dialogue import run
- run(internalResolutions, externalResolutions)
-
- @staticmethod
- def isAvailable():
- try:
- from dsl import processOutputIt
- processOutputIt("zenity", "--version")
- return True
- except Exception:
- return False
-
-
-# CLI frontend
-class CLIFrontend:
- def error(self, message):
- print(message, file=sys.stderr)
-
- def setup(self, internalResolutions, externalResolutions, commonRes):
- raise Exception("Choosing the setup interactively is not supported with the CLI frontend")
-
- @staticmethod
- def isAvailable():
- return True
-
# list of available frontends
frontends = collections.OrderedDict()
frontends["qt"] = QtFrontend
if name in frontends:
if frontends[name].isAvailable():
return frontends[name]() # call constructor
- # frontend not found or not available
- raise Exception("Frontend %s not found or not available" % name)
+ else:
+ raise Exception("Frontend %s not available" % name)
+ # frontend not found
+ raise Exception("Frontend %s not found" % name)
# auto-detect
for frontend in frontends.values():
if frontend.isAvailable():