]> SALOME platform Git repositories - tools/eficas.git/blobdiff - Editeur/comploader.py
Salome HOME
onItem=Deplie
[tools/eficas.git] / Editeur / comploader.py
index 771fa116416a0ac3e5451f0b5f2f1ed139acafcf..cb1f9ebffb5774ee3fb82eaef1a188b7e3b6aa62 100644 (file)
@@ -1,35 +1,34 @@
 # -*- coding: utf-8 -*-
-#            CONFIGURATION MANAGEMENT OF EDF VERSION
-# ======================================================================
-# COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
-# THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
-# IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
-# THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
-# (AT YOUR OPTION) ANY LATER VERSION.
+# Copyright (C) 2007-2013   EDF R&D
 #
-# THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
-# WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
-# MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
-# GENERAL PUBLIC LICENSE FOR MORE DETAILS.
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License.
 #
-# YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
-# ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
-#    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
 #
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
+#
+# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
 #
-# ======================================================================
 """
    Module de chargement des composants et de mapping des objets du noyau
    Accas vers les items d'EFICAS
 
-   - composants : dictionnaire de stockage des relations entre types
-     d'objet du noyau et types d'item
-   - charger_composants() : fonction de chargement des composants. Retourne
-     le dictionnaire composants.
-   - gettreeitem(object) -> type d'item : fonction qui retourne un type
-     d'item correspondant au type de l'objet noyau fourni.
-   - make_objecttreeitem(appli,labeltext, object, setfunction=None) -> item : fonction qui retourne un item
-     correspondant à l'objet noyau fourni.
+     - composants : dictionnaire de stockage des relations entre types
+       d'objet du noyau et types d'item
+     - charger_composants() : fonction de chargement des composants. Retourne
+       le dictionnaire composants.
+     - gettreeitem(object) -> type d'item : fonction qui retourne un type
+       d'item correspondant au type de l'objet noyau fourni.
+     - make_objecttreeitem(appli,labeltext, object, setfunction=None) -> item : fonction qui retourne un item
+       correspondant à l'objet noyau fourni.
 """
 # import généraux
 import os,glob,types
@@ -38,17 +37,26 @@ import os,glob,types
 # Ce dictionnaire est renseigné par la méthode charger_composants 
 composants = {}
 
-def charger_composants():
+def charger_composants(Ihm="TK"):
     """
         Cette fonction a pour but de charger tous les modules composants graphiques
         (fichiers compo*.py dans le même répertoire que ce module )
         et de remplir le dictionnaire composants utilisé par make_objecttreeitem
     """
-    repertoire=os.path.dirname(__file__)
+    reper=os.path.dirname(__file__)
+    if Ihm == "TK" :
+       repertoire=reper+"/../InterfaceTK"
+       package="InterfaceTK"
+    else :
+       repertoire=reper+"/../InterfaceQT4"
+       package="InterfaceQT4"
+       #repertoire=reper+"/../InterfaceQT"
+       #package="InterfaceQT"
     listfich=glob.glob(os.path.join(repertoire, "compo*.py"))
     for fichier in listfich:
         m= os.path.basename(fichier)[:-3]
-        module=__import__(m,globals(),locals())
+        module=__import__(package,globals(),locals(),[m])
+        module = getattr(module, m)
         composants[module.objet]=module.treeitem
     return composants
 
@@ -58,32 +66,28 @@ def gettreeitem(object):
       Cette classe item dépend bien sûr de la nature de object, d'où
       l'interrogation du dictionnaire composants
     """
-    if type(object) == types.InstanceType:
-       # Si la definition de l'objet a un attribut itemeditor, il indique 
-       # la classe a utiliser pour l'item
-       try:
-          return object.definition.itemeditor
-       except:
-          pass
+    # Si la definition de l'objet a un attribut itemeditor, il indique 
+    # la classe a utiliser pour l'item
+    try:
+       return object.definition.itemeditor
+    except:
+       pass
 
-       # On cherche ensuite dans les composants (plugins)
-       try:
-           itemtype= composants[object.__class__]
-           return itemtype
-       except:
-           pass
+    # On cherche ensuite dans les composants (plugins)
+    try:
+       itemtype= composants[object.__class__]
+       return itemtype
+    except:
+       pass
 
-       # Puis une eventuelle classe heritee (aleatoire car sans ordre)
-       for e in composants.keys():
-           if isinstance(object,e):
-              itemtype= composants[e]
-              return itemtype
+    # Puis une eventuelle classe heritee (aleatoire car sans ordre)
+    for e in composants.keys():
+        if e and isinstance(object,e):
+           itemtype= composants[e]
+           return itemtype
 
-    # Apres poum ??? Les lignes suivantes sont elles utiles ?
     # Si on n'a rien trouve dans les composants on utilise l'objet par defaut
-    print ObjectTreeItem
-    print itemtype
-    itemtype=ObjectTreeItem
+    itemtype=composants[None]
     return itemtype
 
 def make_objecttreeitem(appli,labeltext, object, setfunction=None):
@@ -92,5 +96,6 @@ def make_objecttreeitem(appli,labeltext, object, setfunction=None):
        de type item associé à l'object passé en argument.
     """
     c = gettreeitem(object)
+    #print appli,labeltext, object, setfunction
     return c(appli,labeltext, object, setfunction)