LSST Applications  21.0.0+04719a4bac,21.0.0-1-ga51b5d4+f5e6047307,21.0.0-11-g2b59f77+a9c1acf22d,21.0.0-11-ga42c5b2+86977b0b17,21.0.0-12-gf4ce030+76814010d2,21.0.0-13-g1721dae+760e7a6536,21.0.0-13-g3a573fe+768d78a30a,21.0.0-15-g5a7caf0+f21cbc5713,21.0.0-16-g0fb55c1+b60e2d390c,21.0.0-19-g4cded4ca+71a93a33c0,21.0.0-2-g103fe59+bb20972958,21.0.0-2-g45278ab+04719a4bac,21.0.0-2-g5242d73+3ad5d60fb1,21.0.0-2-g7f82c8f+8babb168e8,21.0.0-2-g8f08a60+06509c8b61,21.0.0-2-g8faa9b5+616205b9df,21.0.0-2-ga326454+8babb168e8,21.0.0-2-gde069b7+5e4aea9c2f,21.0.0-2-gecfae73+1d3a86e577,21.0.0-2-gfc62afb+3ad5d60fb1,21.0.0-25-g1d57be3cd+e73869a214,21.0.0-3-g357aad2+ed88757d29,21.0.0-3-g4a4ce7f+3ad5d60fb1,21.0.0-3-g4be5c26+3ad5d60fb1,21.0.0-3-g65f322c+e0b24896a3,21.0.0-3-g7d9da8d+616205b9df,21.0.0-3-ge02ed75+a9c1acf22d,21.0.0-4-g591bb35+a9c1acf22d,21.0.0-4-g65b4814+b60e2d390c,21.0.0-4-gccdca77+0de219a2bc,21.0.0-4-ge8a399c+6c55c39e83,21.0.0-5-gd00fb1e+05fce91b99,21.0.0-6-gc675373+3ad5d60fb1,21.0.0-64-g1122c245+4fb2b8f86e,21.0.0-7-g04766d7+cd19d05db2,21.0.0-7-gdf92d54+04719a4bac,21.0.0-8-g5674e7b+d1bd76f71f,master-gac4afde19b+a9c1acf22d,w.2021.13
LSST Data Management Base Package
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
table::Key< std::string > name
Definition: Amplifier.cc:116
Interface for DateTime class.
T c_str(T... args)
Class for storing ordered metadata with comments.
Definition: PropertyList.h:68
Class for storing generic metadata.
Definition: PropertySet.h:67
daf::base::PropertySet * set
Definition: fits.cc:912
std::string const & getName() const noexcept
Return a filter's name.
Definition: Filter.h:78
PYBIND11_MODULE(propertyList, mod)
Definition: propertyList.cc:59
A base class for image defects.