StorageClass¶
- class lsst.daf.butler.StorageClass(name: str | None = None, pytype: Type | str | None = None, components: Dict[str, StorageClass] | None = None, derivedComponents: Dict[str, StorageClass] | None = None, parameters: Sequence | Set | None = None, delegate: str | None = None, converters: Dict[str, str] | None = None)¶
Bases:
object
Class describing how a label maps to a particular Python type.
- Parameters:
- name
str
Name to use for this class.
- pytype
type
orstr
Python type (or name of type) to associate with the
StorageClass
- components
dict
, optional dict
mapping name of a component to anotherStorageClass
.- derivedComponents
dict
, optional dict
mapping name of a derived component to anotherStorageClass
.- parameters
Sequence
orSet
Parameters understood by this
StorageClass
that can control reading of data from datastores.- delegate
str
, optional Fully qualified name of class supporting assembly and disassembly of a
pytype
instance.- converters
dict
[str
,str
], optional Mapping of python type to function that can be called to convert that python type to the valid type of this storage class.
- name
Attributes Summary
Return the components associated with this
StorageClass
.Return the type converters supported by this
StorageClass
.Return the type converters as python types.
Class to use to delegate type-specific actions.
Return derived components associated with
StorageClass
.Return
set
of names of supported parameters.Return Python type associated with this
StorageClass
.Methods Summary
Return all defined components.
can_convert
(other)Return
True
if this storage class can convert python types in the other storage class.coerce_type
(incorrect)Coerce the supplied incorrect instance to the python type associated with this
StorageClass
.delegate
()Return an instance of a storage class delegate.
filterParameters
(parameters[, subset])Filter out parameters that are not known to this
StorageClass
.Return Boolean indicating whether this is a composite or not.
is_type
(other[, compare_types])Return Boolean indicating whether the supplied type matches the type in this
StorageClass
.Return set of all parameters known to this
StorageClass
.validateInstance
(instance)Check that the supplied Python object has the expected Python type.
validateParameters
([parameters])Check that the parameters are known to this
StorageClass
.Attributes Documentation
- components¶
Return the components associated with this
StorageClass
.
- converters¶
Return the type converters supported by this
StorageClass
.
- converters_by_type¶
Return the type converters as python types.
- delegateClass¶
Class to use to delegate type-specific actions.
- derivedComponents¶
Return derived components associated with
StorageClass
.
- pytype¶
Return Python type associated with this
StorageClass
.
Methods Documentation
- allComponents() Mapping[str, StorageClass] ¶
Return all defined components.
This mapping includes all the derived and read/write components for the corresponding storage class.
- Returns:
- comp
dict
of [str
,StorageClass
] The component name to storage class mapping.
- comp
- can_convert(other: StorageClass) bool ¶
Return
True
if this storage class can convert python types in the other storage class.- Parameters:
- other
StorageClass
The storage class to check.
- other
- Returns:
- coerce_type(incorrect: Any) Any ¶
Coerce the supplied incorrect instance to the python type associated with this
StorageClass
.- Parameters:
- incorrect
object
An object that might be the incorrect type.
- incorrect
- Returns:
- correct
object
An object that matches the python type of this
StorageClass
. Can be the same object as given. IfNone
,None
will be returned.
- correct
- Raises:
- TypeError
Raised if no conversion can be found.
- delegate() StorageClassDelegate ¶
Return an instance of a storage class delegate.
- Returns:
- delegate
StorageClassDelegate
Instance of the delegate associated with this
StorageClass
. The delegate is constructed with thisStorageClass
.
- delegate
- Raises:
- TypeError
This StorageClass has no associated delegate.
- filterParameters(parameters: Mapping[str, Any] | None, subset: Collection | None = None) Mapping[str, Any] ¶
Filter out parameters that are not known to this
StorageClass
.- Parameters:
- parameters
Mapping
, optional Candidate parameters. Can be
None
if no parameters have been provided.- subset
Collection
, optional Subset of supported parameters that the caller is interested in using. The subset must be known to the
StorageClass
if specified. IfNone
the supplied parameters will all be checked, else only the keys in this set will be checked.
- parameters
- Returns:
- filtered
Mapping
Valid parameters. Empty
dict
if none are suitable.
- filtered
- Raises:
- ValueError
Raised if the provided subset is not a subset of the supported parameters or if it is an empty set.
- isComposite() bool ¶
Return Boolean indicating whether this is a composite or not.
- Returns:
- isComposite
bool
True
if thisStorageClass
is a composite,False
otherwise.
- isComposite
- is_type(other: Type, compare_types: bool = False) bool ¶
Return Boolean indicating whether the supplied type matches the type in this
StorageClass
.- Parameters:
- Returns:
Notes
If this
StorageClass
has not yet imported the Python type the check is done against the full type name, this prevents an attempt to import the type when it will likely not match.
- knownParameters() Set[str] ¶
Return set of all parameters known to this
StorageClass
.The set includes parameters understood by components of a composite.
- Returns:
- known
set
All parameter keys of this
StorageClass
and the component storage classes.
- known
- validateInstance(instance: Any) bool ¶
Check that the supplied Python object has the expected Python type.
- Parameters:
- instance
object
Object to check.
- instance
- Returns:
- isOk
bool
True if the supplied instance object can be handled by this
StorageClass
, False otherwise.
- isOk
- validateParameters(parameters: Collection | None = None) None ¶
Check that the parameters are known to this
StorageClass
.Does not check the values.
- Parameters:
- parameters
Collection
, optional Collection containing the parameters. Can be
dict
-like orset
-like. The parameter values are not checked. If no parameters are supplied, always returns without error.
- parameters
- Raises:
- KeyError
Some parameters are not understood by this
StorageClass
.