Coverage for pySDC/core/common.py: 100%
22 statements
« prev ^ index » next coverage.py v7.6.1, created at 2024-09-09 14:59 +0000
« prev ^ index » next coverage.py v7.6.1, created at 2024-09-09 14:59 +0000
1#!/usr/bin/env python3
2# -*- coding: utf-8 -*-
3"""
4Description
5-----------
7Module containing utility classe(s) from which inherit some of the pySDC base
8classes.
9"""
10from pySDC.core.errors import ReadOnlyError
13class _MetaRegisterParams(type):
14 """Metaclass for RegisterParams base class"""
16 def __new__(cls, name, bases, dct):
17 obj = super().__new__(cls, name, bases, dct)
18 obj._parNamesReadOnly = set()
19 obj._parNames = set()
20 return obj
23class RegisterParams(metaclass=_MetaRegisterParams):
24 """
25 Base class to register parameters.
27 Attributes
28 ----------
29 params : dict (property)
30 Dictionary containing names and values of registered parameters.
31 _parNames : set of str
32 Names of all the registered parameters.
33 _parNamesReadOnly : set of str
34 Names of all the parameters registered as read-only.
35 """
37 def _makeAttributeAndRegister(self, *names, localVars=None, readOnly=False):
38 """
39 Register a list of attribute name as parameters of the class.
41 Parameters
42 ----------
43 *names : list of str
44 The name of the parameters to be registered (should be class attributes).
45 localVars : dict
46 Dictionary containing key=names and values=paramValues for each
47 parNames given in names. Can be provided, for instance, using
48 `locals()` built-in dictionary. MUST BE provided as soon as
49 names contains anything.
50 readOnly : bool, optional
51 Wether or not store the parameters as read-only attributes
52 """
53 if len(names) > 1 and localVars is None:
54 raise ValueError("a dictionary must be provided in localVars with parameters values")
55 # Set parameters as attributes
56 for name in names:
57 try:
58 super().__setattr__(name, localVars[name])
59 except KeyError as e: # pragma: no cover
60 raise ValueError(f'value for {name} not given in localVars') from e
61 # Register as class parameter
62 if readOnly:
63 self._parNamesReadOnly = self._parNamesReadOnly.union(names)
64 else:
65 self._parNames = self._parNames.union(names)
67 @property
68 def params(self):
69 """Dictionary containing names and values of registered parameters"""
70 return {name: getattr(self, name) for name in self._parNamesReadOnly.union(self._parNames)}
72 def __setattr__(self, name, value):
73 if name in self._parNamesReadOnly:
74 raise ReadOnlyError(name)
75 super().__setattr__(name, value)