LSST Applications g04a91732dc+b257dfc5ef,g07dc498a13+7e3c5f68a2,g12483e3c20+719ef69748,g1409bbee79+7e3c5f68a2,g1a7e361dbc+7e3c5f68a2,g1fd858c14a+9f35e23ec3,g35bb328faa+fcb1d3bbc8,g3bd4b5ce2c+376b67b515,g4e0f332c67+5d362be553,g53246c7159+fcb1d3bbc8,g60b5630c4e+719ef69748,g6a5c94f25a+5f44f05f97,g78460c75b0+2f9a1b4bcd,g786e29fd12+cf7ec2a62a,g794fd9dcec+ed0768eb49,g7b71ed6315+fcb1d3bbc8,g8852436030+a85a031248,g89139ef638+7e3c5f68a2,g9125e01d80+fcb1d3bbc8,g919ac25b3e+7deac9a2c2,g95236ca021+f7a31438ed,g989de1cb63+7e3c5f68a2,g9f33ca652e+c9b5dfb7a3,ga9baa6287d+719ef69748,gaaedd4e678+7e3c5f68a2,gabe3b4be73+1e0a283bba,gb1101e3267+5c5d870f02,gb44bc621b2+6e77abaf78,gb58c049af0+f03b321e39,gbaa7868d32+719ef69748,gc45c3306ec+33b3578538,gc99c83e5f0+76d20ab76d,gcf25f946ba+a85a031248,gd315a588df+0122250889,gd6cbbdb0b4+c8606af20c,gde0f65d7ad+aaea62184c,ge278dab8ac+932305ba37,gfba249425e+fcb1d3bbc8,w.2025.08
LSST Data Management Base Package
Loading...
Searching...
No Matches
python.h File Reference

Go to the source code of this file.

Macros

#define LSST_DECLARE_CONTROL_FIELD(WRAPPER, CLASS, NAME)
 Macro used to wrap fields declared by LSST_CONTROL_FIELD using Pybind11.
 
#define LSST_DECLARE_NESTED_CONTROL_FIELD(WRAPPER, CLASS, NAME)
 Macro used to wrap fields declared by LSST_NESTED_CONTROL_FIELD using Pybind11.
 

Macro Definition Documentation

◆ LSST_DECLARE_CONTROL_FIELD

#define LSST_DECLARE_CONTROL_FIELD ( WRAPPER,
CLASS,
NAME )
Value:
WRAPPER.def_readwrite(#NAME, &CLASS::NAME); \
WRAPPER.def_static("_doc_" #NAME, &CLASS::_doc_ ## NAME); \
WRAPPER.def_static("_type_" #NAME, &CLASS::_type_ ## NAME);

Macro used to wrap fields declared by LSST_CONTROL_FIELD using Pybind11.

Example:

LSST_DECLARE_CONTROL_FIELD(clsFoo, Foo, myField)
Parameters
WRAPPERThe py::class_ object representing the control class being wrapped.
CLASSThe control class. Must be a C++ identifier (not a string), properly namespace-qualified for the context where this macro is being called.
NAMEThe control field. Must be a C++ identifier (not a string), and must match the NAME argument of the original LSST_CONTROL_FIELD macro.

Definition at line 50 of file python.h.

50#define LSST_DECLARE_CONTROL_FIELD(WRAPPER, CLASS, NAME) \
51 WRAPPER.def_readwrite(#NAME, &CLASS::NAME); \
52 WRAPPER.def_static("_doc_" #NAME, &CLASS::_doc_ ## NAME); \
53 WRAPPER.def_static("_type_" #NAME, &CLASS::_type_ ## NAME);

◆ LSST_DECLARE_NESTED_CONTROL_FIELD

#define LSST_DECLARE_NESTED_CONTROL_FIELD ( WRAPPER,
CLASS,
NAME )
Value:
WRAPPER.def_readwrite(#NAME, &CLASS::NAME); \
WRAPPER.def_static("_doc_" #NAME, &CLASS::_doc_ ## NAME); \
WRAPPER.def_static("_type_" #NAME, &CLASS::_type_ ## NAME); \
WRAPPER.def_static("_module_" #NAME, &CLASS::_module_ ## NAME);

Macro used to wrap fields declared by LSST_NESTED_CONTROL_FIELD using Pybind11.

Example:

LSST_DECLARE_NESTED_CONTROL_FIELD(clsFoo, Foo, myField)
Parameters
WRAPPERThe py::class_ object representing the control class being wrapped.
CLASSThe control class. Must be a C++ identifier (not a string), properly namespace-qualified for the context where this macro is being called.
NAMEThe control field. Must be a C++ identifier (not a string), and must match the NAME argument of the original LSST_CONTROL_FIELD macro.

Definition at line 72 of file python.h.

72#define LSST_DECLARE_NESTED_CONTROL_FIELD(WRAPPER, CLASS, NAME) \
73 WRAPPER.def_readwrite(#NAME, &CLASS::NAME); \
74 WRAPPER.def_static("_doc_" #NAME, &CLASS::_doc_ ## NAME); \
75 WRAPPER.def_static("_type_" #NAME, &CLASS::_type_ ## NAME); \
76 WRAPPER.def_static("_module_" #NAME, &CLASS::_module_ ## NAME);