# -*- 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
#
-# ======================================================================
"""
Ce module contient le plugin convertisseur de fichier
au format python pour EFICAS.
Un plugin convertisseur doit fournir deux attributs de classe :
- extensions et formats et deux méthodes : readfile,convert.
+ extensions et formats et deux méthodes : readfile,convert.
L'attribut de classe extensions est une liste d'extensions
- de fichiers préconisées pour ce type de format. Cette information
+ de fichiers préconisées pour ce type de format. Cette information
est seulement indicative.
L'attribut de classe formats est une liste de formats de sortie
- supportés par le convertisseur. Les formats possibles sont :
+ supportés par le convertisseur. Les formats possibles sont :
eval, dict ou exec.
- Le format eval est un texte source Python qui peut etre evalué. Le
- résultat de l'évaluation est un objet Python quelconque.
+ Le format eval est un texte source Python qui peut etre evalué. Le
+ résultat de l'évaluation est un objet Python quelconque.
Le format dict est un dictionnaire Python.
- Le format exec est un texte source Python qui peut etre executé.
+ Le format exec est un texte source Python qui peut etre executé.
- La méthode readfile a pour fonction de lire un fichier dont le
- nom est passé en argument de la fonction.
+ La méthode readfile a pour fonction de lire un fichier dont le
+ nom est passé en argument de la fonction.
- convertisseur.readfile(nom_fichier)
- La méthode convert a pour fonction de convertir le fichier
- préalablement lu dans un objet du format passé en argument.
+ La méthode convert a pour fonction de convertir le fichier
+ préalablement lu dans un objet du format passé en argument.
- objet=convertisseur.convert(outformat)
Ce convertisseur supporte le format de sortie exec
import parseur_python
from Noyau import N_CR
+from Extensions.i18n import tr
+from Extensions.eficas_exception import EficasException
def entryPoint():
"""
- Retourne les informations nécessaires pour le chargeur de plugins
- Ces informations sont retournées dans un dictionnaire
+ Retourne les informations nécessaires pour le chargeur de plugins
+ Ces informations sont retournées dans un dictionnaire
"""
return {
# Le nom du plugin
'name' : 'homard',
- # La factory pour créer une instance du plugin
+ # La factory pour créer une instance du plugin
'factory' : PythonParser,
}
et retourne le texte au format outformat avec la
methode convertisseur.convert(outformat)
- Ses caractéristiques principales sont exposées dans 2 attributs
+ Ses caractéristiques principales sont exposées dans 2 attributs
de classe :
- - extensions : qui donne une liste d'extensions de fichier préconisées
- - formats : qui donne une liste de formats de sortie supportés
+ - extensions : qui donne une liste d'extensions de fichier préconisées
+ - formats : qui donne une liste de formats de sortie supportés
"""
- # Les extensions de fichier préconisées
+ # Les extensions de fichier préconisées
extensions=('.py',)
- # Les formats de sortie supportés (eval dict ou exec)
+ # Les formats de sortie supportés (eval dict ou exec)
# Le format exec est du python executable (commande exec) converti avec PARSEUR_PYTHON
# Le format execnoparseur est du python executable (commande exec) non converti
formats=('exec','execnoparseur')
try:
self.text=open(filename).read()
except:
- self.cr.fatal("Impossible ouvrir fichier %s" % filename)
+ self.cr.fatal(tr("Impossible d'ouvrir le fichier: %s", str(filename)))
return
- def convert(self,outformat):
+ def convert(self,outformat,appli=None):
if outformat == 'exec':
try:
return parseur_python.PARSEUR_PYTHON(self.text).get_texte()
# Erreur lors de la conversion
l=traceback.format_exception(sys.exc_info()[0],sys.exc_info()[1],
sys.exc_info()[2])
- self.cr.exception("Impossible de convertir le fichier python \
- qui doit contenir des erreurs.\n \
- On retourne le fichier non converti \n \
- Prévenir la maintenance. \n" + string.join(l))
- # On retourne néanmoins le source initial non converti (au cas où)
+ self.cr.exception(tr("Impossible de convertir le fichier Python \
+ qui doit contenir des erreurs.\n \
+ On retourne le fichier non converti \n \
+ Prevenir la maintenance. \n %s", string.join(l)))
+ # On retourne neanmoins le source initial non converti (au cas ou)
return self.text
elif outformat == 'execnoparseur':
return self.text
else:
- raise "Format de sortie : %s, non supporté"
+ raise EficasException(tr("Format de sortie : %s, non supporte", unicode(outformat)))
return None
-