From 29087903eee36b6e20fe3e15bba2a8caa872ed95 Mon Sep 17 00:00:00 2001 From: necoro <> Date: Wed, 9 May 2007 19:08:37 +0000 Subject: added etcproposals-1.2 support --- portato/plugins/etc_proposals.py | 31 +++++++++++++++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) (limited to 'portato/plugins') diff --git a/portato/plugins/etc_proposals.py b/portato/plugins/etc_proposals.py index 6cf53ad..fa54600 100644 --- a/portato/plugins/etc_proposals.py +++ b/portato/plugins/etc_proposals.py @@ -16,6 +16,12 @@ from portato.backend import system from subprocess import Popen from etcproposals.etcproposals_lib import EtcProposals, __version__ +try: + from etcproposals.etcproposals_info import FRONTEND, VERSIONS +except ImportError: + FRONTEND = None + VERSIONS = None + PROG="/usr/sbin/etc-proposals" class PortatoEtcProposals(EtcProposals): @@ -28,6 +34,17 @@ class PortatoEtcProposals(EtcProposals): self._add_update_proposals(dir) self.sort() +def get_frontend (): + if FRONTEND is None: + return ["--frontend", "gtk"] + else: + cmds = dict(zip([x.name for x in FRONTEND], [[x.command] for x in FRONTEND])) + names = [x.shortname for x in VERSIONS] # need this too, because etcproposals stores frontends in FRONTEND which cannot be launched + + for f in ["gtk2", "qt4"]: + if f in names: + return cmds[f] + def etc_prop (*args, **kwargs): """Entry point for this plugin.""" @@ -38,13 +55,23 @@ def etc_prop (*args, **kwargs): if l > 0: Popen(PROG) else: - Popen([PROG, "--frontend", "gtk", "--fastexit"]) + f = get_frontend() + + if f: + Popen([PROG, "--fastexit"]+f) + else: + debug("Cannot start etc-proposals. No graphical frontend installed!", error = 1) def etc_prop_menu (*args, **kwargs): if am_i_root(): if float(__version__) < 1.1: Popen(PROG) else: - Popen([PROG, "--frontend", "gtk"]) + f = get_frontend() + + if f: + Popen([PROG]+f) + else: + debug("Cannot start etc-proposals. No graphical frontend installed!", error = 1) else: debug("Cannot start etc-proposals. Not root!", error = 1) -- cgit v1.2.3