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  }