diff options
author | Anders Carlsson <andersca@mac.com> | 2009-03-15 20:12:13 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-03-15 20:12:13 +0000 |
commit | 5bd30395b96ce7ab3e5495a2af5639c3b29669ea (patch) | |
tree | b9c498f9379c40dfa47b3ad7434f971ee6a6fde2 /clang/test/SemaTemplate/instantiate-array.cpp | |
parent | 27de6a5e9148f3090fdf4e70c50a9238e60d11d0 (diff) | |
download | bcm5719-llvm-5bd30395b96ce7ab3e5495a2af5639c3b29669ea.tar.gz bcm5719-llvm-5bd30395b96ce7ab3e5495a2af5639c3b29669ea.zip |
(Hopefully) instantiate dependent array types correctly.
llvm-svn: 67032
Diffstat (limited to 'clang/test/SemaTemplate/instantiate-array.cpp')
-rw-r--r-- | clang/test/SemaTemplate/instantiate-array.cpp | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/clang/test/SemaTemplate/instantiate-array.cpp b/clang/test/SemaTemplate/instantiate-array.cpp new file mode 100644 index 00000000000..d67645e0417 --- /dev/null +++ b/clang/test/SemaTemplate/instantiate-array.cpp @@ -0,0 +1,28 @@ +// RUN: clang -fsyntax-only -verify %s -std=c++0x + +#ifndef __GXX_EXPERIMENTAL_CXX0X__ +#define __CONCAT(__X, __Y) __CONCAT1(__X, __Y) +#define __CONCAT1(__X, __Y) __X ## __Y + +#define static_assert(__b, __m) \ + typedef int __CONCAT(__sa, __LINE__)[__b ? 1 : -1] +#endif + +template <int N> class IntArray { + int elems[N]; +}; + +static_assert(sizeof(IntArray<10>) == sizeof(int) * 10, "Array size mismatch"); +static_assert(sizeof(IntArray<1>) == sizeof(int) * 1, "Array size mismatch"); + +template <typename T> class TenElementArray { + int elems[10]; +}; + +static_assert(sizeof(TenElementArray<int>) == sizeof(int) * 10, "Array size mismatch"); + +template<typename T, int N> class Array { + T elems[N]; +}; + +static_assert(sizeof(Array<int, 10>) == sizeof(int) * 10, "Array size mismatch"); |