test_docstring_options.cpp
Go to the documentation of this file.
1 /*
2  tests/test_docstring_options.cpp -- generation of docstrings and signatures
3 
4  Copyright (c) 2016 Wenzel Jakob <wenzel.jakob@epfl.ch>
5 
6  All rights reserved. Use of this source code is governed by a
7  BSD-style license that can be found in the LICENSE file.
8 */
9 
10 #include "pybind11_tests.h"
11 
12 TEST_SUBMODULE(docstring_options, m) {
13  // test_docstring_options
14  {
17 
18  m.def(
19  "test_function1", [](int, int) {}, py::arg("a"), py::arg("b"));
20  m.def(
21  "test_function2", [](int, int) {}, py::arg("a"), py::arg("b"), "A custom docstring");
22 
23  m.def(
24  "test_overloaded1", [](int) {}, py::arg("i"), "Overload docstring");
25  m.def(
26  "test_overloaded1", [](double) {}, py::arg("d"));
27 
28  m.def(
29  "test_overloaded2", [](int) {}, py::arg("i"), "overload docstring 1");
30  m.def(
31  "test_overloaded2", [](double) {}, py::arg("d"), "overload docstring 2");
32 
33  m.def(
34  "test_overloaded3", [](int) {}, py::arg("i"));
35  m.def(
36  "test_overloaded3", [](double) {}, py::arg("d"), "Overload docstr");
37 
39 
40  m.def(
41  "test_function3", [](int, int) {}, py::arg("a"), py::arg("b"));
42  m.def(
43  "test_function4", [](int, int) {}, py::arg("a"), py::arg("b"), "A custom docstring");
44 
46 
47  m.def(
48  "test_function5", [](int, int) {}, py::arg("a"), py::arg("b"), "A custom docstring");
49 
50  {
51  py::options nested_options;
52  nested_options.enable_user_defined_docstrings();
53  m.def(
54  "test_function6",
55  [](int, int) {},
56  py::arg("a"),
57  py::arg("b"),
58  "A custom docstring");
59  }
60  }
61 
62  m.def(
63  "test_function7", [](int, int) {}, py::arg("a"), py::arg("b"), "A custom docstring");
64 
65  {
69 
70  m.def("test_function8", []() {});
71  }
72 
73  {
76 
77  struct DocstringTestFoo {
78  int value;
79  void setValue(int v) { value = v; }
80  int getValue() const { return value; }
81  };
82  py::class_<DocstringTestFoo>(m, "DocstringTestFoo", "This is a class docstring")
83  .def_property("value_prop",
84  &DocstringTestFoo::getValue,
85  &DocstringTestFoo::setValue,
86  "This is a property docstring");
87  }
88 
89  {
90  enum class DocstringTestEnum1 { Member1, Member2 };
91 
92  py::enum_<DocstringTestEnum1>(m, "DocstringTestEnum1", "Enum docstring")
93  .value("Member1", DocstringTestEnum1::Member1)
94  .value("Member2", DocstringTestEnum1::Member2);
95  }
96 
97  {
100 
101  enum class DocstringTestEnum2 { Member1, Member2 };
102 
103  py::enum_<DocstringTestEnum2>(m, "DocstringTestEnum2", "Enum docstring")
104  .value("Member1", DocstringTestEnum2::Member1)
105  .value("Member2", DocstringTestEnum2::Member2);
106  }
107 
108  {
111 
112  enum class DocstringTestEnum3 { Member1, Member2 };
113 
114  py::enum_<DocstringTestEnum3>(m, "DocstringTestEnum3", "Enum docstring")
115  .value("Member1", DocstringTestEnum3::Member1)
116  .value("Member2", DocstringTestEnum3::Member2);
117  }
118 
119  {
122 
123  enum class DocstringTestEnum4 { Member1, Member2 };
124 
125  py::enum_<DocstringTestEnum4>(m, "DocstringTestEnum4", "Enum docstring")
126  .value("Member1", DocstringTestEnum4::Member1)
127  .value("Member2", DocstringTestEnum4::Member2);
128  }
129 
130  {
134 
135  enum class DocstringTestEnum5 { Member1, Member2 };
136 
137  py::enum_<DocstringTestEnum5>(m, "DocstringTestEnum5", "Enum docstring")
138  .value("Member1", DocstringTestEnum5::Member1)
139  .value("Member2", DocstringTestEnum5::Member2);
140  }
141 }
TEST_SUBMODULE
TEST_SUBMODULE(docstring_options, m)
Definition: test_docstring_options.cpp:12
options::disable_function_signatures
options & disable_function_signatures() &
Definition: options.h:40
options::enable_function_signatures
options & enable_function_signatures() &
Definition: options.h:45
m
Matrix3f m
Definition: AngleAxis_mimic_euler.cpp:1
arg
EIGEN_DEVICE_FUNC const EIGEN_STRONG_INLINE ArgReturnType arg() const
Definition: ArrayCwiseUnaryOps.h:66
options::disable_user_defined_docstrings
options & disable_user_defined_docstrings() &
Definition: options.h:30
options
idx_t idx_t idx_t idx_t idx_t idx_t idx_t real_t real_t idx_t * options
Definition: include/metis.h:199
options::enable_enum_members_docstring
options & enable_enum_members_docstring() &
Definition: options.h:55
pybind11_tests.h
v
Array< int, Dynamic, 1 > v
Definition: Array_initializer_list_vector_cxx11.cpp:1
options::disable_enum_members_docstring
options & disable_enum_members_docstring() &
Definition: options.h:50
options
Definition: options.h:16
test_callbacks.value
value
Definition: test_callbacks.py:158


gtsam
Author(s):
autogenerated on Tue Jun 25 2024 03:05:28