1 [section boost/python/type_id.hpp]
3 <boost/python/type_id.hpp> provides types and functions for runtime type identification like those of of `<typeinfo>`. It exists mostly to work around certain compiler bugs and platform-dependent interactions with shared libraries.
5 [section Class template `type_info`]
6 `type_info` instances identify a type. As `std::type_info` is specified to (but unlike its implementation in some compilers), `boost::python::type_info` never represents top-level references or cv-qualification (see section 5.2.8 in the C++ standard). Unlike `std::type_info`, `boost::python::type_info` instances are copyable, and comparisons always work reliably across shared library boundaries.
8 namespace boost { namespace python
10 class type_info : totally_ordered<type_info>
14 type_info(std::type_info const& = typeid(void));
17 bool operator<(type_info const& rhs) const;
18 bool operator==(type_info const& rhs) const;
21 char const* name() const;
25 [section Class template `type_info` constructor]
26 ``type_info(std::type_info const& = typeid(void));``
28 [[Effects][constructs a `type_info` object which identifies the same type as its argument.]]
29 [[Rationale][Since it is occasionally necessary to make an array of `type_info` objects a benign default argument is supplied. Note: this constructor does not correct for non-conformance of compiler `typeid()` implementations. See `type_id`, below.]]
32 [section Class template `type_info` comparison]
33 ``bool operator<(type_info const &rhs) const;``
35 [[Effects][yields a total order over `type_info` objects.]]
37 ``bool operator==(type_info const &rhs) const;``
39 [[Returns][`true` iff the two values describe the same type.]]
40 [[Note][The use of `totally_ordered<type_info>` as a private base class supplies operators `<=`, `>=`, `>`, and `!=`]]
43 [section Class template `type_info` observers]
45 char const* name() const;
48 [[Returns][The result of calling `name()` on the argument used to construct the object.]]
54 std::ostream& operator<<(std::ostream&s, type_info const&x);
57 [[Effects][Writes a description of the type described by to `x` into s.]]
58 [[Rationale][Not every C++ implementation provides a truly human-readable `type_info::name()` string, but for some we may be able to decode the string and produce a reasonable representation.]]
59 [[Note][On some non-conforming C++ implementations, the code is not actually as simple as described above; the semantics are adjusted to work as-if the C++ implementation were conforming.]]
62 template <class T> type_info type_id()
65 [[Returns][`type_info(typeid(T))`]]
66 [[Note][On some non-conforming C++ implementations, the code is not actually as simple as described above; the semantics are adjusted to work as-if the C++ implementation were conforming.]]
70 The following example, though silly, illustrates how the type_id facility might be used
72 #include <boost/python/type_id.hpp>
74 // Returns true iff the user passes an int argument
78 using boost::python::type_id;
79 return type_id<T>() == type_id<int>();