]> SALOME platform Git repositories - tools/eficas.git/blob - Editeur/eficas_test.py
Salome HOME
PN pour homard
[tools/eficas.git] / Editeur / eficas_test.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     Ce module permet de lancer l'application EFICAS en affichant
23     un ecran Splash pour faire patentier l'utilisateur
24 """
25 # Modules Python
26 import Tkinter
27
28 # Modules Eficas
29 import import_code
30
31 def lance_eficas(code,fichier=None):
32     """
33         Lance l'appli EFICAS
34     """
35
36     root = Tkinter.Tk()
37     import eficas
38     if fichier :
39         a=eficas.EFICAS(root,code=code,fichier = fichier,test=1)
40         bureau=a.getBureau()
41     else:
42         eficas.EFICAS(root,code=code)
43
44     print bureau.JDC.report()
45     bureau.closeJDC()
46
47 def duplique_fichier(code,fichier=None,root=None):
48     print code
49     print fichier
50     if root == None :
51        root = Tkinter.Tk()
52     import eficas
53     import convert
54     import generator
55     import utils
56     import string
57
58     appli=eficas.EFICAS(root,code=code,fichier = fichier,test=1)
59     format='homard'
60     if convert.plugins.has_key(format):
61        p=convert.plugins[format]()
62        p.readfile(fichier)
63        text=p.convert('exec',appli)
64        text2=convertir(text)
65        cata=appli.readercata.cata
66        J=cata[0].JdC(procedure=text2,cata=cata)
67        J.analyse()
68        fileName=fichier+"_init"
69        if generator.plugins.has_key(format):
70           g=generator.plugins[format]()
71           jdc_formate=g.gener(J,format='beautifie')
72           print jdc_formate
73           jdc_fini = string.replace(jdc_formate,'\r\n','\n')
74           print jdc_fini
75           utils.save_in_file(fileName+".comm",jdc_fini)
76
77 def convertir(texte):
78     import re
79     dict_change={"FICHIER_MED_MAILLAGE_N=":"FICHIER_MED_MAILLAGE_NP1","NOM_MED_MAILLAGE_N=":"NOM_MED_MAILLAGE_NP1"}
80     for mot in dict_change.keys():
81         if( re.search(mot,texte)):
82           indicenouveau=re.search(mot,texte).end()
83           indicefinnouveau= texte.find(",",indicenouveau)
84           avant=dict_change[mot]
85           if( re.search(avant,texte)):
86              indiceancien=re.search(avant,texte).end()+1
87              indicefinancien= texte.find(",",indiceancien)
88              valeur=texte[indiceancien:indicefinancien]
89              texte=texte[0:indicenouveau]+valeur+texte[indicefinnouveau:]
90     liste_mot_clef_None=['CRIT_RAFF_ABS','CRIT_RAFF_REL','CRIT_RAFF_PE','CRIT_DERA_ABS','CRIT_DERA_REL','CRIT_DERA_PE','NITER','NOM_MED_MAILLAGE_NP1','FICHIER_MED_MAILLAGE_NP1']
91
92     for mot in liste_mot_clef_None:
93         if( re.search(mot,texte)):
94            indice=re.search(mot,texte).end()+1
95            indicefin= texte.find(",",indice)
96            texte=texte[0:indice]+"None"+texte[indicefin:]
97     return texte
98