X-Git-Url: https://git.ralfj.de/lilass.git/blobdiff_plain/41c87e2c4099296550511b3752358e7417e62877..4c3831b98072b3668350cd8c4140383f85484c4c:/gui.py?ds=inline diff --git a/gui.py b/gui.py index 7c9979d..155226b 100644 --- a/gui.py +++ b/gui.py @@ -18,26 +18,36 @@ # This file abstracts GUI stuff away, so that the actual dsl.py does not have to deal with it import sys -qt_available = True -try: +# frontend detectors +def qtAvailable(): + try: + import PyQt4 + return True + except ImportError: + return False + +def zenityAvailable(): + return True # FIXME + +# actual frontend +if qtAvailable(): from PyQt4 import QtGui from qt_dialogue import PositionSelection app = QtGui.QApplication(sys.argv) -except Exception, e: - import subprocess - from zenity_dialogue import run as zenity_run - qt_available = False - -def error(message): - '''Displays a fatal error to the user''' - if qt_available: + + def error(message): + '''Displays a fatal error to the user''' QtGui.QMessageBox.critical(None, 'Fatal error', message) - else: - subprocess.Popen(["zenity", "--error", "--text="+message], stdout=subprocess.PIPE) - -def setup(internalResolutions, externalResolutions): - '''Returns a ScreenSetup instance, or None if the user canceled''' - if qt_available: + + def setup(internalResolutions, externalResolutions): + '''Returns a ScreenSetup instance, or None if the user canceled''' return PositionSelection(internalResolutions, externalResolutions).run() - else: - return zenity_run(internalResolutions, externalResolutions) +elif zenityAvailable(): + import subprocess + from zenity_dialogue import run as setup # this provides the setup function + + def error(message): + '''Displays a fatal error to the user''' + subprocess.check_call(["zenity", "--error", "--text="+message]) +else: + print >> sys.stderr, 'No GUI frontend available, please make sure PyQt4 or Zenity is installed'