GaudiPython.TupleUtils Namespace Reference

Functions

def _getToolSvc (kwargs)
 Helper private auxillary utility to get Tool Service. More...
 
def _nTuple_ (s, args)
 Retrive N-Tuple ( book on demand ) More...
 
def nTuple
 Retrieve (book-on-demand) 'Smart'-N-tuple object. More...
 
def activeTuples ()
 Return the list of active tools. More...
 
def releaseTuples ()
 Release the active tool/tuples. More...
 
def _TupleUtils_AtExit_ ()
 

Variables

string __author__ = "Vanya BELYAEV ibelyaev@physics.syr.edu"
 This module contains set of simple and useful utilities to booking and manipulation with N-Tuples (in the spirit of GaudiTuples<TYPE>) More...
 
tuple __all__
 
 _Tool = cpp.ITupleTool
 
 _Deco = cpp.GaudiPython.TupleToolDecorator
 
list _TOOLS_ = []
 
 ntuple = nTuple
 
 getNTuple = nTuple
 
 getNtuple = nTuple
 
 getntuple = nTuple
 
 getTuple = nTuple
 
 gettuple = nTuple
 

Function Documentation

def GaudiPython.TupleUtils._getToolSvc (   kwargs)
private

Helper private auxillary utility to get Tool Service.

Helper private auxillary utility to get Tool Service 

Definition at line 39 of file TupleUtils.py.

39 def _getToolSvc( **kwargs ) :
40  """ Helper private auxillary utility to get Tool Service """
41  svc = kwargs.get ( 'toolSvc' , None )
42  if not svc : svc = kwargs.get ( 'toolsvc' , None )
43  if not svc : svc = kwargs.get ( 'service' , None )
44  if not svc : svc = kwargs.get ( 'svc' , None )
45  else : return svc ## RETURN
46  gaudi = kwargs.get ( 'gaudi' , None )
47  if not gaudi : gaudi = AppMgr()
48  return gaudi.toolsvc() ## RETURN
49 
50 
51 # =============================================================================
def _getToolSvc(kwargs)
Helper private auxillary utility to get Tool Service.
Definition: TupleUtils.py:39
def GaudiPython.TupleUtils._nTuple_ (   s,
  args 
)
private

Retrive N-Tuple ( book on demand )

Retrive N-tuple ( book on demand )  

Definition at line 53 of file TupleUtils.py.

53 def _nTuple_ ( s , *args ) :
54  """ Retrive N-tuple ( book on demand ) """
55  print 'ARGS:' , args
56  return _Deco.nTuple ( s , *args)
57 
58 # =============================================================================
59 _nTuple_. __doc__ += "\n" + _Deco.nTuple . __doc__
60 _Tool.nTuple = _nTuple_
61 _Tool.ntuple = _nTuple_
62 
63 
64 # =============================================================================
def _nTuple_(s, args)
Retrive N-Tuple ( book on demand )
Definition: TupleUtils.py:53
def GaudiPython.TupleUtils._TupleUtils_AtExit_ ( )
private
AtExit function for GaudiPython.TupleUtils module

Definition at line 177 of file TupleUtils.py.

178  """
179  AtExit function for GaudiPython.TupleUtils module
180  """
181  if activeTuples() :
182  print 'WARNING: the list of local TupleTools is not empty!'
183  print 'WARNING: please use GaudiPython.TupleUtils.releaseTuples() at the end'
184 
def activeTuples()
Return the list of active tools.
Definition: TupleUtils.py:148
def GaudiPython.TupleUtils.activeTuples ( )

Return the list of active tools.

Return the list of active tools

Definition at line 148 of file TupleUtils.py.

148 def activeTuples () :
149  """
150  Return the list of active tools
151  """
152  return _TOOLS_
153 
154 # =============================================================================
def activeTuples()
Return the list of active tools.
Definition: TupleUtils.py:148
def GaudiPython.TupleUtils.nTuple (   dirpath,
  ID,
  ID2 = None,
  topdir = None,
  LUN = 'FILE1' 
)

Retrieve (book-on-demand) 'Smart'-N-tuple object.

Retrieve 'Smart'-N-tuple object.
N-tuple is booked on-demand.

Atetntion !!
The logical unit LUN must be configured by N-Tuple Service

Retrieve (book-n-demand) N-Tuple using
the  directory name and the title:
>>> t = nTuple ( 'the/path/to/directory' , ## the path to the directory
                 'N-tuple title'         , ## the title for N-Tuple
                  LUN = 'FILE1'          ) ## logical file unit

Retrieve (book-n-demand) N-Tuple using
the  directory name, literal ID and the title:
>>> t = nTuple ( 'the/path/to/directory' , ## the path to the directory
                 'Tuple1'                , ## the literal ID for N-Tuple
                 'N-tuple title'         , ## the title for N-Tuple
                  LUN = 'FILE1'          ) ## logical file unit

Retrieve (book-n-demand) N-Tuple using
the  directory name, numerical ID and the title:
>>> t = nTuple ( 'the/path/to/directory' , ## the path to the directory
                 124                     , ## the numerical ID for N-Tuple
                 'N-tuple title'         , ## the title for N-Tuple
                  LUN = 'FILE1'          ) ## logical file unit

Definition at line 66 of file TupleUtils.py.

66 def nTuple ( dirpath , ID , ID2 = None , topdir = None , LUN = 'FILE1' ) :
67  """
68  Retrieve 'Smart'-N-tuple object.
69  N-tuple is booked on-demand.
70 
71  Atetntion !!
72  The logical unit LUN must be configured by N-Tuple Service
73 
74  Retrieve (book-n-demand) N-Tuple using
75  the directory name and the title:
76  >>> t = nTuple ( 'the/path/to/directory' , ## the path to the directory
77  'N-tuple title' , ## the title for N-Tuple
78  LUN = 'FILE1' ) ## logical file unit
79 
80  Retrieve (book-n-demand) N-Tuple using
81  the directory name, literal ID and the title:
82  >>> t = nTuple ( 'the/path/to/directory' , ## the path to the directory
83  'Tuple1' , ## the literal ID for N-Tuple
84  'N-tuple title' , ## the title for N-Tuple
85  LUN = 'FILE1' ) ## logical file unit
86 
87  Retrieve (book-n-demand) N-Tuple using
88  the directory name, numerical ID and the title:
89  >>> t = nTuple ( 'the/path/to/directory' , ## the path to the directory
90  124 , ## the numerical ID for N-Tuple
91  'N-tuple title' , ## the title for N-Tuple
92  LUN = 'FILE1' ) ## logical file unit
93 
94 
95  """
96  toolSvc = _getToolSvc ()
97 
98  # construct the name of the intermediate TupleTool
99  name = 'Tuple'+LUN+"/"
100  if topdir : name += topdir
101  name += dirpath
102  name += "_%s"%ID
103  if ID2 : name += "_%s"%ID2
104  name=name.replace ( '.' , '_' )
105  name=name.replace ( '/' , '_' )
106  name=name.replace ( '\\' , '_' )
107  name=name.replace ( ' ' , '_' )
108 
109  ## define tool properties
110  t0 = GaudiPython.iAlgTool( 'ToolSvc.'+name )
111  t0.OutputLevel = 1
112  t0.NTupleLUN = LUN
113  t0.NTupleDir = dirpath
114  t0.PropertiesPrint = False
115  t0.OutputLevel = 4
116  if topdir : t0.NTupleTopDir = topdir
117 
118  ## get the tool from Tool service
119  tool = toolSvc.create ( 'TupleTool' ,
120  name ,
121  interface = _Tool )
122 
123  ## check the properties and redefine them if needed
124  t1 = GaudiPython.iAlgTool ( tool.name() , tool )
125  if t1.NTupleLUN != LUN : t1.NTupleLUN = LUN
126  if t1.NTupleDir != dirpath : t1.NTupleDir = dirpath
127  if topdir and ( t1.NTupleTopDir != topdir ) :
128  t1.NTupleTopDir = topdir
129 
130  _TOOLS_.append ( tool )
131  if not ID2 : return tool.nTuple ( ID ) ## RETURN
132 
133  return tool.nTuple ( ID , ID2 ) ## RETURN
134 
135 
def nTuple
Retrieve (book-on-demand) 'Smart'-N-tuple object.
Definition: TupleUtils.py:66
def GaudiPython.TupleUtils.releaseTuples ( )

Release the active tool/tuples.

Release the active tool/tuples
The method needs to be invoked explicitely at the end of the job

Definition at line 156 of file TupleUtils.py.

157  """
158  Release the active tool/tuples
159  The method needs to be invoked explicitely at the end of the job
160  """
161  if not _TOOLS_ : return
162  print ' %s/%s: release all pending ITupleTools: %s' % ( __file__ ,
163  __name__ ,
164  len(_TOOLS_) )
165  from GaudiPython.Bindings import _gaudi
166  if not _gaudi : return
167 
168  toolSvc = _getToolSvc()
169  if toolSvc.isValid() :
170  while _TOOLS_ :
171  t = _TOOLS_.pop()
172  if not t : continue
173  while 1 < t.refCount() :
174  toolSvc._its.releaseTool( t )
175 
176 # =============================================================================
def releaseTuples()
Release the active tool/tuples.
Definition: TupleUtils.py:156
def _getToolSvc(kwargs)
Helper private auxillary utility to get Tool Service.
Definition: TupleUtils.py:39

Variable Documentation

tuple GaudiPython.TupleUtils.__all__
Initial value:
1 = (
2  'nTuple' , ## function to book/retrieve N-tuple
3  'getNTuple' , ## ditto
4  'getNtuple' , ## ditto
5  'getntuple' , ## ditto
6  'gettuple' , ## ditto
7  'activeTuples' , ## get the list of all active n-tuples
8  'releaseTuples' ## release all actibe N-tuples
9  )

Definition at line 16 of file TupleUtils.py.

string GaudiPython.TupleUtils.__author__ = "Vanya BELYAEV ibelyaev@physics.syr.edu"

This module contains set of simple and useful utilities to booking and manipulation with N-Tuples (in the spirit of GaudiTuples<TYPE>)

Author
Vanya BELYAEV ibely.nosp@m.aev@.nosp@m.physi.nosp@m.cs.s.nosp@m.yr.ed.nosp@m.u

2007-08-04

Definition at line 14 of file TupleUtils.py.

GaudiPython.TupleUtils._Deco = cpp.GaudiPython.TupleToolDecorator

Definition at line 32 of file TupleUtils.py.

GaudiPython.TupleUtils._Tool = cpp.ITupleTool

Definition at line 31 of file TupleUtils.py.

list GaudiPython.TupleUtils._TOOLS_ = []

Definition at line 35 of file TupleUtils.py.

GaudiPython.TupleUtils.getNTuple = nTuple

Definition at line 140 of file TupleUtils.py.

GaudiPython.TupleUtils.getNtuple = nTuple

Definition at line 141 of file TupleUtils.py.

GaudiPython.TupleUtils.getntuple = nTuple

Definition at line 142 of file TupleUtils.py.

GaudiPython.TupleUtils.getTuple = nTuple

Definition at line 143 of file TupleUtils.py.

GaudiPython.TupleUtils.gettuple = nTuple

Definition at line 144 of file TupleUtils.py.

GaudiPython.TupleUtils.ntuple = nTuple

Definition at line 139 of file TupleUtils.py.