diff options
author | Alexis Hunt <alercah@gmail.com> | 2010-08-29 21:26:48 +0000 |
---|---|---|
committer | Alexis Hunt <alercah@gmail.com> | 2010-08-29 21:26:48 +0000 |
commit | 79eb5469e04aa8906262619d1f7a3a71ba5dbd94 (patch) | |
tree | 6c9a4252f73fd27626204a4de22602dc8802d849 /clang/test/SemaCXX/literal-operators.cpp | |
parent | c843fca2fde772c85010123556d3e3abeb75b9ab (diff) | |
download | bcm5719-llvm-79eb5469e04aa8906262619d1f7a3a71ba5dbd94.tar.gz bcm5719-llvm-79eb5469e04aa8906262619d1f7a3a71ba5dbd94.zip |
Implement C++0x user-defined string literals.
The extra data stored on user-defined literal Tokens is stored in extra
allocated memory, which is managed by the PreprocessorLexer because there isn't
a better place to put it that makes sure it gets deallocated, but only after
it's used up. My testing has shown no significant slowdown as a result, but
independent testing would be appreciated.
llvm-svn: 112458
Diffstat (limited to 'clang/test/SemaCXX/literal-operators.cpp')
-rw-r--r-- | clang/test/SemaCXX/literal-operators.cpp | 43 |
1 files changed, 11 insertions, 32 deletions
diff --git a/clang/test/SemaCXX/literal-operators.cpp b/clang/test/SemaCXX/literal-operators.cpp index ec585a61da9..93fd4b6a142 100644 --- a/clang/test/SemaCXX/literal-operators.cpp +++ b/clang/test/SemaCXX/literal-operators.cpp @@ -2,42 +2,21 @@ #include <stddef.h> -struct tag { - void operator "" tag_bad (const char *); // expected-error {{literal operator 'operator "" tag_bad' must be in a namespace or global scope}} - friend void operator "" tag_good (const char *); +template <typename T, typename U> struct same_type { + static const bool value = false; }; -namespace ns { void operator "" ns_good (const char *); } - -// Check extern "C++" declarations -extern "C++" void operator "" extern_good (const char *); -extern "C++" { void operator "" extern_good (const char *); } - -void fn () { void operator "" fn_bad (const char *); } // expected-error {{literal operator 'operator "" fn_bad' must be in a namespace or global scope}} - -// One-param declarations (const char * was already checked) -void operator "" good (char); -void operator "" good (wchar_t); -void operator "" good (char16_t); -void operator "" good (char32_t); -void operator "" good (unsigned long long); -void operator "" good (long double); +template <typename T> struct same_type<T, T> { + static const bool value = true; +}; -// Two-param declarations -void operator "" good (const char *, size_t); -void operator "" good (const wchar_t *, size_t); -void operator "" good (const char16_t *, size_t); -void operator "" good (const char32_t *, size_t); +int operator "" _int (const char *, size_t); +static_assert(same_type<int, decltype(""_int)>::value, "not the same type!"); -// Check typedef and array equivalences -void operator "" good (const char[]); -typedef const char c; -void operator "" good (c*); +int i = ""_int; +int j = L""_int; // expected-error {{no matching literal operator function}} -// Check extra cv-qualifiers -void operator "" cv_good (volatile const char *, const size_t); +int operator "" _int (const wchar_t *, size_t); -// Template delcaration (not implemented yet) -// template <char...> void operator "" good (); +int k = L""_int; -// FIXME: Test some invalid decls that might crop up. |