ATLAS Offline Software
Public Member Functions | Public Attributes | Static Public Attributes | Private Member Functions | Private Attributes | List of all members
python.trfArgClasses.argSubstepSteering Class Reference

Special argument class to hold steering information. More...

Inheritance diagram for python.trfArgClasses.argSubstepSteering:
Collaboration diagram for python.trfArgClasses.argSubstepSteering:

Public Member Functions

def value (self)
 Return argument value. More...
 
def dumpvalue (self)
 
def prodsysDescription (self)
 
def value (self, value)
 
def returnMyValue (self, name=None, substep=None, first=False, exe=None)
 Return the value of this substep arg for an executor with the given parameters. More...
 
def isRunarg (self)
 Return runarg status. More...
 
def name (self)
 Name getter. More...
 
def name (self, value)
 Name setter. More...
 
def __str__ (self)
 String conversion of our value. More...
 
def __repr__ (self)
 Repr conversion of our value. More...
 
def __eq__ (self, other)
 Comparison is based on value attribute. More...
 
def __nq__ (self, other)
 
def __lt__ (self, other)
 
def __gt__ (self, other)
 

Public Attributes

 value
 

Static Public Attributes

 steeringAlises
 

Private Member Functions

def _parseSetterString (self, string)
 
def _parseSteeringString (self, ivalue)
 
def _parseStringAsSubstep (self, string)
 Parse a string for substep:value format. More...
 

Private Attributes

 _value
 
 _dumpvalue
 
 _defaultSubstep
 
 _separator
 
 _runarg
 
 _name
 

Detailed Description

Special argument class to hold steering information.

Definition at line 2317 of file trfArgClasses.py.

Member Function Documentation

◆ __eq__()

def python.trfArgClasses.argument.__eq__ (   self,
  other 
)
inherited

Comparison is based on value attribute.

Definition at line 161 of file trfArgClasses.py.

161  def __eq__(self,other):
162  return self.value == other.value
163 

◆ __gt__()

def python.trfArgClasses.argument.__gt__ (   self,
  other 
)
inherited

Definition at line 170 of file trfArgClasses.py.

170  def __gt__(self, other):
171  return self.value > other.value
172 

◆ __lt__()

def python.trfArgClasses.argument.__lt__ (   self,
  other 
)
inherited

Definition at line 167 of file trfArgClasses.py.

167  def __lt__(self, other):
168  return self.value < other.value
169 

◆ __nq__()

def python.trfArgClasses.argument.__nq__ (   self,
  other 
)
inherited

Definition at line 164 of file trfArgClasses.py.

164  def __nq__(self, other):
165  return self.value != other.value
166 

◆ __repr__()

def python.trfArgClasses.argument.__repr__ (   self)
inherited

Repr conversion of our value.

Reimplemented in python.trfArgClasses.argList.

Definition at line 157 of file trfArgClasses.py.

157  def __repr__(self):
158  return repr(self.value)
159 

◆ __str__()

def python.trfArgClasses.argument.__str__ (   self)
inherited

String conversion of our value.

Reimplemented in python.trfArgClasses.argFile, python.trfArgClasses.argKeyFloatValueList, python.trfArgClasses.argIntList, python.trfArgClasses.argList, and python.trfArgClasses.argString.

Definition at line 153 of file trfArgClasses.py.

153  def __str__(self):
154  return '{0}: Value {1} (isRunArg={2})'.format(self.__class__.__name__, self._value, self._runarg)
155 

◆ _parseSetterString()

def python.trfArgClasses.argSubstepSteering._parseSetterString (   self,
  string 
)
private

Definition at line 2404 of file trfArgClasses.py.

2404  def _parseSetterString(self, string):
2405  if string in argSubstepSteering.steeringAlises:
2406  return argSubstepSteering.steeringAlises[string]
2407 

◆ _parseSteeringString()

def python.trfArgClasses.argSubstepSteering._parseSteeringString (   self,
  ivalue 
)
private

Definition at line 2408 of file trfArgClasses.py.

2408  def _parseSteeringString(self, ivalue):
2409  retvalue = []
2410  for subvalue in ivalue.split(','):
2411  matchedParts = re.match(r'(in|out)(\+|\-)([A-Z_]+)$', subvalue)
2412  if not matchedParts:
2413  raise trfExceptions.TransformArgException(trfExit.nameToCode('TRF_ARG_CONV_FAIL'),
2414  'Failed to convert string {0!s} to argSubstepSteering'.format(subvalue))
2415  retvalue.append((matchedParts.group(1), matchedParts.group(2), matchedParts.group(3)))
2416  return retvalue
2417 
2418 

◆ _parseStringAsSubstep()

def python.trfArgClasses.argSubstep._parseStringAsSubstep (   self,
  string 
)
privateinherited

Parse a string for substep:value format.

If the string matches the substep specifier regexp then we return the two parts; if not then the substep is returned as self._defaultSubstep, with the entire string passed back as the value

Parameters
stringThe string which should be parsed

Reimplemented in python.trfArgClasses.argSubstepList.

Definition at line 1987 of file trfArgClasses.py.

1987  def _parseStringAsSubstep(self, string):
1988  subStepMatch = re.match(r'([a-zA-Z0-9,]+)' + self._separator + r'(.*)', string)
1989  subStepList = []
1990  if subStepMatch:
1991  subStep = subStepMatch.group(1).split(',')
1992  subStepValue = subStepMatch.group(2)
1993  else:
1994  subStep = [self._defaultSubstep]
1995  subStepValue = string
1996  msg.debug('Parsed {0} as substep {1}, argument {2}'.format(string, subStep, subStepValue))
1997  for step in subStep:
1998  subStepList.append((step, subStepValue))
1999  return subStepList
2000 
2001 

◆ dumpvalue()

def python.trfArgClasses.argSubstepSteering.dumpvalue (   self)

Definition at line 2346 of file trfArgClasses.py.

2346  def dumpvalue(self):
2347  return self._dumpvalue
2348 

◆ isRunarg()

def python.trfArgClasses.argument.isRunarg (   self)
inherited

Return runarg status.

Definition at line 134 of file trfArgClasses.py.

134  def isRunarg(self):
135  return self._runarg
136 

◆ name() [1/2]

def python.trfArgClasses.argument.name (   self)
inherited

Name getter.

Reimplemented in python.trfArgClasses.argFile.

Definition at line 139 of file trfArgClasses.py.

139  def name(self):
140  return self._name
141 

◆ name() [2/2]

def python.trfArgClasses.argument.name (   self,
  value 
)
inherited

Name setter.

Reimplemented in python.trfArgClasses.argFile.

Definition at line 144 of file trfArgClasses.py.

144  def name(self, value):
145  self._name = value
146 

◆ prodsysDescription()

def python.trfArgClasses.argSubstepSteering.prodsysDescription (   self)

Reimplemented from python.trfArgClasses.argSubstep.

Definition at line 2350 of file trfArgClasses.py.

2350  def prodsysDescription(self):
2351  desc = {'type': 'substep', 'substeptype': 'steering', 'listtype': 'str', 'separator': self._separator,
2352  'default': self._defaultSubstep}
2353  return desc
2354 

◆ returnMyValue()

def python.trfArgClasses.argSubstep.returnMyValue (   self,
  name = None,
  substep = None,
  first = False,
  exe = None 
)
inherited

Return the value of this substep arg for an executor with the given parameters.

Parameters
nameExecutor name
substepExecutor substep nickname
firstBoolean flag set true if this is the first executor in the chain
exeExecutor instance, from which 'name', 'substep' and 'first' can be taken.

Definition at line 2007 of file trfArgClasses.py.

2007  def returnMyValue(self, name=None, substep=None, first=False, exe=None):
2008  if exe:
2009  name = exe.name
2010  substep = exe.substep
2011  first = exe.conf.firstExecutor
2012 
2013  name = commonExecutorStepName(name)
2014 
2015  value = None
2016 
2017  if name in self._value:
2018  value = self._value[name]
2019  elif substep in self._value:
2020  value = self._value[substep]
2021  elif first and 'first' in self._value:
2022  value = self._value['first']
2023  elif 'default' in self._value:
2024  value = self._value['default']
2025 
2026 
2034  if 'all' in self._value:
2035  if value is None:
2036  value = self._value['all']
2037  elif isinstance(value, list):
2038  value = self._value['all'] + value
2039 
2040  msg.debug('From substep argument {myvalue} picked value "{value}" for {name}, {substep}, first={first}'.format(myvalue=self._value, value=value, name=name, substep=substep, first=first))
2041 
2042  return value
2043 

◆ value() [1/2]

def python.trfArgClasses.argSubstepSteering.value (   self)

Return argument value.

Returns
Current value

Reimplemented from python.trfArgClasses.argSubstep.

Definition at line 2340 of file trfArgClasses.py.

2340  def value(self):
2341  return self._value
2342 

◆ value() [2/2]

def python.trfArgClasses.argSubstepSteering.value (   self,
  value 
)

For strings passed to the setter we expect the format to be substep:{in/out}{+/-}DATATYPE or to be a steering alias, which is then expanded to the more complex format. This is then cast into a dictionary of tuples {substep: [('in/out', '+/-', DATATYPE), ...], ...}

Reimplemented from python.trfArgClasses.argSubstep.

Definition at line 2359 of file trfArgClasses.py.

2359  def value(self, value):
2360  msg.debug('Attempting to set argSubstepSteering from {0!s} (type {1})'.format(value, type(value)))
2361  if value is None:
2362  self._value = {}
2363  self._dumpvalue = [""]
2364  elif isinstance(value, dict):
2365  # OK, this should be the direct setable dictionary - but do a check of that
2366  for k, v in value.items():
2367  if not isinstance(k, str) or not isinstance(v, list):
2368  raise trfExceptions.TransformArgException(trfExit.nameToCode('TRF_ARG_CONV_FAIL'),
2369  'Failed to convert dict {0!s} to argSubstepSteering'.format(value))
2370  for subv in v:
2371  if not isinstance(subv, (list, tuple)) or len(subv) != 3 or subv[0] not in ('in', 'out') or subv[1] not in ('+', '-'):
2372  raise trfExceptions.TransformArgException(trfExit.nameToCode('TRF_ARG_CONV_FAIL'),
2373  'Failed to convert dict {0!s} to argSubstepSteering'.format(value))
2374  self._value = value
2375  # Note we are a little careful here to never reset the dumpvalue - this is
2376  # because when processing the _list_ of steering arguments down to a single
2377  # multi-valued argument we re-call value() with an expanded diectionary and
2378  # one can nievely reset dumpvalue by mistake
2379  self._dumpvalue = getattr(self, "_dumpvalue", value)
2380  elif isinstance(value, (str, list, tuple)):
2381  if isinstance(value, str):
2382  value = [value,]
2383  self._dumpvalue = getattr(self, "_dumpvalue", value)
2384  # Now we have a list of strings to parse
2385  self._value = {}
2386  for item in value:
2387  if not isinstance(item, str):
2388  raise trfExceptions.TransformArgException(trfExit.nameToCode('TRF_ARG_CONV_FAIL'),
2389  'Failed to convert list item {0!s} to substep (should be a string)'.format(item))
2390  if item in argSubstepSteering.steeringAlises:
2391  msg.debug("Found value {0} in steeringAlises ({1})".format(item, argSubstepSteering.steeringAlises[item]))
2392  for substep, steerlist in argSubstepSteering.steeringAlises[item].items():
2393  if substep in self._value:
2394  self._value[substep].extend(steerlist)
2395  else:
2396  self._value[substep] = steerlist
2397  else:
2398  subStepList = self._parseStringAsSubstep(item)
2399  self._value.update(dict([(subStep[0], self._parseSteeringString(subStep[1])) for subStep in subStepList]))
2400  else:
2401  raise trfExceptions.TransformArgException(trfExit.nameToCode('TRF_ARG_CONV_FAIL'),
2402  'Setter value {0!s} (type {1}) for substep argument cannot be parsed'.format(value, type(value)))
2403 

Member Data Documentation

◆ _defaultSubstep

python.trfArgClasses.argSubstep._defaultSubstep
privateinherited

Definition at line 1952 of file trfArgClasses.py.

◆ _dumpvalue

python.trfArgClasses.argSubstepSteering._dumpvalue
private

Definition at line 2363 of file trfArgClasses.py.

◆ _name

python.trfArgClasses.argument._name
privateinherited

Definition at line 111 of file trfArgClasses.py.

◆ _runarg

python.trfArgClasses.argument._runarg
privateinherited

Definition at line 110 of file trfArgClasses.py.

◆ _separator

python.trfArgClasses.argSubstep._separator
privateinherited

Definition at line 1953 of file trfArgClasses.py.

◆ _value

python.trfArgClasses.argSubstepSteering._value
private

Definition at line 2362 of file trfArgClasses.py.

◆ steeringAlises

python.trfArgClasses.argSubstepSteering.steeringAlises
static

Definition at line 2327 of file trfArgClasses.py.

◆ value

python.trfArgClasses.argument.value
inherited
Note
We have a default of None here, but all derived classes should definitely have their own value setter and translate this value to something sensible for their underlying value type. N.B. As most argument classes use this default constructor it must call the @value .setter function!

Definition at line 118 of file trfArgClasses.py.


The documentation for this class was generated from the following file:
vtune_athena.format
format
Definition: vtune_athena.py:14
athena.value
value
Definition: athena.py:124
python.CaloAddPedShiftConfig.type
type
Definition: CaloAddPedShiftConfig.py:42
PyAthena::repr
std::string repr(PyObject *o)
returns the string representation of a python object equivalent of calling repr(o) in python
Definition: PyAthenaUtils.cxx:106
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:240
TrigJetMonitorAlgorithm.items
items
Definition: TrigJetMonitorAlgorithm.py:71
python.trfExeStepTools.commonExecutorStepName
def commonExecutorStepName(name)
Definition: trfExeStepTools.py:7
ActsTrk::detail::MakeDerivedVariant::extend
constexpr std::variant< Args..., T > extend(const std::variant< Args... > &, const T &)
Definition: MakeDerivedVariant.h:17
Trk::split
@ split
Definition: LayerMaterialProperties.h:38