1 # -*- coding: utf-8 -*-
\r
2 # Copyright (C) 2007-2013 EDF R&D
\r
4 # This library is free software; you can redistribute it and/or
\r
5 # modify it under the terms of the GNU Lesser General Public
\r
6 # License as published by the Free Software Foundation; either
\r
7 # version 2.1 of the License.
\r
9 # This library is distributed in the hope that it will be useful,
\r
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
\r
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
\r
12 # Lesser General Public License for more details.
\r
14 # You should have received a copy of the GNU Lesser General Public
\r
15 # License along with this library; if not, write to the Free Software
\r
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
\r
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
\r
21 Ce module sert pour charger les parametres de configuration d'EFICAS
\r
24 import os, sys, string, types, re
\r
26 from PyQt4.QtGui import QMessageBox
\r
27 from Editeur.utils import read_file
\r
28 from Extensions.i18n import tr
\r
32 #-------------------------------
\r
33 def __init__(self,appli,repIni):
\r
34 #-------------------------------
\r
36 # Classe de base permettant de lire, afficher
\r
37 # et sauvegarder les fichiers utilisateurs
\r
38 # On a deux directories : la directory generale (Repertoire d install + Nom du code
\r
39 # Par exemple : ~/Install_Eficas/EficasV1_14/Openturns_Wrapper
\r
40 # et la directorie de l utilisateur
\r
41 # HOME/.Eficas_Openturns
\r
42 # Le fichier prefs.py va etre lu dans la directory generale
\r
43 # puis surcharge eventuellement par celui contenu dans ${PREFS_CATA_$CODE}
\r
44 # par celui de l utilisateur
\r
45 # le fichier de catalogue va etre lu dans la directory de l utilisateur s il exite
\r
46 # dans le fichier general sinon
\r
48 self.code = appli.code
\r
49 self.salome = appli.salome
\r
50 if self.salome : self.name="editeur_salome.ini"
\r
51 else : self.name="editeur.ini"
\r
53 self.repIni = repIni
\r
54 if sys.platform[0:5]=="linux" :
\r
55 self.rep_user = os.path.join(os.environ['HOME'],'.config/Eficas',appli.code)
\r
57 self.rep_user = os.path.join('C:/','.config/Eficas',appli.code)
\r
61 self.setValeursParDefaut()
\r
63 self.lecture_fichier_ini_standard()
\r
64 self.lecture_fichier_ini_integrateur()
\r
65 self.lecture_fichier_ini_utilisateur()
\r
67 #Particularite des schemas MAP
\r
68 if hasattr(self,'make_ssCode'): self.make_ssCode(self.ssCode)
\r
70 if self.appli: self.parent=appli.top
\r
71 else: self.parent=None
\r
73 if not os.path.isdir(self.savedir) :
\r
74 if sys.platform[0:5]=="linux" :
\r
75 self.savedir=os.environ['HOME']
\r
81 def setValeursParDefaut(self):
\r
82 #-----------------------------
\r
84 # Valeurs par defaut
\r
85 if not os.path.isdir(self.rep_user) : os.makedirs(self.rep_user)
\r
86 self.path_doc = os.path.abspath(os.path.join(self.repIni,'..','Doc'))
\r
87 self.exec_acrobat = 'acroread'
\r
88 nomDir="Eficas_"+self.code
\r
89 if sys.platform[0:5]=="linux" :
\r
90 self.savedir = os.path.abspath(os.path.join(os.environ['HOME'],nomDir))
\r
92 self.savedir = os.path.abspath('C:/')
\r
93 self.mode_nouv_commande='initial'
\r
94 self.affiche="alpha"
\r
96 #--------------------------------------
\r
97 def lecture_fichier_ini_standard(self):
\r
98 #--------------------------------------
\r
100 name='prefs_'+self.appli.code
\r
101 prefsCode=__import__(name)
\r
102 for k in dir(prefsCode):
\r
103 if (k[0:1] != "__" and k[-1:-2] !='__'):
\r
104 valeur=getattr(prefsCode,k)
\r
105 setattr(self,k,valeur)
\r
109 #--------------------------------------
\r
110 def lecture_fichier_ini_integrateur(self):
\r
111 #--------------------------------------
\r
112 # Verifie l'existence du fichier "standard"
\r
113 # appelle la lecture de ce fichier
\r
114 clef="PREFS_CATA_"+self.code
\r
116 repIntegrateur=os.path.abspath(os.environ[clef])
\r
120 fic_ini_integrateur=os.path.join(repIntegrateur,self.name)
\r
121 if not os.path.isfile(fic_ini_integrateur): return
\r
122 txt = read_file(fic_ini_integrateur)
\r
127 QMessageBox.critical( None, tr("Import du fichier de Configuration"),
\r
128 tr("Erreur a la lecture du fichier de configuration %s " , str(fic_ini_integrateur)))
\r
130 self.labels_eficas.append('rep_aide')
\r
131 for k in self.labels_eficas :
\r
133 setattr(self,k,d[k])
\r
136 #Glut pour les repertoires materiaux
\r
138 for k in d.keys() :
\r
139 if (k[0:8]=="rep_mat_") or (k[0:8]=="rep_doc_"):
\r
140 setattr(self,k,d[k])
\r
143 #--------------------------------------
\r
144 def lecture_fichier_ini_utilisateur(self):
\r
145 #--------------------------------------
\r
146 # Surcharge les parametres standards par les parametres utilisateur s'ils existent
\r
147 self.fic_ini_utilisateur = os.path.join(self.rep_user,self.name)
\r
148 if not os.path.isfile(self.fic_ini_utilisateur): return
\r
150 txt = read_file(self.fic_ini_utilisateur)
\r
155 l=traceback.format_exception(sys.exc_info()[0],sys.exc_info()[1],sys.exc_info()[2])
\r
156 QMessageBox.critical( None, tr("Import du fichier de Configuration"),
\r
157 tr("Erreur a la lecture du fichier de configuration %s " , str(fic_ini_integrateur)))
\r
158 for k in self.labels_user :
\r
160 setattr(self,k,d[k])
\r
163 for k in d.keys() :
\r
164 if (k[0:8]=="rep_mat_") or (k[0:8]=="rep_doc_"):
\r
165 setattr(self,k,d[k])
\r
167 #--------------------------------------
\r
168 def save_params(self):
\r
169 #--------------------------------------
\r
171 # les nouveaux parametres dans le fichier de configuration utilisateur
\r
174 for clef in self.labels_user :
\r
175 if hasattr(self,clef):
\r
176 valeur=getattr(self,clef)
\r
177 texte= texte + clef+" = " + repr(valeur) +"\n"
\r
178 #Glut pour les repertoires materiaux
\r
180 for k in dir(self):
\r
181 if (k[0:8]=="rep_mat_") or (k[0:8]=="rep_doc_"):
\r
182 valeur=getattr(self,k)
\r
183 texte= texte + k+" = " + repr(valeur) +"\n"
\r
185 f=open(self.fic_ini_utilisateur,'w+')
\r