facesVolumesToriques.py
findWireEndVertices.py
findWireIntermediateVertices.py
+ fissError.py
fissureCoude.py
fissureGenerique.py
fusionMaillageAttributionDefaut.py
--- /dev/null
+# -*- coding: utf-8 -*-
+
+class fissError(Exception):
+ """
+ usage:
+ try:
+ instructions()
+ except:
+ raise fissError(traceback.extract_stack(),"mon message")
+ """
+ def __init__(self, pile, msg):
+ self.pile = pile
+ self.msg = msg
+
+ def __str__(self):
+ return 'msg=%s\npile=%s\n'%(self.msg, repr(self.pile))
+
from geomsmesh import geomPublish
from geomsmesh import geomPublishInFather
import initLog
+import traceback
from findWireEndVertices import findWireEndVertices
from prolongeWire import prolongeWire
+from fissError import fissError
def partitionneFissureParPipe(shapesFissure, elementsDefaut, rayonPipe):
"""
cercle = geompy.MakeRotation(cercle, norms[0], math.pi/3.0 ) # éviter d'avoir l'arête de couture du pipe presque confondue avec la face fissure
geomPublish(initLog.debug, cercle, 'cercle')
fondFissProlonge = prolongeWire(fondFiss, extrem, norms, 2*rayonPipe)
- pipeFiss = geompy.MakePipe(cercle, fondFissProlonge)
+ try:
+ pipeFiss = geompy.MakePipe(cercle, fondFissProlonge)
+ except:
+ texte = "génération du pipe le long de la ligne de fond de fissure prolongée impossible. "
+ texte += "Cause éventuelle : la ligne s'autointersecte lorsqu'on la prolonge."
+ raise fissError(traceback.extract_stack(),texte)
geomPublish(initLog.debug, pipeFiss, 'pipeFiss')
partFissPipe = geompy.MakePartition([shapeDefaut, pipeFiss], [], [], [], geompy.ShapeType["FACE"], 0, [], 1)
geomPublish(initLog.debug, partFissPipe, 'partFissPipe')
from PyQt4.QtGui import QMessageBox
from PyQt4.QtGui import QPalette
from PyQt4.QtGui import QColor
+ from PyQt4.QtCore import QString
from fissureGenerale_ui import Ui_Dialog
class fissureGeneraleDialog(QtGui.QDialog):
areteFaceFissure = self.ui.dsb_areteFaceFissure.value(),
reptrav = str(self.ui.le_reptrav.text()),
nomres = str(self.ui.le_nomres.text()),
+ verbosite = self.ui.cb_log.currentIndex()
)
print dico
return dico
self.setLogVerbosity(logfile)
from blocFissure.gmu import geomsmesh # après intialisation log dans setLogVerbosity
from blocFissure.gmu.casStandard import casStandard # après intialisation log dans setLogVerbosity
- execInstance = casStandard(dico)
+ from blocFissure.gmu.fissError import fissError
+ try:
+ execInstance = casStandard(dico)
+ except fissError as erreur:
+ print '-'*60
+ print type(erreur)
+ print '-'*60
+ print erreur.msg
+ print '-'*60
+ for ligne in erreur.pile:
+ print repr(ligne)
+ print '-'*60
+ texte = erreur.msg
+# texte += +"<br>" +'-'*60 +"<br>"
+# for ligne in erreur.pile:
+# texte += repr(ligne) +"<br>"
+ mbox = QMessageBox(self)
+ mbox.setWindowTitle("erreur blocFissure")
+ mbox.setText(QString.fromUtf8(texte))
+ mbox.exec_()
+# except Exception as erreur:
+# print "exception non répertoriée"
self.NOK = NOK
self.accept()