parent
4c19e0273a
commit
58da54cb7a
@ -44,7 +44,7 @@ struct base_any_policy
|
|||||||
virtual void clone(void* const* src, void** dest) = 0;
|
virtual void clone(void* const* src, void** dest) = 0;
|
||||||
virtual void move(void* const* src, void** dest) = 0;
|
virtual void move(void* const* src, void** dest) = 0;
|
||||||
virtual void* get_value(void** src) = 0;
|
virtual void* get_value(void** src) = 0;
|
||||||
virtual void* get_value(void* const * src) = 0;
|
virtual const void* get_value(void* const * src) = 0;
|
||||||
virtual ::size_t get_size() = 0;
|
virtual ::size_t get_size() = 0;
|
||||||
virtual const std::type_info& type() = 0;
|
virtual const std::type_info& type() = 0;
|
||||||
virtual void print(std::ostream& out, void* const* src) = 0;
|
virtual void print(std::ostream& out, void* const* src) = 0;
|
||||||
@ -70,7 +70,7 @@ struct small_any_policy : typed_base_any_policy<T>
|
|||||||
virtual void clone(void* const* src, void** dest) { *dest = *src; }
|
virtual void clone(void* const* src, void** dest) { *dest = *src; }
|
||||||
virtual void move(void* const* src, void** dest) { *dest = *src; }
|
virtual void move(void* const* src, void** dest) { *dest = *src; }
|
||||||
virtual void* get_value(void** src) { return reinterpret_cast<void*>(src); }
|
virtual void* get_value(void** src) { return reinterpret_cast<void*>(src); }
|
||||||
virtual void* get_value(void* const * src) { return const_cast<void *>( reinterpret_cast<const void*>(src) ); }
|
virtual const void* get_value(void* const * src) { return reinterpret_cast<const void*>(src); }
|
||||||
virtual void print(std::ostream& out, void* const* src) { out << *reinterpret_cast<T const*>(src); }
|
virtual void print(std::ostream& out, void* const* src) { out << *reinterpret_cast<T const*>(src); }
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -95,7 +95,7 @@ struct big_any_policy : typed_base_any_policy<T>
|
|||||||
**reinterpret_cast<T**>(dest) = **reinterpret_cast<T* const*>(src);
|
**reinterpret_cast<T**>(dest) = **reinterpret_cast<T* const*>(src);
|
||||||
}
|
}
|
||||||
virtual void* get_value(void** src) { return *src; }
|
virtual void* get_value(void** src) { return *src; }
|
||||||
virtual void* get_value(void* const * src) { return const_cast<void*>(*src); }
|
virtual const void* get_value(void* const * src) { return *src; }
|
||||||
virtual void print(std::ostream& out, void* const* src) { out << *reinterpret_cast<T const*>(*src); }
|
virtual void print(std::ostream& out, void* const* src) { out << *reinterpret_cast<T const*>(*src); }
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -260,7 +260,7 @@ public:
|
|||||||
const T& cast() const
|
const T& cast() const
|
||||||
{
|
{
|
||||||
if (policy->type() != typeid(T)) throw anyimpl::bad_any_cast();
|
if (policy->type() != typeid(T)) throw anyimpl::bad_any_cast();
|
||||||
T* r = reinterpret_cast<T*>(policy->get_value(&object));
|
const T* r = reinterpret_cast<const T*>(policy->get_value(&object));
|
||||||
return *r;
|
return *r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user