improve isPodLike to know that all non-class types are pod.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@91425 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2009-12-15 07:40:44 +00:00
parent 729a8acc9f
commit dc2e570411
2 changed files with 24 additions and 27 deletions

View File

@ -46,6 +46,13 @@ namespace std {
namespace llvm {
/// SmallVectorBase - This is all the non-templated stuff common to all
/// SmallVectors.
class SmallVectorBase {
};
/// SmallVectorImpl - This class consists of common code factored out of the
/// SmallVector class to reduce code duplication based on the SmallVector 'N'
/// template parameter.

View File

@ -26,33 +26,6 @@
namespace llvm {
/// isPodLike - This is a type trait that is used to determine whether a given
/// type can be copied around with memcpy instead of running ctors etc.
template <typename T>
struct isPodLike {
static const bool value = false;
};
// pointers are all pod-like.
template <typename T>
struct isPodLike<T*> { static const bool value = true; };
// builtin types are pod-like as well.
// There is probably a much better way to do this.
template <> struct isPodLike<char> { static const bool value = true; };
template <> struct isPodLike<unsigned> { static const bool value = true; };
template <> struct isPodLike<unsigned long> { static const bool value = true; };
template <> struct isPodLike<unsigned long long> {
static const bool value = true;
};
// pairs are pod-like if their elements are.
template<typename T, typename U>
struct isPodLike<std::pair<T, U> > {
static const bool value = isPodLike<T>::value & isPodLike<U>::value;
};
namespace dont_use
{
// These two functions should never be used. They are helpers to
@ -78,6 +51,23 @@ struct is_class
enum { value = sizeof(char) == sizeof(dont_use::is_class_helper<T>(0)) };
};
/// isPodLike - This is a type trait that is used to determine whether a given
/// type can be copied around with memcpy instead of running ctors etc.
template <typename T>
struct isPodLike {
// If we don't know anything else, we can (at least) assume that all non-class
// types are PODs.
static const bool value = !is_class<T>::value;
};
// std::pair's are pod-like if their elements are.
template<typename T, typename U>
struct isPodLike<std::pair<T, U> > {
static const bool value = isPodLike<T>::value & isPodLike<U>::value;
};
/// \brief Metafunction that determines whether the two given types are
/// equivalent.
template<typename T, typename U>