# -*- coding: utf-8 -*- # # File: portato/gui/utils.py # This file is part of the Portato-Project, a graphical portage-frontend. # # Copyright (C) 2006-2010 René 'Necoro' Neumann # This is free software. You may redistribute copies of it under the terms of # the GNU General Public License version 2. # There is NO WARRANTY, to the extent permitted by law. # # Written by René 'Necoro' Neumann # some stuff needed import sys import logging import gettext from threading import Thread import gtk # some backend things from ..backend import flags, system from ..helper import debug, info from ..log import set_log_level from ..constants import APP, LOCALE_DIR # parser from ..config_parser import ConfigParser def get_color (cfg, name): return gtk.gdk.color_parse("#%s" % cfg.get(name, section = "COLORS")) class GtkThread (Thread): def run(self): # for some reason, I have to install this for each thread ... gettext.install(APP, LOCALE_DIR, unicode = True) try: Thread.run(self) except SystemExit: raise # let normal thread handle it except: type, val, tb = sys.exc_info() try: sys.excepthook(type, val, tb, thread = self.getName()) except TypeError: raise type(val).with_traceback(tb) # let normal thread handle it finally: del type, val, tb class Config (ConfigParser): def __init__ (self, cfgFile): """Constructor. @param cfgFile: path to config file @type cfgFile: string""" ConfigParser.__init__(self, cfgFile) # read config self.parse() # local configs self.local = {} # session configs self.session = {} def modify_flags_config (self): """Sets the internal config of the L{flags}-module. @see: L{flags.set_config()}""" flagCfg = { "usefile": self.get("useFile"), "usePerVersion" : self.get_boolean("usePerVersion"), "maskfile" : self.get("maskFile"), "maskPerVersion" : self.get_boolean("maskPerVersion"), "testingfile" : self.get("keywordFile"), "testingPerVersion" : self.get_boolean("keywordPerVersion")} flags.set_config(flagCfg) def modify_debug_config (self): if self.get_boolean("debug"): level = logging.DEBUG else: level = logging.INFO set_log_level(level) def modify_system_config (self): """Sets the system config.""" system.set_system(self.get("system")) def modify_external_configs (self): """Convenience function setting all external configs.""" self.modify_debug_config() self.modify_flags_config() self.modify_system_config() def set_local(self, cpv, name, val): """Sets some local config. @param cpv: the cpv describing the package for which to set this option @type cpv: string (cpv) @param name: the option's name @type name: string @param val: the value to set @type val: any""" if not cpv in self.local: self.local[cpv] = {} self.local[cpv].update({name:val}) def get_local(self, cpv, name): """Returns something out of the local config. @param cpv: the cpv describing the package from which to get this option @type cpv: string (cpv) @param name: the option's name @type name: string @return: value stored for the cpv and name or None if not found @rtype: any""" if not cpv in self.local: return None if not name in self.local[cpv]: return None return self.local[cpv][name] def set_session (self, name, cat, val): self.session[(cat, name)] = val def get_session (self, name, cat): v = self.session.get((cat, name), None) if v == "": v = None return v def write(self): """Writes to the config file and modify any external configs.""" ConfigParser.write(self) self.modify_external_configs() class GtkTree (object): """The implementation of the abstract tree.""" def __init__ (self, tree, col = 0): """Constructor. @param tree: original tree @type tree: gtk.TreeStore @param col: the column where the cpv is stored @type col: int""" self.tree = tree self.cpv_col = col self.emergeIt = None self.unmergeIt = None self.updateIt = None def build_append_value (self, cpv, oneshot = False, update = False, downgrade = False, version = None, useChange = []): """ Builds the list, which is going to be passed to append. @param cpv: the cpv @type cpv: string (cpv) @param oneshot: True if oneshot @type oneshot: boolean @param update: True if this is an update @type update: boolean @param downgrade: True if this is a downgrade @type downgrade: boolean @param version: the version we update from @type version: string @param useChange: list of changed useflags; use "-use" for removed and "+use" for added flags @type useChange: string[] @returns: the created list @rtype: list """ string = "" if oneshot: string += "%s" % _("oneshot") if update: if oneshot: string += "; " if version is not None: string += "%s" % (_("updating from version %s") % version) else: string += "%s" % _("updating") elif downgrade: if oneshot: string += "; " if version is not None: string += "%s" % (_("downgrading from version %s") % version) else: string += "%s" % _("downgrading") if useChange: if update or downgrade or oneshot: string += "; " string += "%s " % _("IUSE changes:") useChange.sort() string += "%s" % " ".join(useChange) return [cpv, string, False] def set_in_progress (self, it, to = True): """ Marks the queue where the given iterator belongs as being in progress. @param it: one iterator of the queue to mark to @type it: Iterator @param to: whether to enable or disable @type to: boolean """ iter = self.first_iter(it) if to: self.tree.set_value(iter, 1, "%s" % _("(In Progress)")) else: self.tree.set_value(iter, 1, "") self.tree.set_value(iter, 2, to) def is_in_progress (self, it): """ Returns whether the queue where the given iterator belongs to, is marked as "being in progress". @param it: the iterator @type it: Iterator @returns: whether the queue is marked "in progress" @rtype: boolean """ return self.tree.get_value(it, 2) def get_emerge_it (self): """ Returns an iterator signaling the top of the emerge section. @returns: emerge-iterator @rtype: Iterator """ if self.emergeIt is None: self.emergeIt = self.append(None, ["%s" % _("Install"), "", False]) return self.emergeIt def get_unmerge_it (self): """ Returns an iterator signaling the top of the unmerge section. @returns: unmerge-iterator @rtype: Iterator """ if self.unmergeIt is None: self.unmergeIt = self.append(None, ["%s" % _("Uninstall"), "", False]) return self.unmergeIt def get_update_it (self): """ Returns an iterator signaling the top of the update section. @returns: unmerge-iterator @rtype: Iterator """ if self.updateIt is None: self.updateIt = self.append(None, ["%s" % _("Update"), "", False]) return self.updateIt def first_iter (self, it): """ Returns the iterator at the top. @param it: the iterator @type it: Iterator @returns: the top iterator @rtype: Iterator """ return self.tree.get_iter_from_string(self.tree.get_string_from_iter(it).split(":")[0]) def is_in (self, it, in_it): return in_it and self.iter_equal(self.first_iter(it), in_it) def is_in_emerge (self, it): """ Checks whether an iterator is part of the "Emerge" section. @param it: the iterator to check @type it: Iterator @returns: True if the iter is part; False otherwise @rtype: boolean """ return self.is_in(it, self.emergeIt) def is_in_unmerge (self, it): """ Checks whether an iterator is part of the "Unmerge" section. @param it: the iterator to check @type it: Iterator @returns: True if the iter is part; False otherwise @rtype: boolean """ return self.is_in(it, self.unmergeIt) def is_in_update (self, it): """ Checks whether an iterator is part of the "Update" section. @param it: the iterator to check @type it: Iterator @returns: True if the iter is part; False otherwise @rtype: boolean """ return self.is_in(it, self.updateIt) def iter_has_parent (self, it): """ Returns whether the actual iterator has a parent. @param it: the iterator @type it: Iterator @returns: True if it has a parent it, else False. @rtype: boolean """ return (self.tree.iter_parent(it) != None) def parent_iter (self, it): """ Returns the parent iter. @param it: the iterator @type it: Iterator @returns: Parent iterator or None if the current it has no parent. @rtype: Iterator; None """ return self.tree.iter_parent(it) def first_child_iter (self, it): """ Returns the first child iter. @param it: the iterator @type it: Iterator @returns: First child iterator or None if the current it has no children. @rtype: Iterator; None """ return self.tree.iter_children(it) def iter_has_children (self, it): """ Returns whether the actual iterator has children. @param it: the iterator @type it: Iterator @returns: True if it has children, else False. @rtype: boolean """ return self.tree.iter_has_child(it) def next_iter (self, it): """ Returns the next iter. @param it: the iterator @type it: Iterator @returns: Next iterator or None if the current iter is the last one. @rtype: Iterator; None """ return self.tree.iter_next(it) def get_value (self, it, column): """ Returns the value of the specific column at the given iterator. @param it: the iterator @type it: Iterator @param column: the column of the iterator from where to get the value @type column: int @returns: the value @rtype: anything """ return self.tree.get_value(it, column) def iter_equal (self, it, other_it): """ Checks whether to iterators are equal. @param it: the one iterator to compare @type it: Iterator @param other_it: the other iterator to compare @type other_it: Iterator @returns: True if both iterators are equal; False otherwise @rtype boolean """ return self.tree.get_string_from_iter(it) == self.tree.get_string_from_iter(other_it) def append (self, parent = None, values = None): """ Appends some values right after the given parent. If parent is None, it is appended as the first element. @param parent: the iterator to append the values right after; if None it symbolizes the top @type parent: Iterator @param values: a list of values which are going to be appended to the tree @type values: list @returns: Iterator pointing to the newly appended stuff @rtype: Iterator """ return self.tree.append(parent, values) def remove (self, it): """ Removes an iterator out of the tree. @attention: The iterator can point to anything hereafter. Do not reuse! @param it: iterator to remove @type it: Iterator """ if self.emergeIt and self.iter_equal(it, self.emergeIt) : self.emergeIt = None elif self.unmergeIt and self.iter_equal(it, self.unmergeIt) : self.unmergeIt = None elif self.updateIt and self.iter_equal(it, self.updateIt) : self.updateIt = None self.tree.remove(it) def get_original (self): """ Returns the original tree-object. @returns: original tree-object @rtype: tree-object """ return self.tree def get_cpv_column (self): """ Returns the number of the column where the cpv's are stored. @returns: column with cpv's @rtype: int """ return self.cpv_col