Gaudi Framework, version v23r2

Home   Generated: Thu Jun 28 2012

Bindings.py

Go to the documentation of this file.
00001 # File: GaudiPython/Bindings.py
00002 # Author: Pere Mato (pere.mato@cern.ch)
00003 
00004 """ GaudiPython.Bindings module.
00005     This module provides the basic bindings of the main Gaudi
00006     components to Python. It is itself based on the PyCintex
00007     extersion module provided by LCG/ROOT that provided
00008     dynamic bindigns of classes for which LCG dictionaires exists.
00009 """
00010 
00011 __all__ = [ 'gbl','InterfaceCast', 'Interface', 'PropertyEntry',
00012             'AppMgr', 'PyAlgorithm', 'CallbackStreamBuf',
00013             'iAlgorithm', 'iDataSvc', 'iHistogramSvc','iNTupleSvc','iService', 'iAlgTool', 'Helper',
00014             'SUCCESS', 'FAILURE', 'toArray',
00015             'ROOT', 'makeNullPointer', 'makeClass', 'setOwnership',
00016             'getClass', 'loaddict', 'deprecation' ]
00017 
00018 import os, sys, string, warnings, re
00019 import PyCintex
00020 import Pythonizations
00021 # Import Configurable from AthenaCommon or GaudiKernel if the first is not
00022 # available.
00023 from GaudiKernel.Proxy.Configurable import Configurable, getNeededConfigurables
00024 
00025 #namespaces
00026 gbl    = PyCintex.makeNamespace('')
00027 Gaudi = gbl.Gaudi
00028 
00029 _gaudi = None
00030 
00031 #----Useful shortcuts for classes -------------------------------------------------------
00032 #Helper              = PyCintex.makeClass     ('GaudiPython::Helper')
00033 Helper              = gbl.GaudiPython.Helper
00034 StringProperty      = gbl.SimpleProperty     ('string','BoundedVerifier<string>')
00035 StringPropertyRef   = gbl.SimplePropertyRef  ('string','NullVerifier<string>')
00036 GaudiHandleProperty = gbl.GaudiHandleProperty
00037 GaudiHandleArrayProperty = gbl.GaudiHandleArrayProperty
00038 DataObject          = gbl.DataObject
00039 SUCCESS             = gbl.StatusCode( gbl.StatusCode.SUCCESS, True )
00040 FAILURE             = gbl.StatusCode( gbl.StatusCode.FAILURE, True )
00041 # toIntArray, toShortArray, etc.
00042 for l in [ l for l in dir(Helper) if re.match("^to.*Array$",l) ]:
00043     exec "%s = Helper.%s"%(l,l)
00044     __all__.append(l)
00045 
00046 # FIXME: (MCl) Hack to handle ROOT 5.18 and ROOT >= 5.20
00047 if hasattr(Helper,"toArray"):
00048     # This is not backward compatible, but allows to use the same signature
00049     # with all the versions of ROOT.
00050     toArray = lambda typ: getattr(Helper,"toArray")
00051 else:
00052     # forward to the actual implementation of GaudiPython::Helper::toArray<T>
00053     toArray = lambda typ: getattr(Helper,"toArray<%s>"%typ)
00054 
00055 #----Convenient accessors to PyROOT functionality ---------------------------------------
00056 ROOT            = PyCintex.libPyROOT
00057 makeNullPointer = PyCintex.libPyROOT.MakeNullPointer
00058 makeClass       = PyCintex.libPyROOT.MakeRootClass
00059 setOwnership    = PyCintex.libPyROOT.SetOwnership
00060 
00061 def deprecation(message):
00062     warnings.warn('GaudiPython: '+ message, DeprecationWarning, stacklevel=3)
00063 
00064 #----InterfaceCast class ----------------------------------------------------------------
00065 class InterfaceCast(object) :
00066     """ Helper class to obtain the adequate interface from a component
00067         by using the Gaudi queryInterface() mechanism """
00068     def __init__(self, t ) :
00069         if type(t) is str : t = PyCintex.makeClass(t)
00070         self.type = t
00071     def __call__(self, obj) :
00072         if obj :
00073             ip = PyCintex.libPyROOT.MakeNullPointer(self.type)
00074             try:
00075                 if obj.queryInterface(self.type.interfaceID(), ip).isSuccess() :
00076                     return ip
00077                 else :
00078                     print "ERROR: queryInterface failed for", obj, "interface:", self.type
00079             except Exception, e:
00080                 print "ERROR: exception", e, "caught when retrieving interface", self.type, "for object", obj
00081                 import traceback
00082                 traceback.print_stack()
00083         return None
00084     cast = __call__
00085 #---Interface class (for backward compatibility)-----------------------------------------
00086 class Interface(InterfaceCast) :
00087     def __init__(self, t ):
00088         deprecation('Use InterfaceCast class instead')
00089         InterfaceCast.__init__(self,t)
00090     def cast(self, obj) :
00091         return self(obj)
00092 
00093 #----load dictionary function using Gaudi function---------------------------------------
00094 def loaddict(dict) :
00095     """ Load a LCG dictionary using various mechanisms"""
00096     if Helper.loadDynamicLib(dict) == 1 : return
00097     else :
00098         try:
00099             PyCintex.loadDict(dict)
00100         except:
00101             raise ImportError, 'Error loading dictionary library'
00102 
00103 #---get a class (by loading modules if needed)--------------------------------------------
00104 def getClass( name , libs = [] ) :
00105     """
00106     Function to retrieve a certain C++ class by name and to load dictionary if requested
00107 
00108     Usage:
00109 
00110     from gaudimodule import getClass
00111     # one knows that class is already loaded
00112     AppMgr     = getClass( 'ApplicationMgr'           )
00113     # one knows where to look for class, if not loaded yet
00114     MCParticle = getClass( 'MCParticle' , 'EventDict' )
00115     # one knows where to look for class, if not loaded yet
00116     Vertex     = getClass( 'Vertex' , ['EventDict', 'PhysEventDict'] )
00117     """
00118     # see if class is already loaded
00119     if hasattr( gbl , name )  : return getattr( gbl , name )
00120     # try to load dictionaries and  look for the required class
00121     if type(libs) is not list : libs = [libs]
00122     for lib in libs :
00123         loaddict( lib )
00124         if hasattr( gbl , name ) : return getattr( gbl , name )
00125     # return None ( or raise exception? I do not know...  )
00126     return None
00127 
00128 #----PropertyEntry class---------------------------------------------------------------------
00129 class PropertyEntry(object) :
00130     """ holds the value and the documentation string of a property """
00131     def __init__(self, prop) :
00132         self._type = type(prop).__name__
00133         self.__doc__ = " --- Property type is " + self.ptype()
00134 
00135         if   issubclass(type(prop),GaudiHandleProperty) :
00136             self._value = prop.value()   # do nothing for ATLAS' handles
00137         elif issubclass(type(prop),GaudiHandleArrayProperty) :
00138             self._value = prop.value()   # do nothing for ATLAS' handles
00139         else :
00140             # for all other types try to extract the native python type
00141             try:    self._value = eval( prop.toString() , {} , {} )
00142             except:
00143                 if hasattr ( prop , 'value' ) : self._value = prop.value()
00144                 else                          : self._value = prop.toString()
00145 
00146         self.__doc__ += " --- Default value = " + str(self._value) + " --- "
00147         if prop.documentation() != 'none':
00148             self.__doc__ = prop.documentation() + '\\n' + self.__doc__
00149         ## keep the original property
00150         self._property = prop # property itself
00151     def value(self) :
00152         return self._value
00153     def ptype(self) :
00154         return self._type
00155     def property(self):
00156         "Return the underlying  property itself "
00157         return self._property
00158     def documentation(self) :
00159         return self.__doc__
00160     def hasDoc(self):
00161         return len(self.__doc__)>0 and self.__doc__ != 'none'
00162 
00163 #----iProperty class---------------------------------------------------------------------
00164 class iProperty(object) :
00165     """ Python equivalent to the C++ Property interface """
00166     def __init__(self, name, ip = None) :
00167         if ip : self.__dict__['_ip'] = InterfaceCast(gbl.IProperty)(ip)
00168         else  : self.__dict__['_ip'] = None
00169         self.__dict__['_svcloc'] = gbl.Gaudi.svcLocator()
00170         optsvc = Helper.service(self._svcloc,'JobOptionsSvc')
00171         if optsvc : self.__dict__['_optsvc'] = InterfaceCast(gbl.IJobOptionsSvc)(optsvc)
00172         else      : self.__dict__['_optsvc'] = None
00173         self.__dict__['_name'] = name
00174     def getInterface(self) :
00175         if not self._ip : self.retrieveInterface()
00176         return self._ip
00177     def retrieveInterface(self) :
00178         pass
00179     def __call_interface_method__(self,ifname,method,*args):
00180         if not getattr(self,ifname) : self.retrieveInterface()
00181         return getattr(getattr(self,ifname),method)(*args)
00182     def __setattr__(self, name, value):
00183         """
00184         The method which is used for setting the property from the given value.
00185         - In the case of the valid instance it sets the property through IProperty interface
00186         - In the case of placeholder the property is added to JobOptionsCatalogue
00187         """
00188         if hasattr( value, 'toStringProperty' ):
00189             # user defined behaviour
00190             value = '%s' % value.toStringProperty()
00191         ip = self.getInterface()
00192         if ip :
00193             if not gbl.Gaudi.Utils.hasProperty ( ip , name ) :
00194                 raise AttributeError, 'property %s does not exist' % name
00195             prop = ip.getProperty(name)
00196             if not hasattr ( prop , 'value' ) or not type( value ) == type( prop.value() ) :
00197                 if   tuple     == type( value  )     : value = str(value)
00198                 elif hasattr ( value , 'toString' )  : value = value.toString()
00199                 elif not long  == type( value )      : value = '%s' % value
00200                 else                                 : value = '%d' % value
00201                 if prop.fromString( value ).isFailure() :
00202                     raise AttributeError, 'property %s could not be set from %s' % (name,value)
00203             else :
00204                 if not prop.setValue( value ) :
00205                     raise AttributeError, 'property %s could not be set from %s' % (name,value)
00206         else :
00207             if   type(value) == str            : value = '"%s"' % value # need double quotes
00208             elif type(value) == tuple          : value = str(value)
00209             elif hasattr( value , 'toString' ) : value = value.toString()
00210             elif type(value) == long: value = '%d'   % value # prevent pending 'L'
00211             sp = StringProperty( name , str(value))
00212             self._optsvc.addPropertyToCatalogue( self._name , sp )
00213     def __getattr__(self, name ):
00214         """
00215         The method which returns the value for the given property
00216         - In the case of the valid instance it returns the valid property value through IProperty interface
00217         - In the case of placeholder the property value is retrieved from JobOptionsCatalogue
00218         """
00219         ip = self.getInterface()
00220         if ip :
00221             if not gbl.Gaudi.Utils.hasProperty ( ip , name ) :
00222                 raise AttributeError, 'property %s does not exist' % name
00223             prop = ip.getProperty(name)
00224             if   StringProperty    == type( prop )   : return prop.value()
00225             elif StringPropertyRef == type( prop )   : return prop.value()
00226             try:     return eval( prop.toString(), {}, {} )
00227             except : return prop.value()
00228         else :
00229             props = self._optsvc.getProperties(self._name)
00230             for p in props :
00231                 if not p.name() == name : continue
00232                 # from JobOptionsSvc we always have only strings
00233                 try:    return eval( p.value(), {}, {} )
00234                 except: return p.value()
00235             raise AttributeError, 'property %s does not exist' % name
00236     def properties(self):
00237         dct = {}
00238         props = None
00239         ip = self.getInterface()
00240         if ip :
00241             props = ip.getProperties()
00242             propsFrom = self._name # "interface"
00243         else:
00244             props = self._optsvc.getProperties( self._name )
00245             propsFrom = "jobOptionsSvc"
00246         if props:
00247             for p in props :
00248                 try:
00249                     dct[p.name()] = PropertyEntry(p)
00250                 except (ValueError,TypeError),e:
00251                     raise ValueError, "gaudimodule.iProperty.properties(): %s%s processing property %s.%s = %s" % \
00252                           (e.__class__.__name__, e.args, propsFrom, p.name(), p.value())
00253         return dct
00254     def name(self) :
00255         return self._name
00256 
00257 #----iService class---------------------------------------------------------------------
00258 class iService(iProperty) :
00259     """ Python equivalent to IProperty interface """
00260     def __init__(self, name, isvc = None ) :
00261         iProperty.__init__(self, name, isvc )
00262         if isvc : self.__dict__['_isvc'] = InterfaceCast(gbl.IService)(isvc)
00263         else    : self.__dict__['_isvc'] = None
00264     def retrieveInterface(self) :
00265         isvc = Helper.service(self._svcloc,self._name)
00266         if isvc : iService.__init__(self, self._name, isvc)
00267     initialize   = lambda self : self.__call_interface_method__("_isvc","initialize")
00268     start        = lambda self : self.__call_interface_method__("_isvc","start")
00269     stop         = lambda self : self.__call_interface_method__("_isvc","stop")
00270     finalize     = lambda self : self.__call_interface_method__("_isvc","finalize")
00271     reinitialize = lambda self : self.__call_interface_method__("_isvc","reinitialize")
00272     restart      = lambda self : self.__call_interface_method__("_isvc","restart")
00273     def isValid(self) :
00274         if self._isvc: return True
00275         else :         return False
00276 
00277 #----iAlgorithm class---------------------------------------------------------------------
00278 class iAlgorithm(iProperty) :
00279     """ Python equivalent to IAlgorithm interface """
00280     def __init__(self, name, ialg = None ) :
00281         iProperty.__init__(self, name, ialg )
00282         if ialg : self.__dict__['_ialg'] = InterfaceCast(gbl.IAlgorithm)(ialg)
00283         else    : self.__dict__['_ialg'] = None
00284     def retrieveInterface(self) :
00285         ialg = Helper.algorithm(InterfaceCast(gbl.IAlgManager)(self._svcloc),self._name)
00286         if ialg : iAlgorithm.__init__(self, self._name, ialg)
00287     initialize   = lambda self : self.__call_interface_method__("_ialg","initialize")
00288     start        = lambda self : self.__call_interface_method__("_ialg","start")
00289     execute      = lambda self : self.__call_interface_method__("_ialg","execute")
00290     stop         = lambda self : self.__call_interface_method__("_ialg","stop")
00291     finalize     = lambda self : self.__call_interface_method__("_ialg","finalize")
00292     reinitialize = lambda self : self.__call_interface_method__("_ialg","reinitialize")
00293     restart      = lambda self : self.__call_interface_method__("_ialg","restart")
00294     sysInitialize   = lambda self : self.__call_interface_method__("_ialg","sysInitialize")
00295     sysStart        = lambda self : self.__call_interface_method__("_ialg","sysStart")
00296     sysExecute      = lambda self : self.__call_interface_method__("_ialg","sysExecute")
00297     sysStop         = lambda self : self.__call_interface_method__("_ialg","sysStop")
00298     sysFinalize     = lambda self : self.__call_interface_method__("_ialg","sysFinalize")
00299     sysReinitialize = lambda self : self.__call_interface_method__("_ialg","sysReinitialize")
00300     sysRestart      = lambda self : self.__call_interface_method__("_ialg","sysRestart")
00301 
00302 #----iAlgTool class---------------------------------------------------------------------
00303 class iAlgTool(iProperty) :
00304     """ Python equivalent to IAlgTool interface (not completed yet) """
00305     def __init__(self, name, itool = None ) :
00306         iProperty.__init__(self, name, itool )
00307         if itool : self.__dict__['_itool'] = itool
00308         else     : self.__dict__['_itool'] = None
00309         svc = Helper.service( self._svcloc, 'ToolSvc', True )
00310         self.__dict__['_toolsvc']= iToolSvc('ToolSvc', svc)
00311     def retrieveInterface(self) :
00312         itool = self._toolsvc._retrieve(self._name)
00313         if itool : iAlgTool.__init__(self, self._name, itool)
00314     start = lambda self : self.__call_interface_method__("_itool","start")
00315     stop  = lambda self : self.__call_interface_method__("_itool","stop")
00316     type  = lambda self : self.__call_interface_method__("_itool","type")
00317     def name(self) :
00318         if self._itool : return self._itool.name()
00319         else : return self._name
00320 
00321 #----iDataSvc class---------------------------------------------------------------------
00322 class iDataSvc(iService) :
00323     def __init__(self, name, idp) :
00324         iService.__init__(self, name, idp )
00325         self.__dict__['_idp'] = InterfaceCast(gbl.IDataProviderSvc)(idp)
00326         self.__dict__['_idm'] = InterfaceCast(gbl.IDataManagerSvc)(idp)
00327     def registerObject(self, path, obj) :
00328         if not self._idp : raise AttributeError('C++ service %s does not exist' % self.__dict__['_name'])
00329         return self._idp.registerObject(path,obj)
00330     def unregisterObject(self, path) :
00331         if not self._idp : raise AttributeError('C++ service %s does not exist' % self.__dict__['_name'])
00332         return self._idp.unregisterObject(path)
00333     def retrieveObject(self, path) :
00334         if not self._idp : return  None
00335         return Helper.dataobject(self._idp, path)
00336     ## get object from TES
00337     def findObject(self, path) :
00338         """
00339 
00340         Get the existing object in TransientStore for the given location
00341 
00342         - loading of object from persistency is NOT triggered
00343         - 'data-on-demand' action is NOT triggered
00344 
00345         >>> svc  =  ...                     ## get the service
00346         >>> path =  ...                     ## get the path in Transient Store
00347         >>> data = svc.findObject ( path )  ## use the method
00348 
00349         """
00350         if not self._idp : raise IndexError('C++ service %s does not exist' % self.__dict__['_name'])
00351         return Helper.findobject(self._idp, path)
00352 
00353     ##  get or retrieve object, possible switch-off 'on-demand' actions
00354     def getObject ( self , path , *args ) :
00355         """
00356         Get object from Transient Store  for the given location
00357 
00358         arguments :
00359         - path                           : Location of object in Transient Store
00360         - retrieve          (bool) True  : retrieve versus find
00361         - disable on-demand (bool) False : temporary disable 'on-demand' actions
00362 
00363         >>> svc  = ...   ## get the service
00364         >>> path = ...   ## get the path
00365 
00366         >>> data = svc.getObject ( path , False )  ## find object in Transient Store
00367 
00368         ## find object in Transient Store
00369         #  load form tape or use 'on-demand' action  for missing objects :
00370         >>> data = svc.getObject ( path , True  )
00371 
00372         ## find object in Transient Store
00373         #  load from tape or for missing objects, disable 'on-demand'-actions
00374         >>> data = svc.getObject ( path , True  , True )
00375 
00376         """
00377         if not self._idp : raise IndexError('C++ service %s does not exist' % self.__dict__['_name'])
00378         return Helper.getobject(self._idp, path, *args )
00379 
00380     def __getitem__(self, path) :
00381         if not self._idp : raise IndexError('C++ service %s does not exist' % self.__dict__['_name'])
00382         return Helper.dataobject(self._idp, path)
00383     def __setitem__(self, path, obj) :
00384         if not self._idp : raise IndexError('C++ service %s does not exist' % self.__dict__['_name'])
00385         return self._idp.registerObject(path,obj)
00386     def __delitem__(self, path) :
00387         if not self._idp : raise IndexError('C++ service %s does not exist' % self.__dict__['_name'])
00388         return self._idp.unregisterObject(path)
00389     def leaves(self, node=None) :
00390         if not node : node = self.retrieveObject('')
00391         ll = gbl.std.vector('IRegistry*')()
00392         if type(node) is str : obj = self.retrieveObject(node)
00393         else                 : obj = node
00394         if self._idm.objectLeaves(node, ll).isSuccess() : return ll
00395     def dump(self, node=None) :
00396         if not node :
00397             root = self.retrieveObject('')
00398             if root : node = root.registry()
00399             else : return
00400         print node.identifier()
00401         if node.object() :
00402             for l in self.leaves(node) : self.dump(l)
00403     def getList(self, node=None, lst=[], rootFID=None) :
00404         if not node :
00405             root = self.retrieveObject('')
00406             if root :
00407                 node = root.registry()
00408                 rootFID = node.address().par()
00409                 lst = []
00410             else :
00411                 return
00412         Helper.dataobject( self._idp, node.identifier() )
00413         if node.object() :
00414             lst.append( node.identifier() )
00415             for l in self.leaves(node) :
00416                 if l.address() and l.address().par() == rootFID :
00417                     self.getList(l,lst,rootFID)
00418                 else :
00419                     continue
00420         return lst
00421     def getHistoNames( self, node=None, lst=[] ) :
00422         if not node :
00423             root = self.retrieveObject('')
00424             if root :
00425                 node = root.registry()
00426                 # rootFID = node.address().par()
00427                 lst = []
00428             else : return
00429         Helper.dataobject( self._idp, node.identifier() )
00430         if node.object() :
00431             lst.append( node.identifier() )
00432             for l in self.leaves(node) :
00433                 if l.name() : # and l.address().par() == rootFID :
00434                     self.getHistoNames(l,lst)
00435                 else :
00436                     continue
00437         return lst
00438     def setRoot(self, name, obj):
00439         if not self._idm : raise IndexError('C++ service %s does not exist' % self.__dict__['_name'])
00440         return self._idm.setRoot(name,obj)
00441     def clearStore(self):
00442         if not self._idm : raise IndexError('C++ service %s does not exist' % self.__dict__['_name'])
00443         return self._idm.clearStore()
00444 
00445 
00446 #----iHistogramSvc class---------------------------------------------------------------------
00447 class iHistogramSvc(iDataSvc) :
00448     def __init__(self, name, ihs) :
00449         self.__dict__['_ihs'] = InterfaceCast(gbl.IHistogramSvc)(ihs)
00450         iDataSvc.__init__(self, name, ihs)
00451     def retrieve1D(self, path) :
00452         return Helper.histo1D(self._ihs, path)
00453     def retrieve2D(self, path) :
00454         return Helper.histo2D(self._ihs, path)
00455     def retrieve3D(self, path) :
00456         return Helper.histo3D(self._ihs, path)
00457     def retrieveProfile1D(self, path) :
00458         return Helper.profile1D(self._ihs, path)
00459     def retrieveProfile2D(self, path) :
00460         return Helper.profile2D(self._ihs, path)
00461     def retrieve(self,path):
00462         """
00463         Retrieve AIDA histogram or AIDA profile histogram by path in Histogram Transient Store
00464         >>> svc = ...
00465         >>> histo = svc.retrieve ( 'path/to/my/histogram' )
00466         """
00467         h = self.retrieve1D(path)
00468         if not h : h = self.retrieve2D(path)
00469         if not h : h = self.retrieve3D(path)
00470         if not h : h = self.retrieveProfile1D(path)
00471         if not h : h = self.retrieveProfile2D(path)
00472         return h
00473     def book(self, *args) :
00474         """
00475         Book the histograms(1D,2D&3D) , see IHistogramSvc::book
00476         >>> svc = ...
00477         >>> histo = svc.book( .... )
00478         """
00479         return apply(self._ihs.book,args)
00480     def bookProf(self, *args) :
00481         """
00482         Book the profile(1D&2D) histograms, see IHistogramSvc::bookProf
00483         >>> svc = ...
00484         >>> histo = svc.bookProf( .... )
00485         """
00486         return apply(self._ihs.bookProf,args)
00487     def __getitem__ ( self, path ) :
00488         """
00489         Retrieve the object from  Histogram Transient Store (by path)
00490         The reference to AIDA histogram is returned (if possible)
00491         >>> svc = ...
00492         >>> histo = svc['path/to/my/histogram']
00493         """
00494         h = self.retrieve ( path )
00495         if h : return h
00496         return iDataSvc.__getitem__( self , path )
00497     def getAsAIDA ( self , path ) :
00498         """
00499         Retrieve the histogram from  Histogram Transient Store (by path)
00500         The reference to AIDA histogram is returned (if possible)
00501         >>> svc = ...
00502         >>> histo = svc.getAsAIDA ( 'path/to/my/histogram' )
00503         """
00504         return self.__getitem__( path )
00505     def getAsROOT ( self , path ) :
00506         """
00507         Retrieve the histogram from  Histogram Transient Store (by path)
00508         The Underlying native ROOT object is returned (if possible)
00509         >>> svc = ...
00510         >>> histo = svc.getAsROOT ( 'path/to/my/histogram' )
00511         """
00512         fun=gbl.Gaudi.Utils.Aida2ROOT.aida2root
00513         return fun( self.getAsAIDA( path ) )
00514 
00515 #----iNTupleSvc class---------------------------------------------------------------------
00516 class iNTupleSvc(iDataSvc) :
00517     RowWiseTuple    = 42
00518     ColumnWiseTuple = 43
00519     def __init__(self, name, ints) :
00520         self.__dict__['_ints'] = InterfaceCast(gbl.INTupleSvc)(ints)
00521         iDataSvc.__init__(self, name, ints)
00522     def book(self, *args) :
00523         return apply(self._ints.book, args)
00524     def defineOutput(self, files, typ="Gaudi::RootCnvSvc"):
00525         """ Defines the mapping between logical names and the output file
00526             Usage:
00527               defineOutput({'LUN1':'MyFile1.root', 'LUN2':'Myfile2.root'}, svc='Gaudi::RootCnvSvc')
00528         """
00529         import Persistency as prs
00530         helper = prs.get(typ)
00531         helper.configure(AppMgr())
00532         self.Output = [helper.formatOutput(files[lun], lun=lun) for lun in files]
00533         if AppMgr().HistogramPersistency == 'NONE':
00534             AppMgr().HistogramPersistency = "ROOT"
00535     def __getitem__ ( self, path ) :
00536         return iDataSvc.__getitem__( self , path )
00537 
00538 
00539 #----iToolSvc class---------------------------------------------------------------------
00540 class iToolSvc(iService) :
00541     def __init__(self, name, its) :
00542         self.__dict__['_its'] = InterfaceCast(gbl.IToolSvc)(its)
00543         iService.__init__(self, name, its)
00544     def _retrieve(self, name, quiet=True):
00545         sol = _gaudi.OutputLevel
00546         if quiet : self.OutputLevel = 6
00547         if name.rfind('.') == -1 :
00548             itool = Helper.tool(self._its, '', name, None, False )
00549         elif name[0:8] == 'ToolSvc.' :
00550             itool = Helper.tool(self._its, '', name[8:], None, False )
00551         elif name.count('.') > 1 :
00552             ptool = self._retrieve(name[:name.rfind('.')])
00553             itool = Helper.tool(self._its, '', name[name.rfind('.')+1:], ptool, False )
00554         elif _gaudi :
00555             prop = _gaudi.property(name[:name.rfind('.')])
00556             itool = Helper.tool(self._its, '', name[name.rfind('.')+1:], prop._ip, False )
00557         if quiet : self.OutputLevel = sol
00558         return itool
00559     def retrieve(self, name):
00560         return iAlgTool(name, self._retrieve(name,quiet=False))
00561     def create(self, typ, name=None, parent=None, interface=None) :
00562         if not name : name = typ
00563         itool = Helper.tool(self._its, typ, name, parent, True )
00564         if interface :
00565             return InterfaceCast(interface)(itool)
00566         else :
00567             return iAlgTool(name,itool)
00568     def release(self, itool) :
00569         if type(itool) is iAlgTool :
00570             self._its.releaseTool(itool._itool)
00571 
00572 #----iJopOptSvc class-------------------------------------------------------------------
00573 class iJobOptSvc(iService) :
00574     """
00575     Python-image of C++ class IJobOptionsSvc
00576     """
00577     ## constructor
00578     def __init__( self , name , svc ) :
00579         """ constructor """
00580         self.__dict__['_optsvc'] = InterfaceCast(gbl.IJobOptionsSvc)(svc)
00581         return iService.__init__( self , name , svc )
00582     def getProperties( self , component ) :
00583         """
00584         Extract *ALL* properties of the given component
00585         Usage :
00586         >>> jos   = gaudi.optSvc()
00587         >>> props = jos.getProperties( 'Name' )
00588         """
00589         props = self._optsvc.getProperties( component )
00590         prps = {}
00591         if not props : return  prps              # RETURN
00592         for p in props :
00593             prop  = p.name().upper()
00594             try :
00595                 value = eval( p.value() , {} , {} )
00596             except: value = p.value()
00597             prps [ prop ] = value
00598 
00599         return prps                               # RETURN
00600     def getProperty ( self , component , name ) :
00601         """
00602         Get a certain property of the certain component
00603         Usage:
00604         >>> jos  = ...
00605         >>> extServices = jos.getProperty( 'ApplicationMgr', 'ExtSvc' )
00606         """
00607         ## get all properties of the component
00608         all = self.getProperties ( component )
00609         return all.get( name.upper() , None )     # RETURN
00610 
00611 #----iEventSelector class------------------------------------------------------------------
00612 class iEventSelector(iService):
00613     def __init__(self):
00614         iService.__init__(self, 'EventSelector', Helper.service(gbl.Gaudi.svcLocator(),'EventSelector'))
00615         self.__dict__['g'] = AppMgr()
00616     def open(self, stream, typ = 'Gaudi::RootCnvSvc', **kwargs):
00617         import Persistency as prs
00618         helper = prs.get(typ)
00619         helper.configure(self.g)
00620         self.Input = helper.formatInput(stream, **kwargs)
00621         self.reinitialize()
00622     def rewind(self):
00623         # It is not possible to reinitialize EventSelector only
00624         self.g.service('EventLoopMgr').reinitialize()
00625 
00626 #----AppMgr class---------------------------------------------------------------------
00627 class AppMgr(iService) :
00628     def __new__ ( cls, *args, **kwargs ):
00629         global _gaudi
00630         if not _gaudi :
00631             newobj = object.__new__( cls )
00632             cls.__init__(newobj, *args, **kwargs)
00633             _gaudi = newobj
00634         return _gaudi
00635     def __reset__(self):
00636         global _gaudi
00637         # Stop, Finalize and Terminate the current AppMgr
00638         self.exit()
00639         # release interfaces
00640         self._evtpro.release()
00641         self._svcloc.release()
00642         self._appmgr.release()
00643         # Reset the C++ globals
00644         gbl.Gaudi.setInstance(makeNullPointer('ISvcLocator'))
00645         gbl.Gaudi.setInstance(makeNullPointer('IAppMgrUI'))
00646         # Reset the Python global
00647         _gaudi = None
00648     def __init__(self, outputlevel = -1, joboptions = None, selfoptions = {},
00649                  dllname = None, factname = None) :
00650         global _gaudi
00651         if _gaudi : return
00652         # Protection against multiple calls to exit() if the finalization fails
00653         self.__dict__['_exit_called'] = False
00654         # keep the Gaudi namespace around (so it is still available during atexit shutdown)...
00655         self.__dict__['_gaudi_ns'] = Gaudi
00656         try:
00657             from GaudiKernel.Proxy.Configurable import expandvars
00658         except ImportError:
00659             # pass-through implementation if expandvars is not defined (AthenaCommon)
00660             expandvars = lambda data : data
00661         if dllname and factname:
00662             self.__dict__['_appmgr'] = gbl.Gaudi.createApplicationMgr(dllname,factname)
00663         elif dllname:
00664             self.__dict__['_appmgr'] = gbl.Gaudi.createApplicationMgr(dllname)
00665         else:
00666             self.__dict__['_appmgr'] = gbl.Gaudi.createApplicationMgr()
00667         self.__dict__['_svcloc'] = gbl.Gaudi.svcLocator()
00668         self.__dict__['_algmgr'] = InterfaceCast(gbl.IAlgManager)(self._appmgr)
00669         self.__dict__['_evtpro'] = InterfaceCast(gbl.IEventProcessor)(self._appmgr)
00670         self.__dict__['_svcmgr'] = InterfaceCast(gbl.ISvcManager)(self._appmgr)
00671         self.__dict__['pyalgorithms'] = []
00672         iService.__init__(self, 'ApplicationMgr', self._appmgr )
00673         #------python specific initialization-------------------------------------
00674         if self.FSMState() < Gaudi.StateMachine.CONFIGURED :  # Not yet configured
00675             self.JobOptionsType = 'NONE'
00676             if joboptions :
00677                 from GaudiKernel.ProcessJobOptions import importOptions
00678                 importOptions(joboptions)
00679             # Ensure that the ConfigurableUser instances have been applied
00680             import GaudiKernel.Proxy.Configurable
00681             if hasattr(GaudiKernel.Proxy.Configurable, "applyConfigurableUsers"):
00682                 GaudiKernel.Proxy.Configurable.applyConfigurableUsers()
00683             # This is the default and could be overridden with "selfopts"
00684             self.OutputLevel = 3
00685             selfprops = Configurable.allConfigurables.get('ApplicationMgr',{})
00686             if selfprops : selfprops = expandvars(selfprops.getValuedProperties())
00687             for p,v in selfprops.items()   : setattr(self, p, v)
00688             for p,v in selfoptions.items() : setattr(self, p, v)
00689             # Override job options
00690             if outputlevel != -1 : self.OutputLevel = outputlevel
00691             self.configure()
00692         #---MessageSvc------------------------------------------------------------
00693         ms = self.service('MessageSvc')
00694         if 'MessageSvc' in Configurable.allConfigurables:
00695             msprops = Configurable.allConfigurables['MessageSvc']
00696             ms = self.service('MessageSvc')
00697             if hasattr(msprops,"getValuedProperties"):
00698                 msprops = expandvars(msprops.getValuedProperties())
00699             for p,v in msprops.items():
00700                 setattr(ms, p, v)
00701         if outputlevel != -1 : ms.OutputLevel = outputlevel
00702         #---JobOptions------------------------------------------------------------
00703         self.__dict__['_optsvc'] = InterfaceCast(gbl.IJobOptionsSvc)(Helper.service(self._svcloc,'JobOptionsSvc'))
00704         #------Configurables initialization (part2)-------------------------------
00705         for n in getNeededConfigurables():
00706             c = Configurable.allConfigurables[n]
00707             if n in ['ApplicationMgr','MessageSvc'] : continue # These are already done---
00708             for p, v in  c.getValuedProperties().items() :
00709                 v = expandvars(v)
00710                 # Note: AthenaCommon.Configurable does not have Configurable.PropertyReference
00711                 if hasattr(Configurable,"PropertyReference") and type(v) == Configurable.PropertyReference:
00712                 # this is done in "getFullName", but the exception is ignored,
00713                 # so we do it again to get it
00714                     v = v.__resolve__()
00715                 if   type(v) == str : v = '"%s"' % v # need double quotes
00716                 elif type(v) == long: v = '%d'   % v # prevent pending 'L'
00717                 self._optsvc.addPropertyToCatalogue(n, StringProperty(p,str(v)))
00718         if hasattr(Configurable,"_configurationLocked"):
00719             Configurable._configurationLocked = True
00720 
00721         # Ensure that the exit method is called when exiting from Python
00722         import atexit
00723         atexit.register(self.exit)
00724 
00725         #---Hack to avoid bad interactions with the ROOT exit handler
00726         # Look for an exit handler installed by ROOT
00727         root_handler_installed = False
00728         for h in atexit._exithandlers:
00729             func = h[0]
00730             if hasattr(func, "__module__") and func.__module__ == "ROOT":
00731                 root_handler_installed = True
00732                 break
00733 
00734         # If the handler is not yet installed, let's install our private version
00735         # that detects that the ROOT exit handler is installed and add our own
00736         # after it to ensure it is called before.
00737         if not root_handler_installed:
00738             orig_register = atexit.register
00739             def register(func, *targs, **kargs):
00740                 orig_register(func, *targs, **kargs)
00741                 if hasattr(func, "__module__") and func.__module__ == "ROOT":
00742                     orig_register(self.exit)
00743                     # we do not need to remove out handler from the list because
00744                     # it can be safely called more than once
00745             register.__doc__ = (orig_register.__doc__ +
00746                                 "\nNote: version hacked by GaudiPython to work " +
00747                                 "around a problem with the ROOT exit handler")
00748             atexit.register = register
00749 
00750     def state(self) : return self._isvc.FSMState()
00751     def FSMState(self) : return self._isvc.FSMState()
00752     def targetFSMState(self) : return self._isvc.targetFSMState()
00753     def loaddict(self, dict) :
00754         loaddict(dict)
00755     def service(self, name, interface = None) :
00756         svc = Helper.service( self._svcloc, name )
00757         if interface :
00758             return InterfaceCast(interface)(svc)
00759         else :
00760             return iService(name, svc )
00761     def declSvcType(self, svcname, svctype ) :
00762         self._svcmgr.declareSvcType(svcname, svctype)
00763     def createSvc(self, name ) :
00764         return Helper.service( self._svcloc, name, True )
00765     def services(self) :
00766         l = self._svcloc.getServices()
00767         nl = l.__class__(l)  # get a copy
00768         s = []
00769         for i in range(l.size()) :
00770             s.append(nl.front().name())
00771             nl.pop_front()
00772         return s
00773     def algorithm(self, name , createIf = False ) :
00774         alg = Helper.algorithm( self._algmgr, name , createIf )
00775         if not alg : return iAlgorithm ( name       , alg )
00776         else       : return iAlgorithm ( alg.name() , alg )
00777     def algorithms(self) :
00778         l = self._algmgr.getAlgorithms()
00779         nl = l.__class__(l)  # get a copy
00780         s = []
00781         for i in range(l.size()) :
00782             s.append(nl.front().name())
00783             nl.pop_front()
00784         return s
00785     def tool(self, name ) :
00786         return iAlgTool(name)
00787     def property( self , name ) :
00788         if name in self.algorithms() : return self.algorithm( name )
00789         elif name in self.services() : return self.service(name )
00790         else :                         return iProperty( name )
00791     def datasvc(self, name) :
00792         if self.state() == Gaudi.StateMachine.CONFIGURED :  self.initialize()
00793         svc = Helper.service( self._svcloc, name )
00794         return iDataSvc(name, svc)
00795     def evtsvc(self) :
00796         return self.datasvc('EventDataSvc')
00797     def detsvc(self) :
00798         return self.datasvc('DetectorDataSvc')
00799     def filerecordsvc(self) :
00800         return self.datasvc('FileRecordDataSvc')
00801     def evtsel(self):
00802         if self.state() == Gaudi.StateMachine.CONFIGURED :  self.initialize()
00803         if not hasattr(self,'_evtsel') : self.__dict__['_evtsel'] = iEventSelector()
00804         return self._evtsel
00805     def histsvc(self, name='HistogramDataSvc') :
00806         svc = Helper.service( self._svcloc, name )
00807         return iHistogramSvc(name, svc)
00808     def ntuplesvc(self, name='NTupleSvc') :
00809         if name not in self.ExtSvc : self.ExtSvc += [name]
00810 #    if self.HistogramPersistency == 'NONE' : self.HistogramPersistency = 'ROOT'
00811         svc = Helper.service( self._svcloc, name, True )
00812         return iNTupleSvc(name, svc)
00813     def partsvc(self ) :
00814         if self.FSMState() == Gaudi.StateMachine.CONFIGURED :  self.initialize()
00815         svc = Helper.service( self._svcloc, 'ParticlePropertySvc' )
00816         return InterfaceCast(gbl.IParticlePropertySvc)(svc)
00817     def toolsvc(self, name='ToolSvc') :
00818         svc = Helper.service( self._svcloc, name, True )
00819         return iToolSvc(name, svc)
00820     def optSvc (self, name='JobOptionsSvc') :
00821         svc = Helper.service( self._svcloc, name, True )
00822         return iJobOptSvc(name, svc)
00823     def readOptions(self, file) :
00824         return self._optsvc.readOptions(file)
00825     def addAlgorithm(self, alg) :
00826         """ Add an Algorithm to the list of Top algorithms. It can be either a instance of
00827             an Algorithm class or it name """
00828         if type(alg) is  str :
00829             self.topAlg += [alg]
00830         else :
00831             self.pyalgorithms.append(alg)
00832             setOwnership(alg,0)
00833             if self.targetFSMState() >= Gaudi.StateMachine.INITIALIZED :
00834                 alg.sysInitialize()
00835                 if self.targetFSMState() == Gaudi.StateMachine.RUNNING :
00836                     alg.sysStart()
00837             self.topAlg += [alg.name()]
00838     def setAlgorithms(self, algs) :
00839         """ Set the list of Top Algorithms.
00840             It can be an individual of a list of algorithms names or instances """
00841         if type(algs) is not list : algs = [algs]
00842         names = []
00843         for alg in algs :
00844             if type(alg) is str : names.append(alg)
00845             else :
00846                 self.pyalgorithms.append(alg)
00847                 if self.targetFSMState() >= Gaudi.StateMachine.INITIALIZED :
00848                     alg.sysInitialize()
00849                     if self.targetFSMState() == Gaudi.StateMachine.RUNNING :
00850                         alg.sysStart()
00851                 names.append(alg.name())
00852         self.topAlg = names
00853     def removeAlgorithm(self, alg) :
00854         """ Remove an Algorithm to the list of Top algorithms. It can be either a instance of
00855             an Algorithm class or it name """
00856         tmp = self.topAlg
00857         if type(alg) is  str :
00858             tmp.remove(alg)
00859         else :
00860             tmp.remove(alg.name())
00861             self.pyalgorithms.remove(alg)
00862             setOwnership(alg,1)
00863         self.topAlg = tmp
00864     def config ( self, **args ):
00865         """
00866         Simple utility to perform the configuration of Gaudi application.
00867         It reads the set of input job-options files, and set few
00868         additional parameters 'options' through the usage of temporary *.opts file
00869         Usage:
00870         gaudi.config( files   = [ '$GAUSSOPTS/Gauss.opts'                     ,
00871                                   '$DECFILESROOT/options/10022_010.0GeV.opts' ] ,
00872                       options = [ 'EventSelector.PrintFreq   =   5  '         ] )
00873         """
00874         files  = args.get('files',[])
00875         for file in files :
00876             sc = self.readOptions(file)
00877             if sc.isFailure() :
00878                 raise RuntimeError , ' Unable to read file "' + file +'" '
00879         options  = args.get('options',None)
00880         if options :
00881             import tempfile
00882             tmpfilename = tempfile.mktemp()
00883             tmpfile     = open( tmpfilename, 'w' )
00884             tmpfile.write ( '#pragma print on  \n' )
00885             tmpfile.write ( '/// File         "' + tmpfilename+'" generated by GaudiPython \n\n' )
00886             for opt in options :
00887                 if type(options) is dict :
00888                     tmpfile.write( ' \t ' + opt + ' = '+ options[opt]+ ' ;  // added by GaudiPython \n' )
00889                 else :
00890                     tmpfile.write( ' \t ' + opt + ' ;  // added by GaudiPython \n' )
00891             tmpfile.write ( '/// End of  file "' + tmpfilename+'" generated by GaudiPython \n\n' )
00892             tmpfile.close()
00893             sc = self.readOptions( tmpfilename )
00894             if sc.isFailure() :
00895                 raise RuntimeError , ' Unable to read file "' + tmpfilename +'" '
00896             os.remove( tmpfilename )
00897         # We need to make sure that the options are taken by the ApplicationMgr
00898         if self.FSMState() != Gaudi.StateMachine.OFFLINE : # The state is already configured, so we need to do something....
00899 
00900             ## get job-options-service, @see class iJobOptSvc
00901             jos   = self.optSvc()
00902 
00903             ## list of all libraries
00904             _dlls = jos.getProperty   ( self.name() , 'DLLs'   )
00905             ## take care about libraries : APPEND if not done yet
00906             if _dlls :
00907                 libs = [ l for l in _dlls if not l in self.DLLs ]
00908                 if libs : self.DLLs  += libs
00909 
00910             ## all external services
00911             _svcs = jos.getProperty   ( self.name() , 'ExtSvc' )
00912             ## take care about services : APPEND  if not done yet
00913             if _svcs :
00914                 svcs = [ s for s in _svcs if not s in self.ExtSvc ]
00915                 if svcs : self.ExtSvc += svcs
00916 
00917             ## get all properties
00918             props = jos.getProperties ( self.name() )
00919             ## finally treat all other properties (presumably scalar properties)
00920             for key in props :
00921                 if 'DLLS' == key or 'EXTSVC' == key : continue
00922                 self.__setattr__( key , props[key] )
00923         return SUCCESS                                           # RETURN
00924     def configure(self) :
00925         return self._appmgr.configure()
00926     def start(self) :
00927         return self._appmgr.start()
00928     def run(self, n) :
00929         if self.FSMState() == Gaudi.StateMachine.CONFIGURED :
00930             sc = self.initialize()
00931             if sc.isFailure(): return sc
00932         if self.FSMState() == Gaudi.StateMachine.INITIALIZED :
00933             sc = self.start()
00934             if sc.isFailure(): return sc
00935         return self._evtpro.executeRun(n)
00936     def executeEvent(self) :
00937         return self._evtpro.executeEvent()
00938     def execute(self) :
00939         return self._evtpro.executeEvent()
00940     def runSelectedEvents(self, pfn, events):
00941         if self.FSMState() == Gaudi.StateMachine.CONFIGURED :
00942             sc = self.initialize()
00943             if sc.isFailure(): return sc
00944         if self.FSMState() == Gaudi.StateMachine.INITIALIZED :
00945             sc = self.start()
00946             if sc.isFailure(): return sc
00947         #--- Access a number of services ----
00948         if not hasattr(self,'_perssvc'): self.__dict__['_perssvc'] = self.service('EventPersistencySvc','IAddressCreator')
00949         if not hasattr(self,'_filecat'): self.__dict__['_filecat'] = self.service('FileCatalog','Gaudi::IFileCatalog')
00950         if not hasattr(self,'_evtmgr'):  self.__dict__['_evtmgr']  = self.service('EventDataSvc','IDataManagerSvc')
00951         #--- Get FID from PFN and number of events in file
00952         if pfn.find('PFN:') == 0: pfn = pfn[4:]
00953         fid, maxevt = _getFIDandEvents(pfn)
00954         #--- Add FID into catalog if needed ---
00955         if not self._filecat.existsFID(fid) : self._filecat.registerPFN(fid, pfn, '')
00956         #--- Loop over events
00957         if type(events) is not list : events = (events,)
00958         for evt in events :
00959             #--- Create POOL Address from Generic Address
00960             gadd = gbl.GenericAddress(0x202, 1, fid, '/Event', 0, evt)
00961             oadd = makeNullPointer('IOpaqueAddress')
00962             self._perssvc.createAddress(gadd.svcType(),gadd.clID(),gadd.par(),gadd.ipar(),oadd)
00963             #--- Clear TES, set root and run all algorithms
00964             self._evtmgr.clearStore()
00965             self._evtmgr.setRoot('/Event',oadd)
00966             self._evtpro.executeEvent()
00967     def exit(self):
00968         # Protection against multiple calls to exit() if the finalization fails
00969         if not self._exit_called:
00970             self.__dict__['_exit_called'] = True
00971             Gaudi = self._gaudi_ns
00972             if self.FSMState() == Gaudi.StateMachine.RUNNING:
00973                 self._appmgr.stop().ignore()
00974             if self.FSMState() == Gaudi.StateMachine.INITIALIZED:
00975                 self._appmgr.finalize().ignore()
00976             if self.FSMState() == Gaudi.StateMachine.CONFIGURED:
00977                 self._appmgr.terminate()
00978         return SUCCESS
00979     ## Custom destructor to ensure that the application is correctly finalized when exiting from python.
00980     def __del__(self):
00981         self.exit()
00982     evtSvc  = evtsvc
00983     histSvc = histsvc
00984     ntupleSvc = ntuplesvc
00985     evtSel  = evtsel
00986     detSvc  = detsvc
00987     toolSvc = toolsvc
00988     partSvc = partsvc
00989 
00990 #--------------------------------------------------------------------------------------
00991 def _getFIDandEvents( pfn ):
00992     tfile = gbl.TFile.Open(pfn)
00993     if not tfile : raise 'Cannot open ROOT file ', pfn
00994     tree = tfile.Get('##Params')
00995     tree.GetEvent(0)
00996     text = tree.db_string
00997     if 'NAME=FID' in text :
00998         fid = text[text.rfind('VALUE=')+6:-1]
00999     nevt = tfile.Get('_Event').GetEntries()
01000     tfile.Close()
01001     return fid, nevt
01002 
01003 #--------------------------------------------------------------------------------------
01004 def getComponentProperties( name ):
01005     """ Get all the properties of a component as a Python dictionary.
01006         The component is instantiated using the component library
01007     """
01008     properties = {}
01009     if name == 'GaudiCoreSvc' :
01010         if Helper.loadDynamicLib(name) != 1 :
01011             raise ImportError,  'Error loading component library '+ name
01012         factorylist = gbl.FactoryTable.instance().getEntries()
01013         factories = _copyFactoriesFromList(factorylist)
01014         g = AppMgr(outputlevel=7)
01015     else :
01016         g = AppMgr(outputlevel=7)
01017         if Helper.loadDynamicLib(name) != 1 :
01018             raise ImportError,  'Error loading component library '+ name
01019         factorylist = gbl.FactoryTable.instance().getEntries()
01020         factories = _copyFactoriesFromList(factorylist)
01021     svcloc    = gbl.Gaudi.svcLocator()
01022     dummysvc  = gbl.Service('DummySvc',svcloc)
01023     for factory in factories :
01024         if    InterfaceCast(gbl.IAlgFactory)(factory) : ctype = 'Algorithm'
01025         elif  InterfaceCast(gbl.ISvcFactory)(factory) : ctype = 'Service'
01026         elif  InterfaceCast(gbl.IToolFactory)(factory) : ctype = 'AlgTool'
01027         elif  factory.ident() == 'ApplicationMgr' :  ctype = 'ApplicationMgr'
01028         else :  ctype = 'Unknown'
01029         cname = factory.ident().split()[-1]
01030         if ctype in ('Algorithm','Service', 'AlgTool', 'ApplicationMgr') :
01031             try :
01032                 if ctype == 'AlgTool' :
01033                     obj = factory.instantiate(dummysvc)
01034                 else :
01035                     obj = factory.instantiate(svcloc)
01036             except RuntimeError, text :
01037                 print 'Error instantiating', cname, ' from ', name
01038                 print text
01039                 continue
01040             prop = iProperty('dummy', obj)
01041             properties[cname] = [ctype, prop.properties()]
01042             try:  obj.release()
01043             except: pass
01044     return properties
01045 
01046 def _copyFactoriesFromList(factories) :
01047     result = []
01048     for i in range(factories.size()) :
01049         factory = factories.front()
01050         result.append(factory)
01051         factories.pop_front()
01052     for factory in result :
01053         factories.push_back(factory)
01054     return result
01055 
01056 #----CallbackStreamBuf----------------------------------------------------------------
01057 #    Used for redirecting C++ messages to python
01058 _CallbackStreamBufBase = gbl.GaudiPython.CallbackStreamBuf
01059 class CallbackStreamBuf (_CallbackStreamBufBase):
01060     def __init__(self, callback):
01061         _CallbackStreamBufBase.__init__(self, self)
01062         self.callback = callback
01063     def _sync(self, string = None):
01064         if not string : return 0
01065         self.callback(string)
01066         return 0
01067 
01068 #----PyAlgorithm----------------------------------------------------------------------
01069 # Used to implement Algorithms in Python
01070 _PyAlgorithm = gbl.GaudiPython.PyAlgorithm
01071 class PyAlgorithm (_PyAlgorithm) :
01072     def __init__(self, name=None) :
01073         if not name : name = self.__class__.__name__
01074         _PyAlgorithm.__init__(self, self, name)
01075         self._svcloc = gbl.Gaudi.svcLocator()
01076         self._algmgr = InterfaceCast(gbl.IAlgManager)(self._svcloc)
01077         sc = self._algmgr.addAlgorithm(self)
01078         if sc.isFailure() : raise RuntimeError, 'Unable to add Algorithm'
01079     def __del__(self):
01080         sc = self._algmgr.removeAlgorithm(self)
01081         if sc.isFailure() : pass
01082     def initialize(self) : return 1
01083     def start(self) : return 1
01084     def execute(self) : return 1
01085     def stop(self) : return 1
01086     def finalize(self) : return 1
01087     def beginRun(self) : return 1
01088     def endRun(self) : return 1
01089 
01090 #----Enable tab completion------------------------------------------------------------
01091 try:
01092     import rlcompleter, readline
01093     readline.parse_and_bind("tab: complete")
01094 except:
01095     pass
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Defines

Generated at Thu Jun 28 2012 23:27:27 for Gaudi Framework, version v23r2 by Doxygen version 1.7.2 written by Dimitri van Heesch, © 1997-2004