Salome HOME
CCAR : quelques modifs sur convertisseur python (liste de MCFACT)
[tools/eficas.git] / Editeur / comploader.py
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.
9 #
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.
14 #
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.
18 #
19 #
20 # ======================================================================
21 """
22    Module de chargement des composants et de mapping des objets du noyau
23    Accas vers les items d'EFICAS
24
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.
33 """
34 # import généraux
35 import os,glob,types
36
37 # Dictionnaire {object : item} permettant d'associer un item à un object
38 # Ce dictionnaire est renseigné par la méthode charger_composants 
39 composants = {}
40
41 def charger_composants():
42     """
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
46     """
47     repertoire=os.path.dirname(__file__)
48     listfich=glob.glob(os.path.join(repertoire, "compo*.py"))
49     for fichier in listfich:
50         m= os.path.basename(fichier)[:-3]
51         module=__import__(m,globals(),locals())
52         composants[module.objet]=module.treeitem
53     return composants
54
55 def gettreeitem(object):
56     """
57       Cette fonction retourne la classe item associée à l'objet object.
58       Cette classe item dépend bien sûr de la nature de object, d'où
59       l'interrogation du dictionnaire composants
60     """
61     if type(object) == types.InstanceType:
62        # Si la definition de l'objet a un attribut itemeditor, il indique 
63        # la classe a utiliser pour l'item
64        try:
65           return object.definition.itemeditor
66        except:
67           pass
68
69        # On cherche ensuite dans les composants (plugins)
70        try:
71            itemtype= composants[object.__class__]
72            return itemtype
73        except:
74            pass
75
76        # Puis une eventuelle classe heritee (aleatoire car sans ordre)
77        for e in composants.keys():
78            if isinstance(object,e):
79               itemtype= composants[e]
80               return itemtype
81
82     # Si on n'a rien trouve dans les composants on utilise l'objet par defaut
83     itemtype=ObjectTreeItem
84     return itemtype
85
86 def make_objecttreeitem(appli,labeltext, object, setfunction=None):
87     """
88        Cette fonction permet de construire et de retourner un objet
89        de type item associé à l'object passé en argument.
90     """
91     c = gettreeitem(object)
92     return c(appli,labeltext, object, setfunction)
93
94