github.com/kaydxh/golang@v0.0.131/pkg/gocv/cgo/third_path/pybind11/tests/test_constants_and_functions.cpp (about) 1 /* 2 tests/test_constants_and_functions.cpp -- global constants and functions, enumerations, raw 3 byte strings 4 5 Copyright (c) 2016 Wenzel Jakob <wenzel.jakob@epfl.ch> 6 7 All rights reserved. Use of this source code is governed by a 8 BSD-style license that can be found in the LICENSE file. 9 */ 10 11 #include "pybind11_tests.h" 12 13 enum MyEnum { EFirstEntry = 1, ESecondEntry }; 14 15 std::string test_function1() { return "test_function()"; } 16 17 std::string test_function2(MyEnum k) { return "test_function(enum=" + std::to_string(k) + ")"; } 18 19 std::string test_function3(int i) { return "test_function(" + std::to_string(i) + ")"; } 20 21 py::str test_function4() { return "test_function()"; } 22 py::str test_function4(char *) { return "test_function(char *)"; } 23 py::str test_function4(int, float) { return "test_function(int, float)"; } 24 py::str test_function4(float, int) { return "test_function(float, int)"; } 25 26 py::bytes return_bytes() { 27 const char *data = "\x01\x00\x02\x00"; 28 return std::string(data, 4); 29 } 30 31 std::string print_bytes(const py::bytes &bytes) { 32 std::string ret = "bytes["; 33 const auto value = static_cast<std::string>(bytes); 34 for (char c : value) { 35 ret += std::to_string(static_cast<int>(c)) + ' '; 36 } 37 ret.back() = ']'; 38 return ret; 39 } 40 41 // Test that we properly handle C++17 exception specifiers (which are part of the function 42 // signature in C++17). These should all still work before C++17, but don't affect the function 43 // signature. 44 namespace test_exc_sp { 45 // [workaround(intel)] Unable to use noexcept instead of noexcept(true) 46 // Make the f1 test basically the same as the f2 test in C++17 mode for the Intel compiler as 47 // it fails to compile with a plain noexcept (tested with icc (ICC) 2021.1 Beta 20200827). 48 #if defined(__INTEL_COMPILER) && defined(PYBIND11_CPP17) 49 int f1(int x) noexcept(true) { return x + 1; } 50 #else 51 int f1(int x) noexcept { return x + 1; } 52 #endif 53 int f2(int x) noexcept(true) { return x + 2; } 54 int f3(int x) noexcept(false) { return x + 3; } 55 PYBIND11_WARNING_PUSH 56 PYBIND11_WARNING_DISABLE_GCC("-Wdeprecated") 57 PYBIND11_WARNING_DISABLE_CLANG("-Wdeprecated") 58 // NOLINTNEXTLINE(modernize-use-noexcept) 59 int f4(int x) throw() { return x + 4; } // Deprecated equivalent to noexcept(true) 60 PYBIND11_WARNING_POP 61 struct C { 62 int m1(int x) noexcept { return x - 1; } 63 int m2(int x) const noexcept { return x - 2; } 64 int m3(int x) noexcept(true) { return x - 3; } 65 int m4(int x) const noexcept(true) { return x - 4; } 66 int m5(int x) noexcept(false) { return x - 5; } 67 int m6(int x) const noexcept(false) { return x - 6; } 68 PYBIND11_WARNING_PUSH 69 PYBIND11_WARNING_DISABLE_GCC("-Wdeprecated") 70 PYBIND11_WARNING_DISABLE_CLANG("-Wdeprecated") 71 // NOLINTNEXTLINE(modernize-use-noexcept) 72 int m7(int x) throw() { return x - 7; } 73 // NOLINTNEXTLINE(modernize-use-noexcept) 74 int m8(int x) const throw() { return x - 8; } 75 PYBIND11_WARNING_POP 76 }; 77 } // namespace test_exc_sp 78 79 TEST_SUBMODULE(constants_and_functions, m) { 80 // test_constants 81 m.attr("some_constant") = py::int_(14); 82 83 // test_function_overloading 84 m.def("test_function", &test_function1); 85 m.def("test_function", &test_function2); 86 m.def("test_function", &test_function3); 87 88 #if defined(PYBIND11_OVERLOAD_CAST) 89 m.def("test_function", py::overload_cast<>(&test_function4)); 90 m.def("test_function", py::overload_cast<char *>(&test_function4)); 91 m.def("test_function", py::overload_cast<int, float>(&test_function4)); 92 m.def("test_function", py::overload_cast<float, int>(&test_function4)); 93 #else 94 m.def("test_function", static_cast<py::str (*)()>(&test_function4)); 95 m.def("test_function", static_cast<py::str (*)(char *)>(&test_function4)); 96 m.def("test_function", static_cast<py::str (*)(int, float)>(&test_function4)); 97 m.def("test_function", static_cast<py::str (*)(float, int)>(&test_function4)); 98 #endif 99 100 py::enum_<MyEnum>(m, "MyEnum") 101 .value("EFirstEntry", EFirstEntry) 102 .value("ESecondEntry", ESecondEntry) 103 .export_values(); 104 105 // test_bytes 106 m.def("return_bytes", &return_bytes); 107 m.def("print_bytes", &print_bytes); 108 109 // test_exception_specifiers 110 using namespace test_exc_sp; 111 py::class_<C>(m, "C") 112 .def(py::init<>()) 113 .def("m1", &C::m1) 114 .def("m2", &C::m2) 115 .def("m3", &C::m3) 116 .def("m4", &C::m4) 117 .def("m5", &C::m5) 118 .def("m6", &C::m6) 119 .def("m7", &C::m7) 120 .def("m8", &C::m8); 121 m.def("f1", f1); 122 m.def("f2", f2); 123 124 PYBIND11_WARNING_PUSH 125 PYBIND11_WARNING_DISABLE_INTEL(878) // incompatible exception specifications 126 m.def("f3", f3); 127 PYBIND11_WARNING_POP 128 129 m.def("f4", f4); 130 131 // test_function_record_leaks 132 m.def("register_large_capture_with_invalid_arguments", [](py::module_ m) { 133 // This should always be enough to trigger the alternative branch 134 // where `sizeof(capture) > sizeof(rec->data)` 135 uint64_t capture[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; 136 #if defined(__GNUC__) && __GNUC__ == 4 // CentOS7 137 py::detail::silence_unused_warnings(capture); 138 #endif 139 m.def( 140 "should_raise", [capture](int) { return capture[9] + 33; }, py::kw_only(), py::arg()); 141 }); 142 m.def("register_with_raising_repr", [](py::module_ m, const py::object &default_value) { 143 m.def( 144 "should_raise", 145 [](int, int, const py::object &) { return 42; }, 146 "some docstring", 147 py::arg_v("x", 42), 148 py::arg_v("y", 42, "<the answer>"), 149 py::arg_v("z", default_value)); 150 }); 151 }