|
|
@@ -59,57 +59,57 @@ class basic_any {
|
|
|
template<typename Type>
|
|
|
static const void *basic_vtable(const operation op, const basic_any &value, const void *other) {
|
|
|
static_assert(!std::is_void_v<Type> && std::is_same_v<std::remove_cv_t<std::remove_reference_t<Type>>, Type>, "Invalid type");
|
|
|
- const Type *element = nullptr;
|
|
|
+ const Type *elem = nullptr;
|
|
|
|
|
|
if constexpr(in_situ<Type>) {
|
|
|
- element = (value.mode == any_policy::owner) ? reinterpret_cast<const Type *>(&value.storage) : static_cast<const Type *>(value.instance);
|
|
|
+ elem = (value.mode == any_policy::owner) ? reinterpret_cast<const Type *>(&value.storage) : static_cast<const Type *>(value.instance);
|
|
|
} else {
|
|
|
- element = static_cast<const Type *>(value.instance);
|
|
|
+ elem = static_cast<const Type *>(value.instance);
|
|
|
}
|
|
|
|
|
|
switch(op) {
|
|
|
case operation::copy:
|
|
|
if constexpr(std::is_copy_constructible_v<Type>) {
|
|
|
- static_cast<basic_any *>(const_cast<void *>(other))->initialize<Type>(*element);
|
|
|
+ static_cast<basic_any *>(const_cast<void *>(other))->initialize<Type>(*elem);
|
|
|
}
|
|
|
break;
|
|
|
case operation::move:
|
|
|
if constexpr(in_situ<Type>) {
|
|
|
if(value.mode == any_policy::owner) {
|
|
|
- return ::new(&static_cast<basic_any *>(const_cast<void *>(other))->storage) Type{std::move(*const_cast<Type *>(element))};
|
|
|
+ return ::new(&static_cast<basic_any *>(const_cast<void *>(other))->storage) Type{std::move(*const_cast<Type *>(elem))};
|
|
|
}
|
|
|
}
|
|
|
|
|
|
return (static_cast<basic_any *>(const_cast<void *>(other))->instance = std::exchange(const_cast<basic_any &>(value).instance, nullptr));
|
|
|
case operation::transfer:
|
|
|
if constexpr(std::is_move_assignable_v<Type>) {
|
|
|
- *const_cast<Type *>(element) = std::move(*static_cast<Type *>(const_cast<void *>(other)));
|
|
|
+ *const_cast<Type *>(elem) = std::move(*static_cast<Type *>(const_cast<void *>(other)));
|
|
|
return other;
|
|
|
}
|
|
|
[[fallthrough]];
|
|
|
case operation::assign:
|
|
|
if constexpr(std::is_copy_assignable_v<Type>) {
|
|
|
- *const_cast<Type *>(element) = *static_cast<const Type *>(other);
|
|
|
+ *const_cast<Type *>(elem) = *static_cast<const Type *>(other);
|
|
|
return other;
|
|
|
}
|
|
|
break;
|
|
|
case operation::destroy:
|
|
|
if constexpr(in_situ<Type>) {
|
|
|
- element->~Type();
|
|
|
+ elem->~Type();
|
|
|
} else if constexpr(std::is_array_v<Type>) {
|
|
|
- delete[] element;
|
|
|
+ delete[] elem;
|
|
|
} else {
|
|
|
- delete element;
|
|
|
+ delete elem;
|
|
|
}
|
|
|
break;
|
|
|
case operation::compare:
|
|
|
if constexpr(!std::is_function_v<Type> && !std::is_array_v<Type> && is_equality_comparable_v<Type>) {
|
|
|
- return *element == *static_cast<const Type *>(other) ? other : nullptr;
|
|
|
+ return *elem == *static_cast<const Type *>(other) ? other : nullptr;
|
|
|
} else {
|
|
|
- return (element == other) ? other : nullptr;
|
|
|
+ return (elem == other) ? other : nullptr;
|
|
|
}
|
|
|
case operation::get:
|
|
|
- return element;
|
|
|
+ return elem;
|
|
|
}
|
|
|
|
|
|
return nullptr;
|