LSST Applications g1653933729+34a971ddd9,g1a997c3884+34a971ddd9,g2160c40384+da0d0eec6b,g28da252d5a+1236b942f7,g2bbee38e9b+e5a1bc5b38,g2bc492864f+e5a1bc5b38,g2ca4be77d2+192fe503f0,g2cdde0e794+704103fe75,g3156d2b45e+6e87dc994a,g347aa1857d+e5a1bc5b38,g35bb328faa+34a971ddd9,g3a166c0a6a+e5a1bc5b38,g3e281a1b8c+8ec26ec694,g4005a62e65+ba0306790b,g414038480c+9f5be647b3,g41af890bb2+c3a10c924f,g5065538af8+e7237db731,g5a0bb5165c+eae055db26,g717e5f8c0f+b65b5c3ae4,g80478fca09+4ce5a07937,g82479be7b0+08790af60f,g858d7b2824+b65b5c3ae4,g9125e01d80+34a971ddd9,ga5288a1d22+5df949a35e,gae0086650b+34a971ddd9,gb58c049af0+ace264a4f2,gbd397ab92a+2141afb137,gc28159a63d+e5a1bc5b38,gc805d3fbd4+b65b5c3ae4,gcf0d15dbbd+97632ccc20,gd6b7c0dfd1+de826e8718,gda6a2b7d83+97632ccc20,gdaeeff99f8+7774323b41,ge2409df99d+e6cadbf968,ge33fd446bb+b65b5c3ae4,ge79ae78c31+e5a1bc5b38,gf0baf85859+890af219f9,gf5289d68f6+a27069ed62,w.2024.37
LSST Data Management Base Package
Loading...
Searching...
No Matches
Namespaces | Classes | Typedefs | Functions
lsst::afw::typehandling Namespace Reference

Namespaces

namespace  _GenericMap
 
namespace  _SimpleGenericMap
 
namespace  detail
 
namespace  test
 
namespace  testUtils
 

Classes

class  GenericMap
 Interface for a heterogeneous map. More...
 
class  Key
 Key for type-safe lookup in a GenericMap. More...
 
class  MutableGenericMap
 Interface for a GenericMap that allows element addition and removal. More...
 
class  PolymorphicValue
 Container that passes Storable objects by value while preserving type. More...
 
class  SimpleGenericMap
 A GenericMap that allows insertion and deletion of arbitrary values. More...
 
class  Storable
 Interface supporting iteration over heterogenous containers. More...
 
class  StorableHelper
 "Trampoline" for Storable to let it be used as a base class in Python. More...
 
class  UnsupportedOperationException
 Exception thrown by Storable operations for unimplemented operations. More...
 

Typedefs

using PyStorable = py::class_<Storable, PySharedPtr<Storable>, table::io::Persistable, StorableHelper<>>
 

Functions

template<typename V , typename K >
constexpr Key< K, V > makeKey (K const &id)
 Factory function for Key, to enable type parameter inference.
 
template<typename K , typename V >
std::ostreamoperator<< (std::ostream &os, Key< K, V > const &key)
 Output operator for Key.
 
void swap (PolymorphicValue &lhs, PolymorphicValue &rhs) noexcept
 Swap specialization for PolymorphicValue.
 
std::string declareGenericMapRestrictions (std::string const &className, std::string const &keyName)
 
std::ostreamoperator<< (std::ostream &os, Storable const &storable)
 Output operator for Storable.
 
void wrapGenericMap (cpputils::python::WrapperCollection &wrappers)
 
void wrapSimpleGenericMap (cpputils::python::WrapperCollection &wrappers)
 
void wrapStorable (cpputils::python::WrapperCollection &wrappers)
 
 PYBIND11_MODULE (_typehandling, mod)
 

Typedef Documentation

◆ PyStorable

Definition at line 41 of file _Storable.cc.

Function Documentation

◆ declareGenericMapRestrictions()

std::string lsst::afw::typehandling::declareGenericMapRestrictions ( std::string const & className,
std::string const & keyName )

Definition at line 37 of file python.cc.

37 {
38 // Give the class a custom docstring to avoid confusing Python users
39 std::string docstring = R"docstring(
40For compatibility with C++, ``)docstring" +
41 className + R"docstring(`` has the following restrictions:
42 - all keys must be )docstring" + keyName +
43 R"docstring(
44 - values must be built-in types or subclasses of `lsst.afw.typehandling.Storable`.
45 Almost any user-defined class in C++ or Python can have

◆ makeKey()

template<typename V , typename K >
constexpr Key< K, V > makeKey ( K const & id)
constexpr

Factory function for Key, to enable type parameter inference.

Parameters
idthe key ID to create.
Returns
a key of the desired type
Exception Safety
Provides the same exception safety as the copy-constructor of K.

Calling this function prevents you from having to explicitly name the key type:

auto key = makeKey<int>("foo");

Definition at line 173 of file Key.h.

173 {
174 return Key<K, V>(id);
175}
Key for type-safe lookup in a GenericMap.
Definition Key.h:52

◆ operator<<() [1/2]

template<typename K , typename V >
std::ostream & operator<< ( std::ostream & os,
Key< K, V > const & key )

Output operator for Key.

The output will use C++ template notation for the key; for example, a key "foo" pointing to an int may print as "foo<int>".

Parameters
osthe desired output stream
keythe key to print
Returns
a reference to os
Exception Safety
Provides basic exception safety if the output operator of K is exception-safe.
Warning
the type name is compiler-specific and may be mangled or unintuitive; for example, some compilers say "i" instead of "int"

Definition at line 196 of file Key.h.

196 {
197 static const std::string typeStr = boost::core::demangle(typeid(V).name());
198 static const std::string constStr = std::is_const<V>::value ? " const" : "";
199 static const std::string volatileStr = std::is_volatile<V>::value ? " volatile" : "";
200 os << key.getId() << "<" << typeStr << constStr << volatileStr << ">";
201 return os;
202}
table::Key< std::string > name
Definition Amplifier.cc:116
std::ostream * os
Definition Schema.cc:557
constexpr K const & getId() const noexcept
Return the identifier of this field.
Definition Key.h:105

◆ operator<<() [2/2]

std::ostream & operator<< ( std::ostream & os,
Storable const & storable )
inline

Output operator for Storable.

Parameters
osthe desired output stream
storablethe object to print
Returns
a reference to os
Exceptions
UnsupportedOperationExceptionThrown if storable does not have an implementation of Storable::toString.

Definition at line 174 of file Storable.h.

174 {
175 return os << storable.toString();
176}

◆ PYBIND11_MODULE()

lsst::afw::typehandling::PYBIND11_MODULE ( _typehandling ,
mod  )

Definition at line 41 of file _typehandling.cc.

41 {
42 WrapperCollection w(mod, "lsst.afw.typehandling");
46 w.finish();
47}
A helper class for subdividing pybind11 module across multiple translation units (i....
Definition python.h:242
void wrapGenericMap(cpputils::python::WrapperCollection &wrappers)
void wrapSimpleGenericMap(cpputils::python::WrapperCollection &wrappers)
void wrapStorable(cpputils::python::WrapperCollection &wrappers)
Definition _Storable.cc:43
double w
Definition CoaddPsf.cc:70

◆ swap()

void swap ( PolymorphicValue & lhs,
PolymorphicValue & rhs )
inlinenoexcept

Swap specialization for PolymorphicValue.

Definition at line 152 of file PolymorphicValue.h.

152{ lhs.swap(rhs); }
void swap(PolymorphicValue &other) noexcept
Exchange the contents of this container and another.

◆ wrapGenericMap()

void lsst::afw::typehandling::wrapGenericMap ( cpputils::python::WrapperCollection & wrappers)

Definition at line 221 of file _GenericMap.cc.

221 {
222 declareGenericMap<std::string>(wrappers, "S", "strings");
223 declareMutableGenericMap<std::string>(wrappers, "S", "strings");
224}

◆ wrapSimpleGenericMap()

void lsst::afw::typehandling::wrapSimpleGenericMap ( cpputils::python::WrapperCollection & wrappers)

Definition at line 79 of file _SimpleGenericMap.cc.

79 {
80 declareSimpleGenericMap<std::string>(wrappers, "S", "strings");
81}

◆ wrapStorable()

void lsst::afw::typehandling::wrapStorable ( cpputils::python::WrapperCollection & wrappers)

Definition at line 43 of file _Storable.cc.

43 {
44 wrappers.addInheritanceDependency("lsst.afw.table.io");
45
46 wrappers.wrapType(PyStorable(wrappers.module, "Storable"), [](auto& mod, auto& cls) {
47 // Do not wrap methods inherited from Persistable
48 cls.def(py::init<>()); // Dummy constructor for pure-Python subclasses
49 // Do not wrap optional Storable methods; let subclasses do it as appropriate
50 cls.def("__eq__", [](Storable const& self, Storable const& other) { return self.equals(other); },
51 "other"_a);
52 });
53
54 wrappers.wrapType(
55 py::class_<StorableHelperFactory>(
56 wrappers.module, "StorableHelperFactory"
57 ),
58 [](auto& mod, auto& cls) {
59 cls.def(py::init<std::string&, std::string&>());
60 }
61 );
62}
void addInheritanceDependency(std::string const &name)
Indicate an external module that provides a base class for a subsequent addType call.
Definition python.h:343
PyType wrapType(PyType cls, ClassWrapperCallback function, bool setModuleName=true)
Add a type (class or enum) wrapper, deferring method and other attribute definitions until finish() i...
Definition python.h:391
py::class_< Storable, PySharedPtr< Storable >, table::io::Persistable, StorableHelper<> > PyStorable
Definition _Storable.cc:41