1 # -*- coding: utf-8 -*-
2 # CONFIGURATION MANAGEMENT OF EDF VERSION
3 # ======================================================================
4 # COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
5 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
6 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
7 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
8 # (AT YOUR OPTION) ANY LATER VERSION.
10 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
11 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
12 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
13 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
15 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
16 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
17 # 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
20 # ======================================================================
22 Module de chargement des composants et de mapping des objets du noyau
23 Accas vers les items d'EFICAS
25 - composants : dictionnaire de stockage des relations entre types
26 d'objet du noyau et types d'item
27 - charger_composants() : fonction de chargement des composants. Retourne
28 le dictionnaire composants.
29 - gettreeitem(object) -> type d'item : fonction qui retourne un type
30 d'item correspondant au type de l'objet noyau fourni.
31 - make_objecttreeitem(appli,labeltext, object, setfunction=None) -> item : fonction qui retourne un item
32 correspondant à l'objet noyau fourni.
37 # Dictionnaire {object : item} permettant d'associer un item à un object
38 # Ce dictionnaire est renseigné par la méthode charger_composants
41 def charger_composants(Ihm="TK"):
43 Cette fonction a pour but de charger tous les modules composants graphiques
44 (fichiers compo*.py dans le même répertoire que ce module )
45 et de remplir le dictionnaire composants utilisé par make_objecttreeitem
47 reper=os.path.dirname(__file__)
49 repertoire=reper+"/../InterfaceTK"
52 repertoire=reper+"/../InterfaceQT4"
53 package="InterfaceQT4"
54 #repertoire=reper+"/../InterfaceQT"
55 #package="InterfaceQT"
56 listfich=glob.glob(os.path.join(repertoire, "compo*.py"))
57 for fichier in listfich:
58 m= os.path.basename(fichier)[:-3]
59 module=__import__(package,globals(),locals(),[m])
60 module = getattr(module, m)
61 composants[module.objet]=module.treeitem
64 def gettreeitem(object):
66 Cette fonction retourne la classe item associée à l'objet object.
67 Cette classe item dépend bien sûr de la nature de object, d'où
68 l'interrogation du dictionnaire composants
70 # Si la definition de l'objet a un attribut itemeditor, il indique
71 # la classe a utiliser pour l'item
73 return object.definition.itemeditor
77 # On cherche ensuite dans les composants (plugins)
79 itemtype= composants[object.__class__]
84 # Puis une eventuelle classe heritee (aleatoire car sans ordre)
85 for e in composants.keys():
86 if e and isinstance(object,e):
87 itemtype= composants[e]
90 # Si on n'a rien trouve dans les composants on utilise l'objet par defaut
91 itemtype=composants[None]
94 def make_objecttreeitem(appli,labeltext, object, setfunction=None):
96 Cette fonction permet de construire et de retourner un objet
97 de type item associé à l'object passé en argument.
99 c = gettreeitem(object)
100 return c(appli,labeltext, object, setfunction)