2016-09-03 18:54:22 +00:00
|
|
|
#pragma once
|
2021-07-14 01:14:58 +00:00
|
|
|
|
2021-01-01 16:37:28 +00:00
|
|
|
#include <pybind11/eval.h>
|
2022-02-10 20:17:07 +00:00
|
|
|
#include <pybind11/pybind11.h>
|
2015-07-05 18:05:44 +00:00
|
|
|
|
2017-07-03 23:12:09 +00:00
|
|
|
#if defined(_MSC_VER) && _MSC_VER < 1910
|
|
|
|
// We get some really long type names here which causes MSVC 2015 to emit warnings
|
2022-02-10 20:17:07 +00:00
|
|
|
# pragma warning( \
|
|
|
|
disable : 4503) // NOLINT: warning C4503: decorated name length exceeded, name was truncated
|
2017-07-03 23:12:09 +00:00
|
|
|
#endif
|
|
|
|
|
2015-10-15 16:13:33 +00:00
|
|
|
namespace py = pybind11;
|
Support keyword arguments and generalized unpacking in C++
A Python function can be called with the syntax:
```python
foo(a1, a2, *args, ka=1, kb=2, **kwargs)
```
This commit adds support for the equivalent syntax in C++:
```c++
foo(a1, a2, *args, "ka"_a=1, "kb"_a=2, **kwargs)
```
In addition, generalized unpacking is implemented, as per PEP 448,
which allows calls with multiple * and ** unpacking:
```python
bar(*args1, 99, *args2, 101, **kwargs1, kz=200, **kwargs2)
```
and
```c++
bar(*args1, 99, *args2, 101, **kwargs1, "kz"_a=200, **kwargs2)
```
2016-08-29 01:05:42 +00:00
|
|
|
using namespace pybind11::literals;
|
2016-09-03 18:54:22 +00:00
|
|
|
|
|
|
|
class test_initializer {
|
2020-10-03 17:38:03 +00:00
|
|
|
using Initializer = void (*)(py::module_ &);
|
2017-06-08 22:44:49 +00:00
|
|
|
|
|
|
|
public:
|
CodeHealth: Enabling clang-tidy google-explicit-constructor (#3250)
* Adding google-explicit-constructor to .clang-tidy
* clang-tidy explicit attr.h (all automatic)
* clang-tidy explicit cast.h (all automatic)
* clang-tidy detail/init.h (1 NOLINT)
* clang-tidy detail/type_caster_base.h (2 NOLINT)
* clang-tidy pybind11.h (7 NOLINT)
* clang-tidy detail/common.h (3 NOLINT)
* clang-tidy detail/descr.h (2 NOLINT)
* clang-tidy pytypes.h (23 NOLINT, only 1 explicit)
* clang-tidy eigen.h (7 NOLINT, 0 explicit)
* Adding 2 explicit in functional.h
* Adding 4 explicit in iostream.h
* clang-tidy numpy.h (1 NOLINT, 1 explicit)
* clang-tidy embed.h (0 NOLINT, 1 explicit)
* clang-tidy tests/local_bindings.h (0 NOLINT, 4 explicit)
* clang-tidy tests/pybind11_cross_module_tests.cpp (0 NOLINT, 1 explicit)
* clang-tidy tests/pybind11_tests.h (0 NOLINT, 2 explicit)
* clang-tidy tests/test_buffers.cpp (0 NOLINT, 2 explicit)
* clang-tidy tests/test_builtin_casters.cpp (0 NOLINT, 4 explicit)
* clang-tidy tests/test_class.cpp (0 NOLINT, 6 explicit)
* clang-tidy tests/test_copy_move.cpp (0 NOLINT, 7 explicit)
* clang-tidy tests/test_embed/external_module.cpp (0 NOLINT, 1 explicit)
* clang-tidy tests/test_embed/test_interpreter.cpp (0 NOLINT, 1 explicit)
* clang-tidy tests/object.h (0 NOLINT, 2 explicit)
* clang-tidy batch of fully automatic fixes.
* Workaround for MSVC 19.16.27045.0 C++17 Python 2 C++ syntax error.
2021-09-09 01:53:38 +00:00
|
|
|
explicit test_initializer(Initializer init);
|
2017-06-08 22:44:49 +00:00
|
|
|
test_initializer(const char *submodule_name, Initializer init);
|
|
|
|
};
|
|
|
|
|
2021-08-06 18:30:28 +00:00
|
|
|
#define TEST_SUBMODULE(name, variable) \
|
|
|
|
void test_submodule_##name(py::module_ &); \
|
|
|
|
test_initializer name(#name, test_submodule_##name); \
|
|
|
|
void test_submodule_##name(py::module_ &(variable))
|
2017-06-08 22:44:49 +00:00
|
|
|
|
|
|
|
/// Dummy type which is not exported anywhere -- something to trigger a conversion error
|
2022-02-10 20:17:07 +00:00
|
|
|
struct UnregisteredType {};
|
2017-06-08 22:44:49 +00:00
|
|
|
|
|
|
|
/// A user-defined type which is exported and can be used by any test
|
|
|
|
class UserType {
|
|
|
|
public:
|
|
|
|
UserType() = default;
|
2022-02-10 20:17:07 +00:00
|
|
|
explicit UserType(int i) : i(i) {}
|
2017-06-08 22:44:49 +00:00
|
|
|
|
|
|
|
int value() const { return i; }
|
Update all remaining tests to new test styles
This udpates all the remaining tests to the new test suite code and
comment styles started in #898. For the most part, the test coverage
here is unchanged, with a few minor exceptions as noted below.
- test_constants_and_functions: this adds more overload tests with
overloads with different number of arguments for more comprehensive
overload_cast testing. The test style conversion broke the overload
tests under MSVC 2015, prompting the additional tests while looking
for a workaround.
- test_eigen: this dropped the unused functions `get_cm_corners` and
`get_cm_corners_const`--these same tests were duplicates of the same
things provided (and used) via ReturnTester methods.
- test_opaque_types: this test had a hidden dependence on ExampleMandA
which is now fixed by using the global UserType which suffices for the
relevant test.
- test_methods_and_attributes: this required some additions to UserType
to make it usable as a replacement for the test's previous SimpleType:
UserType gained a value mutator, and the `value` property is not
mutable (it was previously readonly). Some overload tests were also
added to better test overload_cast (as described above).
- test_numpy_array: removed the untemplated mutate_data/mutate_data_t:
the templated versions with an empty parameter pack expand to the same
thing.
- test_stl: this was already mostly in the new style; this just tweaks
things a bit, localizing a class, and adding some missing
`// test_whatever` comments.
- test_virtual_functions: like `test_stl`, this was mostly in the new
test style already, but needed some `// test_whatever` comments.
This commit also moves the inherited virtual example code to the end
of the file, after the main set of tests (since it is less important
than the other tests, and rather length); it also got renamed to
`test_inherited_virtuals` (from `test_inheriting_repeat`) because it
tests both inherited virtual approaches, not just the repeat approach.
2017-07-25 20:47:36 +00:00
|
|
|
void set(int set) { i = set; }
|
2017-06-08 22:44:49 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
int i = -1;
|
|
|
|
};
|
|
|
|
|
|
|
|
/// Like UserType, but increments `value` on copy for quick reference vs. copy tests
|
|
|
|
class IncType : public UserType {
|
2016-09-03 18:54:22 +00:00
|
|
|
public:
|
2017-06-08 22:44:49 +00:00
|
|
|
using UserType::UserType;
|
|
|
|
IncType() = default;
|
2022-02-10 20:17:07 +00:00
|
|
|
IncType(const IncType &other) : IncType(other.value() + 1) {}
|
2017-06-08 22:44:49 +00:00
|
|
|
IncType(IncType &&) = delete;
|
|
|
|
IncType &operator=(const IncType &) = delete;
|
|
|
|
IncType &operator=(IncType &&) = delete;
|
2016-09-03 18:54:22 +00:00
|
|
|
};
|
2017-07-03 23:12:09 +00:00
|
|
|
|
2020-10-02 13:39:22 +00:00
|
|
|
/// A simple union for basic testing
|
|
|
|
union IntFloat {
|
|
|
|
int i;
|
|
|
|
float f;
|
|
|
|
};
|
|
|
|
|
2022-02-10 20:17:07 +00:00
|
|
|
/// Custom cast-only type that casts to a string "rvalue" or "lvalue" depending on the cast
|
|
|
|
/// context. Used to test recursive casters (e.g. std::tuple, stl containers).
|
2017-07-03 23:12:09 +00:00
|
|
|
struct RValueCaster {};
|
2020-07-08 22:14:41 +00:00
|
|
|
PYBIND11_NAMESPACE_BEGIN(pybind11)
|
|
|
|
PYBIND11_NAMESPACE_BEGIN(detail)
|
2022-02-10 20:17:07 +00:00
|
|
|
template <>
|
|
|
|
class type_caster<RValueCaster> {
|
2017-07-03 23:12:09 +00:00
|
|
|
public:
|
2021-12-21 19:24:21 +00:00
|
|
|
PYBIND11_TYPE_CASTER(RValueCaster, const_name("RValueCaster"));
|
2022-02-10 20:17:07 +00:00
|
|
|
static handle cast(RValueCaster &&, return_value_policy, handle) {
|
|
|
|
return py::str("rvalue").release();
|
|
|
|
}
|
|
|
|
static handle cast(const RValueCaster &, return_value_policy, handle) {
|
|
|
|
return py::str("lvalue").release();
|
|
|
|
}
|
2017-07-03 23:12:09 +00:00
|
|
|
};
|
2020-07-08 22:14:41 +00:00
|
|
|
PYBIND11_NAMESPACE_END(detail)
|
|
|
|
PYBIND11_NAMESPACE_END(pybind11)
|
2021-01-01 16:37:28 +00:00
|
|
|
|
|
|
|
template <typename F>
|
|
|
|
void ignoreOldStyleInitWarnings(F &&body) {
|
|
|
|
py::exec(R"(
|
|
|
|
message = "pybind11-bound class '.+' is using an old-style placement-new '(?:__init__|__setstate__)' which has been deprecated"
|
|
|
|
|
|
|
|
import warnings
|
|
|
|
with warnings.catch_warnings():
|
|
|
|
warnings.filterwarnings("ignore", message=message, category=FutureWarning)
|
|
|
|
body()
|
2022-02-10 20:17:07 +00:00
|
|
|
)",
|
|
|
|
py::dict(py::arg("body") = py::cpp_function(body)));
|
2021-01-01 16:37:28 +00:00
|
|
|
}
|