LSST Applications  21.0.0-172-gfb10e10a+18fedfabac,22.0.0+297cba6710,22.0.0+80564b0ff1,22.0.0+8d77f4f51a,22.0.0+a28f4c53b1,22.0.0+dcf3732eb2,22.0.1-1-g7d6de66+2a20fdde0d,22.0.1-1-g8e32f31+297cba6710,22.0.1-1-geca5380+7fa3b7d9b6,22.0.1-12-g44dc1dc+2a20fdde0d,22.0.1-15-g6a90155+515f58c32b,22.0.1-16-g9282f48+790f5f2caa,22.0.1-2-g92698f7+dcf3732eb2,22.0.1-2-ga9b0f51+7fa3b7d9b6,22.0.1-2-gd1925c9+bf4f0e694f,22.0.1-24-g1ad7a390+a9625a72a8,22.0.1-25-g5bf6245+3ad8ecd50b,22.0.1-25-gb120d7b+8b5510f75f,22.0.1-27-g97737f7+2a20fdde0d,22.0.1-32-gf62ce7b1+aa4237961e,22.0.1-4-g0b3f228+2a20fdde0d,22.0.1-4-g243d05b+871c1b8305,22.0.1-4-g3a563be+32dcf1063f,22.0.1-4-g44f2e3d+9e4ab0f4fa,22.0.1-42-gca6935d93+ba5e5ca3eb,22.0.1-5-g15c806e+85460ae5f3,22.0.1-5-g58711c4+611d128589,22.0.1-5-g75bb458+99c117b92f,22.0.1-6-g1c63a23+7fa3b7d9b6,22.0.1-6-g50866e6+84ff5a128b,22.0.1-6-g8d3140d+720564cf76,22.0.1-6-gd805d02+cc5644f571,22.0.1-8-ge5750ce+85460ae5f3,master-g6e05de7fdc+babf819c66,master-g99da0e417a+8d77f4f51a,w.2021.48
LSST Data Management Base Package
Namespaces | Classes | Typedefs | Functions
lsst::afw::typehandling Namespace Reference

Namespaces

 _GenericMap
 
 _SimpleGenericMap
 
 detail
 
 test
 
 testUtils
 

Classes

class  GenericMap
 Interface for a heterogeneous map. More...
 
class  MutableGenericMap
 Interface for a GenericMap that allows element addition and removal. More...
 
class  Key
 Key for type-safe lookup in a GenericMap. More...
 
class  PolymorphicValue
 Container that passes Storable objects by value while preserving type. More...
 
class  StorableHelper
 "Trampoline" for Storable to let it be used as a base class in Python. More...
 
class  SimpleGenericMap
 A GenericMap that allows insertion and deletion of arbitrary values. More...
 
class  UnsupportedOperationException
 Exception thrown by Storable operations for unimplemented operations. More...
 
class  Storable
 Interface supporting iteration over heterogenous containers. 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. More...
 
template<typename K , typename V >
std::ostreamoperator<< (std::ostream &os, Key< K, V > const &key)
 Output operator for Key. More...
 
void swap (PolymorphicValue &lhs, PolymorphicValue &rhs) noexcept
 Swap specialization for PolymorphicValue. More...
 
std::string declareGenericMapRestrictions (std::string const &className, std::string const &keyName)
 
std::ostreamoperator<< (std::ostream &os, Storable const &storable)
 Output operator for Storable. More...
 
void wrapGenericMap (utils::python::WrapperCollection &wrappers)
 
void wrapSimpleGenericMap (utils::python::WrapperCollection &wrappers)
 
void wrapStorable (utils::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 32 of file python.cc.

32  {
33  // Give the class a custom docstring to avoid confusing Python users
34  std::string docstring = R"docstring(
35 For compatibility with C++, ``)docstring" +
36  className + R"docstring(`` has the following restrictions:
37  - all keys must be )docstring" + keyName +
38  R"docstring(
39  - values must be built-in types or subclasses of `lsst.afw.typehandling.Storable`.
40  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 }

◆ 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

◆ 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");
43  wrapStorable(w);
46  w.finish();
47 }
void wrapSimpleGenericMap(utils::python::WrapperCollection &wrappers)
void wrapStorable(utils::python::WrapperCollection &wrappers)
Definition: _Storable.cc:43
void wrapGenericMap(utils::python::WrapperCollection &wrappers)
Definition: _GenericMap.cc:221
double w
Definition: CoaddPsf.cc:69

◆ swap()

void swap ( PolymorphicValue lhs,
PolymorphicValue rhs 
)
inlinenoexcept

Swap specialization for PolymorphicValue.

Definition at line 152 of file PolymorphicValue.h.

152 { lhs.swap(rhs); }

◆ wrapGenericMap()

void lsst::afw::typehandling::wrapGenericMap ( utils::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 ( utils::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 ( utils::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 }
py::class_< Storable, PySharedPtr< Storable >, table::io::Persistable, StorableHelper<> > PyStorable
Definition: _Storable.cc:41