ipc_helpers: Add member functions for pushing and popping strongly typed enums
Alleviates the need to static_cast to an enum type at the call sites of the Push and Pop calls. We only allow strongly typed enums, as they have a defined type of int by default if an underlying type isn't explicitly specified, whereas with regular enums, if an underlying type isn't specified, an implementation-defined type is used that can fit all the enumeration values.
This commit is contained in:
parent
9699194b54
commit
91a804707b
|
@ -98,6 +98,15 @@ public:
|
|||
template <typename First, typename... Other>
|
||||
void Push(const First& first_value, const Other&... other_values);
|
||||
|
||||
template <typename T>
|
||||
void PushEnum(T value) {
|
||||
static_assert(std::is_enum<T>(), "T must be an enum type within a PushEnum call.");
|
||||
static_assert(!std::is_convertible<T, int>(),
|
||||
"enum type in PushEnum must be a strongly typed enum.");
|
||||
static_assert(sizeof(value) < sizeof(u64), "64-bit enums may not be pushed.");
|
||||
Push(static_cast<std::underlying_type_t<T>>(value));
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Copies the content of the given trivially copyable class to the buffer as a normal
|
||||
* param
|
||||
|
@ -273,6 +282,15 @@ public:
|
|||
template <typename First, typename... Other>
|
||||
void Pop(First& first_value, Other&... other_values);
|
||||
|
||||
template <typename T>
|
||||
T PopEnum() {
|
||||
static_assert(std::is_enum<T>(), "T must be an enum type within a PopEnum call.");
|
||||
static_assert(!std::is_convertible<T, int>(),
|
||||
"enum type in PopEnum must be a strongly typed enum.");
|
||||
static_assert(sizeof(T) < sizeof(u64), "64-bit enums cannot be popped.");
|
||||
return static_cast<T>(Pop<std::underlying_type_t<T>>());
|
||||
}
|
||||
|
||||
/// Equivalent to calling `PopHandles<1>()[0]`.
|
||||
Kernel::Handle PopHandle();
|
||||
|
||||
|
|
Reference in New Issue