]> SALOME platform Git repositories - modules/eficas.git/commitdiff
Salome HOME
PN : livre dans cataSTAx
authorPascale Noyret <pascale.noyret@edf.fr>
Mon, 27 Nov 2006 15:43:27 +0000 (15:43 +0000)
committerPascale Noyret <pascale.noyret@edf.fr>
Mon, 27 Nov 2006 15:43:27 +0000 (15:43 +0000)
Aster/Cata/ops.py [deleted file]

diff --git a/Aster/Cata/ops.py b/Aster/Cata/ops.py
deleted file mode 100644 (file)
index 088e956..0000000
+++ /dev/null
@@ -1,448 +0,0 @@
-#@ MODIF ops Cata  DATE 08/11/2005   AUTEUR D6BHHJP J.P.LEFEBVRE 
-# -*- coding: iso-8859-1 -*-
-#            CONFIGURATION MANAGEMENT OF EDF VERSION
-# ======================================================================
-# COPYRIGHT (C) 1991 - 2001  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.                                 
-#
-# 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.                            
-#
-# 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.      
-# ======================================================================
-
-
-# Modules Python
-import types
-import string,linecache,os,traceback,re
-import pickle
-
-# Modules Eficas
-import Accas
-from Accas import ASSD
-from Utilitai.Utmess import UTMESS
-
-try:
-   import aster
-   # Si le module aster est présent, on le connecte
-   # au JDC
-   import Build.B_CODE
-   Build.B_CODE.CODE.codex=aster
-except:
-   pass
-
-def DEBUT(self,PAR_LOT,IMPR_MACRO,CODE,DEBUG,**args):
-   """
-       Fonction sdprod de la macro DEBUT
-   """
-   # La commande DEBUT ne peut exister qu'au niveau jdc
-   if self.jdc is not self.parent :
-      raise Accas.AsException("La commande DEBUT ne peut exister qu'au niveau jdc")
-
-   self.jdc.impr_macro=IMPR_MACRO
-   self.jdc.jxveri=0
-   if DEBUG!=None :
-      if DEBUG['JXVERI']=='OUI' : self.jdc.jxveri=1
-   self.jdc.set_par_lot(PAR_LOT)
-   if CODE!=None :
-      self.jdc.fico=CODE['NOM']
-   else:
-      self.jdc.fico=None
-
-def build_debut(self,**args):
-   """
-   Fonction ops pour la macro DEBUT
-   """
-   self.jdc.UserError=self.codex.error
-
-   if self.jdc.par_lot == 'NON' :
-      self.jdc._Build()
-   # On execute la fonction debut pour initialiser les bases
-   # Cette execution est indispensable avant toute autre action sur ASTER
-   # op doit etre un entier car la fonction debut appelle GCECDU qui demande
-   # le numero de l'operateur associé (getoper)
-   self.definition.op=0
-   self.set_icmd(1)
-   lot,ier=self.codex.debut(self,1)
-   # On remet op a None juste apres pour eviter que la commande DEBUT
-   # ne soit executée dans la phase d'execution
-   self.definition.op=None
-   return ier
-
-def POURSUITE(self,PAR_LOT,IMPR_MACRO,CODE,DEBUG,**args):
-   """
-       Fonction sdprod de la macro POURSUITE
-   """
-   # La commande POURSUITE ne peut exister qu'au niveau jdc
-   if self.jdc is not self.parent :
-      raise Accas.AsException("La commande POURSUITE ne peut exister qu'au niveau jdc")
-
-   self.jdc.impr_macro=IMPR_MACRO
-   self.jdc.set_par_lot(PAR_LOT)
-   self.jdc.jxveri=0
-   if DEBUG!=None :
-      if DEBUG['JXVERI']=='OUI' : self.jdc.jxveri=1
-   if CODE!=None :
-      self.jdc.fico=CODE['NOM']
-   else:
-      self.jdc.fico=None
-   if (self.codex and os.path.isfile("glob.1") or os.path.isfile("bhdf.1")):
-     # Le module d'execution est accessible et glob.1 est present
-     # Pour eviter de rappeler plusieurs fois la sequence d'initialisation
-     # on memorise avec l'attribut fichier_init que l'initialisation
-     # est réalisée
-     if hasattr(self,'fichier_init'):return
-     self.fichier_init='glob.1'
-     self.jdc.initexec()
-     # le sous programme fortran appelé par self.codex.poursu demande le numero
-     # de l'operateur (GCECDU->getoper), on lui donne la valeur 0
-     self.definition.op=0
-     lot,ier,lonuti,concepts=self.codex.poursu(self,1)
-     # Par la suite pour ne pas executer la commande pendant la phase
-     # d'execution on le remet à None
-     self.definition.op=None
-     # On demande la numerotation de la commande POURSUITE avec l'incrément
-     # lonuti pour qu'elle soit numérotée à la suite des commandes existantes.
-####CD     self.set_icmd(lonuti)
-     pos=0
-     d={}
-     while pos+80 < len(concepts)+1:
-       nomres=concepts[pos:pos+8]
-       concep=concepts[pos+8:pos+24]
-       nomcmd=concepts[pos+24:pos+40]
-       statut=concepts[pos+40:pos+48]
-       print nomres,concep,nomcmd,statut
-       if nomres[0] not in (' ','.','&') and statut != '&DETRUIT':
-          exec nomres+'='+string.lower(concep)+'()' in self.parent.g_context,d
-       pos=pos+80
-     for k,v in d.items():
-       self.parent.NommerSdprod(v,k)
-     self.g_context=d
-
-     # Il peut exister un contexte python sauvegardé sous forme  pickled
-     # On récupère ces objets après la restauration des concepts pour que
-     # la récupération des objets pickled soit prioritaire.
-     # On vérifie que les concepts relus dans glob.1 sont bien tous
-     # presents sous le meme nom et du meme type dans pick.1
-     # Le contexte est ensuite updaté (surcharge) et donc enrichi des
-     # variables qui ne sont pas des concepts.
-     # On supprime du pickle_context les concepts valant None, ca peut 
-     # etre le cas des concepts non executés, placés après FIN.
-     pickle_context=get_pickled_context()
-     if pickle_context==None :
-        UTMESS('F','Poursuite',"Erreur a la relecture du fichier pick.1 : aucun objet sauvegardé ne sera récupéré")
-        return
-     from Cata.cata  import ASSD,entier
-     from Noyau.N_CO import CO
-     for elem in pickle_context.keys():
-         if type(pickle_context[elem])==types.InstanceType :
-            pickle_class=pickle_context[elem].__class__
-            if elem in self.g_context.keys():
-               poursu_class=self.g_context[elem].__class__
-               if poursu_class!=pickle_class :
-                  UTMESS('F','Poursuite',"Types incompatibles entre glob.1 et pick.1 pour concept de nom "+elem)
-                  return
-            elif isinstance(pickle_context[elem],ASSD) and pickle_class not in (CO,entier) : 
-            # on n'a pas trouvé le concept dans la base et sa classe est ASSD : ce n'est pas normal
-            # sauf dans le cas de CO : il n'a alors pas été typé et c'est normal qu'il soit absent de la base
-            # meme situation pour le type 'entier' produit uniquement par DEFI_FICHIER
-               UTMESS('F','Poursuite',"Concept de nom "+elem+" et de type "+str(pickle_class)+" introuvable dans la base globale")
-               return
-         if pickle_context[elem]==None : del pickle_context[elem]
-     self.g_context.update(pickle_context)
-     return
-
-   else:
-     # Si le module d'execution n est pas accessible ou glob.1 absent on 
-     # demande un fichier (EFICAS)
-     # Il faut éviter de réinterpréter le fichier à chaque appel de
-     # POURSUITE
-     if hasattr(self,'fichier_init'):
-        return
-     self.make_poursuite()
-
-def get_pickled_context():
-    """
-       Cette fonction permet de réimporter dans le contexte courant du jdc (jdc.g_context)
-       les objets python qui auraient été sauvegardés, sous forme pickled, lors d'une 
-       précédente étude. Un fichier pick.1 doit etre présent dans le répertoire de travail
-    """
-    if os.path.isfile("pick.1"):
-       file="pick.1"
-    else: return None
-   
-    # Le fichier pick.1 est présent. On essaie de récupérer les objets python sauvegardés
-    context={}
-    try:
-       file=open(file,'r')
-       # Le contexte sauvegardé a été picklé en une seule fois. Il est seulement
-       # possible de le récupérer en bloc. Si cette opération echoue, on ne récupère
-       # aucun objet.
-       context=pickle.load(file)
-       file.close()
-    except:
-       # En cas d'erreur on ignore le contenu du fichier
-       # traceback.print_exc()
-       return None
-
-    return context
-
-def POURSUITE_context(self,d):
-   """
-       Fonction op_init de la macro POURSUITE
-   """
-   # self représente la macro POURSUITE ...
-   d.update(self.g_context)
-   # Une commande POURSUITE n'est possible qu'au niveau le plus haut
-   # On ajoute directement les concepts dans le contexte du jdc
-   # XXX est ce que les concepts ne sont pas ajoutés plusieurs fois ??
-   for v in self.g_context.values():
-      if isinstance(v,ASSD) : self.jdc.sds.append(v)
-
-def build_poursuite(self,**args):
-   """
-   Fonction ops pour la macro POURSUITE
-   """
-   # Pour POURSUITE on ne modifie pas la valeur initialisee dans ops.POURSUITE
-   # Il n y a pas besoin d executer self.codex.poursu (c'est deja fait dans
-   # la fonction sdprod de la commande (ops.POURSUITE))
-   self.set_icmd(1)
-   self.jdc.UserError=self.codex.error
-   return 0
-
-def INCLUDE(self,UNITE,**args):
-   """ 
-       Fonction sd_prod pour la macro INCLUDE
-   """
-   if not UNITE : return
-   if hasattr(self,'unite'):return
-   self.unite=UNITE
-
-   if self.jdc and self.jdc.par_lot == 'NON':
-      # On est en mode commande par commande, on appelle la methode speciale
-      self.Execute_alone()
-
-   self.make_include(unite=UNITE)
-
-def INCLUDE_context(self,d):
-   """ 
-       Fonction op_init pour macro INCLUDE
-   """
-   for k,v in self.g_context.items():
-      d[k]=v
-
-def build_include(self,**args):
-   """
-   Fonction ops de la macro INCLUDE appelée lors de la phase de Build
-   """
-   # Pour presque toutes les commandes (sauf FORMULE et POURSUITE)
-   # le numero de la commande n est pas utile en phase de construction
-   # La macro INCLUDE ne sera pas numérotée (incrément=None)
-   ier=0
-   self.set_icmd(None)
-   icmd=0
-   # On n'execute pas l'ops d'include en phase BUILD car il ne sert a rien.
-   #ier=self.codex.opsexe(self,icmd,-1,1)
-   return ier
-
-def detruire(self,d):
-   """
-       Cette fonction est la fonction op_init de la PROC DETRUIRE
-   """
-   if self["CONCEPT"]!=None:
-     sd=[]
-     for mc in self["CONCEPT"]:
-       mcs=mc["NOM"]
-       if mcs is None:continue
-       if type(mcs) == types.ListType or type(mcs) == types.TupleType:
-         for e in mcs:
-           if isinstance(e,ASSD):
-             sd.append(e)
-             e=e.nom
-       # traitement particulier pour les listes de concepts, on va mettre à None
-       # le terme de l'indice demandé dans la liste :
-       # nomconcept_i est supprimé, nomconcept[i]=None
-           indice=e[e.rfind('_')+1:]
-           concept_racine=e[:e.rfind('_')]
-           if indice!='' and d.has_key(concept_racine) and type(d[concept_racine])==types.ListType:
-              try               :
-                                  indici=int(indice)
-                                  d[concept_racine][indici]=None
-              except ValueError : pass
-       # pour tous les concepts :
-           if d.has_key(e):del d[e]
-           if self.jdc.sds_dict.has_key(e):del self.jdc.sds_dict[e]
-       else:
-         if isinstance(mcs,ASSD):
-           sd.append(mcs)
-           mcs=mcs.nom
-       # traitement particulier pour les listes de concepts, on va mettre à None
-       # le terme de l'indice demandé dans la liste :
-       # nomconcept_i est supprimé, nomconcept[i]=None
-         indice=mcs[mcs.rfind('_')+1:]
-         concept_racine=mcs[:mcs.rfind('_')]
-         if indice!='' and d.has_key(concept_racine) and type(d[concept_racine])==types.ListType:
-            try               :
-                                indici=int(indice)
-                                d[concept_racine][indici]=None
-            except ValueError : pass
-       # pour tous les concepts :
-         if d.has_key(mcs):del d[mcs]
-         if self.jdc.sds_dict.has_key(mcs):del self.jdc.sds_dict[mcs]
-     for s in sd:
-       # On signale au parent que le concept s n'existe plus apres l'étape self 
-       self.parent.delete_concept_after_etape(self,s)
-
-def subst_materiau(text,NOM_MATER,EXTRACTION,UNITE_LONGUEUR):
-   """
-       Cette fonction retourne un texte obtenu à partir du texte passé en argument (text)
-       en substituant le nom du materiau par NOM_MATER 
-       et en réalisant les extractions spéciifées dans EXTRACTION
-   """
-   lines=string.split(text,'\n')
-
-##### traitement de UNIT : facteur multiplicatif puissance de 10
-   regmcsu=re.compile(r" *(.*) *= *([^ ,]*) *## +([^ ]*) *([^ ]*)")
-   ll_u=[]
-   for l in lines:
-       m=regmcsu.match(l)
-       if m:
-          if m.group(3) == "UNIT":
-             if   UNITE_LONGUEUR=='M'  : coef = '0'
-             elif UNITE_LONGUEUR=='MM' : coef = m.group(4)
-             ll_u.append(m.group(1)+" = "+m.group(2)+coef)
-          else : ll_u.append(l)
-       else : ll_u.append(l)
-
-##### traitement de EXTRACTION
-   if EXTRACTION:
-     regmcf=re.compile(r" *(.*) *= *_F\( *## +(.*) +(.*)")
-     regmcs=re.compile(r" *(.*) *= *([^ ,]*) *, *## +([^ ]*) *([^ ]*)")
-     regfin=re.compile(r" *\) *")
-     ll=[]
-     temps={};lmcf=[]
-     for e in EXTRACTION:
-       mcf=e['COMPOR']
-       lmcf.append(mcf)
-       temps[mcf]=e['TEMP_EVAL']
-     FLAG=0
-     for l in ll_u:
-       m=regmcf.match(l)
-       if m: # On a trouve un mot cle facteur "commentarise"
-         if m.group(2) == "SUBST": # il est de plus substituable
-           if temps.has_key(m.group(3)): # Il est a substituer
-             ll.append(" "+m.group(3)+"=_F(")
-             mcf=m.group(3)
-             TEMP=temps[mcf]
-             FLAG=1 # Indique que l'on est en cours de substitution
-           else: # Il n est pas a substituer car il n est pas dans la liste demandee
-             ll.append(l)
-         else: # Mot cle facteur commentarise non substituable
-           ll.append(l)
-       else:  # La ligne ne contient pas un mot cle facteur commentarise
-         if FLAG == 0: # On n est pas en cours de substitution
-           ll.append(l)
-         else: # On est en cours de substitution. On cherche les mots cles simples commentarises
-           m=regmcs.match(l)
-           if m: # On a trouve un mot cle simple commentarise
-             if m.group(3) == "EVAL":
-               ll.append("  "+m.group(1)+' = '+m.group(4)+"("+str(TEMP)+'),')
-             elif m.group(3) == "SUPPR":
-               pass
-             else:
-               ll.append(l)
-           else: # On cherche la fin du mot cle facteur en cours de substitution
-             m=regfin.match(l)
-             if m: # On l a trouve. On le supprime de la liste
-               FLAG=0
-               del temps[mcf]
-             ll.append(l)
-   else:
-     ll=ll_u
-
-   lines=ll
-   ll=[]
-   for l in lines:
-     l=re.sub(" *MAT *= *",NOM_MATER+" = ",l,1)
-     ll.append(l)
-   text=string.join(ll,'\n')
-   return text
-
-def post_INCLUDE(self):
-  """
-      Cette fonction est executée apres toutes les commandes d'un INCLUDE (RETOUR)
-      Elle sert principalement pour les INCLUDE_MATERIAU : remise a blanc du prefixe Fortran
-  """
-  self.codex.opsexe(self,0,-1,2)
-
-def INCLUDE_MATERIAU(self,NOM_AFNOR,TYPE_MODELE,VARIANTE,TYPE_VALE,NOM_MATER,
-                    EXTRACTION,UNITE_LONGUEUR,INFO,**args):
-  """ 
-      Fonction sd_prod pour la macro INCLUDE_MATERIAU
-  """
-  mat=string.join((NOM_AFNOR,'_',TYPE_MODELE,'_',VARIANTE,'.',TYPE_VALE),'')
-  if not hasattr(self,'mat') or self.mat != mat or self.nom_mater != NOM_MATER :
-    # On récupère le répertoire des matériaux dans les arguments 
-    # supplémentaires du JDC
-    rep_mat=self.jdc.args.get("rep_mat","NOrep_mat")
-    f=os.path.join(rep_mat,mat)
-    self.mat=mat
-    self.nom_mater=NOM_MATER
-    if not os.path.isfile(f):
-       del self.mat
-       self.make_contexte(f,"#Texte sans effet pour reinitialiser le contexte a vide\n")
-       raise "Erreur sur le fichier materiau: "+f
-    # Les materiaux sont uniquement disponibles en syntaxe Python
-    # On lit le fichier et on supprime les éventuels \r
-    text=string.replace(open(f).read(),'\r\n','\n')
-    # On effectue les substitutions necessaires
-    self.prefix=NOM_MATER
-    self.text= subst_materiau(text,NOM_MATER,EXTRACTION,UNITE_LONGUEUR)
-    if INFO == 2:
-      print "INCLUDE_MATERIAU: ", self.mat,' ',NOM_MATER,'\n'
-      print self.text
-    # on execute le texte fourni dans le contexte forme par
-    # le contexte de l etape pere (global au sens Python)
-    # et le contexte de l etape (local au sens Python)
-    # Il faut auparavant l'enregistrer aupres du module linecache (utile pour nommage.py)
-    linecache.cache[f]=0,0,string.split(self.text,'\n'),f
-
-    self.postexec=post_INCLUDE
-
-    if self.jdc.par_lot == 'NON':
-      # On est en mode commande par commande, on appelle la methode speciale
-      self.Execute_alone()
-
-    self.make_contexte(f,self.text)
-    for k,v in self.g_context.items() :
-        if isinstance(v,ASSD) and k!=v.nom : del self.g_context[k]
-
-def build_procedure(self,**args):
-    """
-    Fonction ops de la macro PROCEDURE appelée lors de la phase de Build
-    """
-    ier=0
-    # Pour presque toutes les commandes (sauf FORMULE et POURSUITE)
-    # le numero de la commande n est pas utile en phase de construction
-    # On ne numérote pas une macro PROCEDURE (incrément=None)
-    self.set_icmd(None)
-    icmd=0
-    #ier=self.codex.opsexe(self,icmd,-1,3)
-    return ier
-
-def build_DEFI_FICHIER(self,**args):
-    """
-    Fonction ops de la macro DEFI_FICHIER
-    """
-    ier=0
-    self.set_icmd(1)
-    icmd=0
-    ier=self.codex.opsexe(self,icmd,-1,26)
-    return ier