X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FLogger%2FSALOME_Trace.py;h=900693e4106b5a547ac99b14b1570fee5e07c1c3;hb=6dd1af68fb168b4df7558ebf8e7ffe6c4abbfc5b;hp=04dbcc35c92262642fc20ca1aed111279449556d;hpb=611c96f1b845f602ce9dbdc154c6fe4425937b9b;p=modules%2Fyacs.git diff --git a/src/Logger/SALOME_Trace.py b/src/Logger/SALOME_Trace.py index 04dbcc35c..900693e41 100644 --- a/src/Logger/SALOME_Trace.py +++ b/src/Logger/SALOME_Trace.py @@ -11,31 +11,49 @@ import sys import CosNaming from omniORB import CORBA import SALOME_Logger +import time +import os + +trace="local" +if (os.environ.has_key("SALOME_trace")): + if (os.environ["SALOME_trace"] == "with_logger"): + trace="logger" class SALOME_Trace : def __init__(self): self.m_pInterfaceLogger = None - try: - orb = CORBA.ORB_init(sys.argv, CORBA.ORB_ID) - theObj = orb.resolve_initial_references("NameService") - inc = theObj._narrow(CosNaming.NamingContext) - name = [CosNaming.NameComponent("Logger","")] - obj = inc.resolve(name); - - self.m_pInterfaceLogger = obj._narrow(SALOME_Logger.Logger) - - except CosNaming.NamingContext.NotFound, e : - print "Caught exception: Naming Service can't found Logger" - except CORBA.COMM_FAILURE, e: - print "Caught CORBA::SystemException CommFailure" - except CORBA.SystemException, e: - print "Caught CORBA::SystemException." - except CORBA.Exception, e: - print "Caught CORBA::Exception." - except Exception, e: - print "Caught unknown exception." - + if trace=="logger": + ok = 0 + steps = 40 + while steps > 0 and ok == 0: + + try: + orb = CORBA.ORB_init(sys.argv, CORBA.ORB_ID) + theObj = orb.resolve_initial_references("NameService") + inc = theObj._narrow(CosNaming.NamingContext) + name = [CosNaming.NameComponent("Logger","")] + obj = inc.resolve(name); + + self.m_pInterfaceLogger = obj._narrow(SALOME_Logger.Logger) + + if not self.m_pInterfaceLogger is None: + ok = 1 + + except CosNaming.NamingContext.NotFound, e : + if steps == 1: print "Caught exception: Naming Service can't found Logger" + except CORBA.COMM_FAILURE, e: + if steps == 1: print "Caught CORBA::SystemException CommFailure" + except CORBA.SystemException, e: + if steps == 1: print "Caught CORBA::SystemException." + except CORBA.Exception, e: + if steps == 1: print "Caught CORBA::Exception." + except Exception, e: + if steps == 1: print "Caught unknown exception." + time.sleep(0.25) + steps = steps - 1 + + def putMessage ( self, LogMsg ) : if (CORBA.is_nil(self.m_pInterfaceLogger)):