File: test_enum.cpp

package info (click to toggle)
nanobind 2.9.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,060 kB
  • sloc: cpp: 11,838; python: 5,862; ansic: 4,820; makefile: 22; sh: 15
file content (88 lines) | stat: -rw-r--r-- 3,594 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#include <nanobind/nanobind.h>
#include <nanobind/operators.h>
#include <nanobind/stl/string.h>

namespace nb = nanobind;

enum class Enum  : uint32_t { A, B, C = (uint32_t) -1 };
enum class Flag  : uint32_t { A = 1, B = 2, C = 4};
enum class UnsignedFlag : uint64_t {
     A = 1 << 0,
     B = 1 << 1,
     All = (uint64_t) -1,
};
enum class SEnum : int32_t { A, B, C = (int32_t) -1 };
enum ClassicEnum { Item1, Item2 };

struct EnumProperty { Enum get_enum() { return Enum::A; } };

enum class OpaqueEnum { X, Y };
NB_MAKE_OPAQUE(OpaqueEnum)

NB_MODULE(test_enum_ext, m) {
    nb::enum_<Enum>(m, "Enum", "enum-level docstring")
        .value("A", Enum::A, "Value A")
        .value("B", Enum::B, "Value B")
        .value("C", Enum::C, "Value C");

    nb::enum_<Flag>(m, "Flag", "enum-level docstring", nb::is_flag())
            .value("A", Flag::A, "Value A")
            .value("B", Flag::B, "Value B")
            .value("C", Flag::C, "Value C")
            .export_values();

    nb::enum_<UnsignedFlag>(m, "UnsignedFlag", nb::is_flag())
                .value("A", UnsignedFlag::A, "Value A")
                .value("B", UnsignedFlag::B, "Value B")
                .value("All", UnsignedFlag::All, "All values");

    nb::enum_<SEnum>(m, "SEnum", nb::is_arithmetic())
        .value("A", SEnum::A)
        .value("B", SEnum::B)
        .value("C", SEnum::C);

    auto ce = nb::enum_<ClassicEnum>(m, "ClassicEnum")
        .value("Item1", ClassicEnum::Item1)
        .value("Item2", ClassicEnum::Item2)
        .export_values();

    ce.def("get_value", [](ClassicEnum &x) { return (int) x; })
      .def_prop_ro("my_value", [](ClassicEnum &x) { return (int) x; })
      .def("foo", [](ClassicEnum x) { return x; })
      .def_static("bar", [](ClassicEnum x) { return x; });

    m.def("from_enum", [](Enum value) { return (uint32_t) value; }, nb::arg().noconvert());
    m.def("to_enum", [](uint32_t value) { return (Enum) value; });
    m.def("from_enum", [](Flag value) { return (uint32_t) value; }, nb::arg().noconvert());
    m.def("to_flag", [](uint32_t value) { return (Flag) value; });
    m.def("from_enum", [](SEnum value) { return (int32_t) value; }, nb::arg().noconvert());
    m.def("to_unsigned_flag", [](uint64_t value) { return (UnsignedFlag) value; });
    m.def("from_enum", [](UnsignedFlag value) { return (uint64_t) value; }, nb::arg().noconvert());
    m.def("from_enum_implicit", [](Enum value) { return (uint32_t) value; });

    m.def("from_enum_default_0", [](Enum value) { return (uint32_t) value; }, nb::arg("value") = Enum::A);

    m.def("from_enum_implicit", [](Flag value) { return (uint32_t) value; });

    m.def("from_enum_default_0", [](Flag value) { return (uint32_t) value; }, nb::arg("value") = Enum::A);

    m.def("from_enum_default_1", [](SEnum value) { return (uint32_t) value; }, nb::arg("value") = SEnum::A);

    // test for issue #39
    nb::class_<EnumProperty>(m, "EnumProperty")
        .def(nb::init<>())
        .def_prop_ro("read_enum", &EnumProperty::get_enum);


    auto oe = nb::class_<OpaqueEnum>(m, "OpaqueEnum")
        .def_prop_ro_static("X", [](nb::object&){return OpaqueEnum::X;})
        .def_prop_ro_static("Y", [](nb::object&){return OpaqueEnum::Y;})
        .def(nb::init<>())
        .def("__init__", [](OpaqueEnum* p, std::string v){
            if (v == "X") new (p) OpaqueEnum{OpaqueEnum::X};
            else if (v == "Y") new (p) OpaqueEnum{OpaqueEnum::Y};
            else throw std::runtime_error(v);
        })
        .def(nb::self == nb::self);
    nb::implicitly_convertible<std::string, OpaqueEnum>();
}