The Gaudi Framework  master (37c0b60a)
GaudiConfig2 Namespace Reference

Namespaces

 _configurables
 
 _db
 
 Configurables
 
 semantics
 

Functions

def _makeConfigDict (iterable)
 
def mergeConfigs (*configs)
 
def invokeConfig (func, *args, **kwargs)
 

Variables

 Configurables = ConfigurablesDB(__name__ + ".Configurables")
 
 basestring
 
 CALLABLE_FORMAT
 

Function Documentation

◆ _makeConfigDict()

def GaudiConfig2._makeConfigDict (   iterable)
private

Definition at line 38 of file __init__.py.

38 def _makeConfigDict(iterable):
39  try: # pragma no cover
40  from collections.abc import Mapping
41  except ImportError: # pragma no cover
42  from collections import Mapping
43 
44  if iterable is None:
45  return {}
46  if not isinstance(iterable, Mapping):
47  return {c.name: c for c in iterable}
48  return iterable
49 
50 

◆ invokeConfig()

def GaudiConfig2.invokeConfig (   func,
args,
**  kwargs 
)

Definition at line 70 of file __init__.py.

70 def invokeConfig(func, *args, **kwargs):
71  from importlib import import_module
72 
73  if not callable(func):
74  if isinstance(func, basestring):
75  m = CALLABLE_FORMAT.match(func)
76  if m and m.group("module"):
77  func = getattr(import_module(m.group("module")), m.group("callable"))
78  elif m and m.group("path"):
79  globals = {"__file__": m.group("path")}
80  exec(
81  compile(
82  open(m.group("path"), "rb").read(), m.group("path"), "exec"
83  ),
84  globals,
85  )
86  func = globals[m.group("callable")]
87  else:
88  raise ValueError("invalid callable id %r" % func)
89  else:
90  raise TypeError("expected either a callable or a string as first argument")
91  return _makeConfigDict(func(*args, **kwargs))

◆ mergeConfigs()

def GaudiConfig2.mergeConfigs ( configs)
Merge configuration dictionaries ({'name': Configurable('name'), ...}) or
lists ([Configurable('name'), ...]) into one configuration dictionary.

**warning** the configurable instances passed are not cloned during the
merging, so the arguments to this function cannot be used afterwards

Definition at line 51 of file __init__.py.

51 def mergeConfigs(*configs):
52  """
53  Merge configuration dictionaries ({'name': Configurable('name'), ...}) or
54  lists ([Configurable('name'), ...]) into one configuration dictionary.
55 
56  **warning** the configurable instances passed are not cloned during the
57  merging, so the arguments to this function cannot be used afterwards
58  """
59  result = {}
60  for config in configs:
61  config = _makeConfigDict(config)
62  for name in config:
63  if name in result:
64  result[name].merge(config[name])
65  else:
66  result[name] = config[name]
67  return result
68 
69 

Variable Documentation

◆ basestring

GaudiConfig2.basestring

Definition at line 28 of file __init__.py.

◆ CALLABLE_FORMAT

GaudiConfig2.CALLABLE_FORMAT

Definition at line 33 of file __init__.py.

◆ Configurables

GaudiConfig2.Configurables = ConfigurablesDB(__name__ + ".Configurables")

Definition at line 14 of file __init__.py.

GaudiConfig2._makeConfigDict
def _makeConfigDict(iterable)
Definition: __init__.py:38
GaudiConfig2.invokeConfig
def invokeConfig(func, *args, **kwargs)
Definition: __init__.py:70
cpluginsvc.func
func
Definition: cpluginsvc.py:235
GaudiConfig2.mergeConfigs
def mergeConfigs(*configs)
Definition: __init__.py:51
hivetimeline.read
def read(f, regex=".*", skipevents=0)
Definition: hivetimeline.py:32
merge
int merge(const char *target, const char *source, bool fixup=false, bool dbg=true)
Definition: merge.C:430