LSSTApplications  21.0.0+75b29a8a7f,21.0.0+e70536a077,21.0.0-1-ga51b5d4+62c747d40b,21.0.0-11-ga6ea59e8e+47cba9fc36,21.0.0-2-g103fe59+914993bf7c,21.0.0-2-g1367e85+e2614ded12,21.0.0-2-g45278ab+e70536a077,21.0.0-2-g4bc9b9f+7b2b5f8678,21.0.0-2-g5242d73+e2614ded12,21.0.0-2-g54e2caa+6403186824,21.0.0-2-g7f82c8f+3ac4acbffc,21.0.0-2-g8dde007+04a6aea1af,21.0.0-2-g8f08a60+9402881886,21.0.0-2-ga326454+3ac4acbffc,21.0.0-2-ga63a54e+81dd751046,21.0.0-2-gc738bc1+5f65c6e7a9,21.0.0-2-gde069b7+26c92b3210,21.0.0-2-gecfae73+0993ddc9bd,21.0.0-2-gfc62afb+e2614ded12,21.0.0-21-gba890a8+5a4f502a26,21.0.0-23-g9966ff26+03098d1af8,21.0.0-3-g357aad2+8ad216c477,21.0.0-3-g4be5c26+e2614ded12,21.0.0-3-g6d51c4a+4d2fe0280d,21.0.0-3-g7d9da8d+75b29a8a7f,21.0.0-3-gaa929c8+522e0f12c2,21.0.0-3-ge02ed75+4d2fe0280d,21.0.0-4-g3300ddd+e70536a077,21.0.0-4-gc004bbf+eac6615e82,21.0.0-4-gccdca77+f94adcd104,21.0.0-4-gd1c1571+18b81799f9,21.0.0-5-g7b47fff+4d2fe0280d,21.0.0-5-gb155db7+d2632f662b,21.0.0-5-gdf36809+637e4641ee,21.0.0-6-g722ad07+28c848f42a,21.0.0-7-g959bb79+522e0f12c2,21.0.0-7-gfd72ab2+cf01990774,21.0.0-9-g87fb7b8d+e2ab11cdd6,w.2021.04
LSSTDataManagementBasePackage
propertyList.cc
Go to the documentation of this file.
1 #include "pybind11/pybind11.h"
2 #include "pybind11/stl.h"
3 
6 
7 namespace py = pybind11;
8 using namespace pybind11::literals;
9 
10 namespace lsst {
11 namespace daf {
12 namespace base {
13 namespace {
14 
15 template <typename T, typename C>
16 void declareAccessors(C& cls, std::string const& name) {
17  const std::string getName = "get" + name;
18  cls.def(getName.c_str(), (T (PropertyList::*)(std::string const&) const) & PropertyList::get<T>,
19  "name"_a);
20  cls.def(getName.c_str(), (T (PropertyList::*)(std::string const&, T const&) const) & PropertyList::get<T>,
21  "name"_a, "defaultValue"_a);
22 
23  // Warning: __len__ is ambiguous so do not attempt to define it. It could return
24  // the number of unique names or the number of entries (e.g. as returned by toList,
25  // a pure Python method). C++ begin and end iterate over unique names, but users often
26  // view PropertyList as a representation of a FITS header. When in doubt, refuse to guess.
27 
28  const std::string getArrayName = "getArray" + name;
29  cls.def(getArrayName.c_str(),
30  (std::vector<T> (PropertyList::*)(std::string const&) const) & PropertyList::getArray<T>,
31  "name"_a);
32 
33  const std::string setName = "set" + name;
34  cls.def(setName.c_str(), (void (PropertyList::*)(std::string const&, T const&)) & PropertyList::set<T>);
35  cls.def(setName.c_str(),
36  (void (PropertyList::*)(std::string const&, std::vector<T> const&)) & PropertyList::set<T>);
37  cls.def(setName.c_str(), (void (PropertyList::*)(std::string const&, T const&, std::string const&)) &
38  PropertyList::set<T>);
39  cls.def(setName.c_str(),
40  (void (PropertyList::*)(std::string const&, std::vector<T> const&, std::string const&)) &
41  PropertyList::set<T>);
42 
43  const std::string addName = "add" + name;
44  cls.def(addName.c_str(), (void (PropertyList::*)(std::string const&, T const&)) & PropertyList::add<T>);
45  cls.def(addName.c_str(),
46  (void (PropertyList::*)(std::string const&, std::vector<T> const&)) & PropertyList::add<T>);
47  cls.def(addName.c_str(), (void (PropertyList::*)(std::string const&, T const&, std::string const&)) &
48  PropertyList::add<T>);
49  cls.def(addName.c_str(),
50  (void (PropertyList::*)(std::string const&, std::vector<T> const&, std::string const&)) &
51  PropertyList::add<T>);
52 
53  const std::string typeName = "TYPE_" + name;
54  cls.attr(typeName.c_str()) = py::cast(typeid(T), py::return_value_policy::reference);
55 }
56 
57 } // namespace
58 
59 PYBIND11_MODULE(propertyList, mod) {
60  py::module::import("lsst.daf.base.persistable");
61 
62  py::class_<PropertyList, std::shared_ptr<PropertyList>, PropertySet> cls(mod, "PropertyList");
63 
64  cls.def(py::init<>());
65 
66  cls.def("getComment", &PropertyList::getComment);
67  cls.def("getOrderedNames", &PropertyList::getOrderedNames);
68  cls.def("deepCopy",
69  [](PropertyList const& self) { return std::static_pointer_cast<PropertySet>(self.deepCopy()); });
70  declareAccessors<bool>(cls, "Bool");
71  declareAccessors<short>(cls, "Short");
72  declareAccessors<int>(cls, "Int");
73  declareAccessors<long>(cls, "Long");
74  declareAccessors<long long>(cls, "LongLong");
75  declareAccessors<float>(cls, "Float");
76  declareAccessors<double>(cls, "Double");
77  declareAccessors<nullptr_t>(cls, "Undef");
78  declareAccessors<std::string>(cls, "String");
79  declareAccessors<DateTime>(cls, "DateTime");
80 
81  cls.def("setPropertySet",
82  (void (PropertyList::*)(std::string const&, PropertySet::Ptr const&)) & PropertyList::set);
83 }
84 
85 } // base
86 } // daf
87 } // lsst
std::string
STL class.
std::shared_ptr< PropertySet >
lsst::daf::base::PYBIND11_MODULE
PYBIND11_MODULE(propertyList, mod)
Definition: propertyList.cc:59
std::vector
STL class.
DateTime.h
Interface for DateTime class.
lsst::daf::base::PropertyList
Class for storing ordered metadata with comments.
Definition: PropertyList.h:68
lsst::afw::geom.transform.transformContinued.name
string name
Definition: transformContinued.py:32
lsst::afw::geom.transform.transformContinued.cls
cls
Definition: transformContinued.py:33
PropertyList.h
std::string::c_str
T c_str(T... args)
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
lsst::daf::base::PropertySet
Class for storing generic metadata.
Definition: PropertySet.h:67
pybind11
Definition: _GenericMap.cc:40
set
daf::base::PropertySet * set
Definition: fits.cc:912