diff options
| author | Richard Smith <richard-llvm@metafoo.co.uk> | 2012-03-09 08:37:16 +0000 |
|---|---|---|
| committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2012-03-09 08:37:16 +0000 |
| commit | c1b0565a26a4d578f19d0c99253926a255c78573 (patch) | |
| tree | 20562ccc56914afa918ea4dcb80df5c0e7d070bc /clang | |
| parent | 768ceccc75f06329c7a68bebf9dc59c6dd81b3de (diff) | |
| download | bcm5719-llvm-c1b0565a26a4d578f19d0c99253926a255c78573.tar.gz bcm5719-llvm-c1b0565a26a4d578f19d0c99253926a255c78573.zip | |
Literal operator suffixes and regular names live in separate namespaces.
llvm-svn: 152395
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/AST/DeclarationName.cpp | 11 | ||||
| -rw-r--r-- | clang/test/CXX/over/over.oper/over.literal/p2.cpp | 6 | ||||
| -rw-r--r-- | clang/test/SemaCXX/cxx11-user-defined-literals.cpp | 9 |
3 files changed, 23 insertions, 3 deletions
diff --git a/clang/lib/AST/DeclarationName.cpp b/clang/lib/AST/DeclarationName.cpp index a5488e67ca2..64924ad9509 100644 --- a/clang/lib/AST/DeclarationName.cpp +++ b/clang/lib/AST/DeclarationName.cpp @@ -53,7 +53,7 @@ public: void *FETokenInfo; }; -/// CXXLiberalOperatorName - Contains the actual identifier that makes up the +/// CXXLiteralOperatorName - Contains the actual identifier that makes up the /// name. /// /// This identifier is stored here rather than directly in DeclarationName so as @@ -64,6 +64,10 @@ class CXXLiteralOperatorIdName public: IdentifierInfo *ID; + /// FETokenInfo - Extra information associated with this operator + /// name that can be used by the front end. + void *FETokenInfo; + void Profile(llvm::FoldingSetNodeID &FSID) { FSID.AddPointer(ID); } @@ -333,7 +337,7 @@ void *DeclarationName::getFETokenInfoAsVoid() const { return getAsCXXOperatorIdName()->FETokenInfo; case CXXLiteralOperatorName: - return getCXXLiteralIdentifier()->getFETokenInfo<void>(); + return getAsCXXLiteralOperatorIdName()->FETokenInfo; default: llvm_unreachable("Declaration name has no FETokenInfo"); @@ -357,7 +361,7 @@ void DeclarationName::setFETokenInfo(void *T) { break; case CXXLiteralOperatorName: - getCXXLiteralIdentifier()->setFETokenInfo(T); + getAsCXXLiteralOperatorIdName()->FETokenInfo = T; break; default: @@ -471,6 +475,7 @@ DeclarationNameTable::getCXXLiteralOperatorName(IdentifierInfo *II) { CXXLiteralOperatorIdName *LiteralName = new (Ctx) CXXLiteralOperatorIdName; LiteralName->ExtraKindOrNumArgs = DeclarationNameExtra::CXXLiteralOperator; LiteralName->ID = II; + LiteralName->FETokenInfo = 0; LiteralNames->InsertNode(LiteralName, InsertPos); return DeclarationName(LiteralName); diff --git a/clang/test/CXX/over/over.oper/over.literal/p2.cpp b/clang/test/CXX/over/over.oper/over.literal/p2.cpp index fb11ca55786..d0dfde439eb 100644 --- a/clang/test/CXX/over/over.oper/over.literal/p2.cpp +++ b/clang/test/CXX/over/over.oper/over.literal/p2.cpp @@ -25,3 +25,9 @@ void f() { extern "C++" { void operator "" _g(const char *); } + +template<char...> void operator "" _h() {} + +template<> void operator "" _h<'a', 'b', 'c'>() {} + +template void operator "" _h<'a', 'b', 'c', 'd'>(); diff --git a/clang/test/SemaCXX/cxx11-user-defined-literals.cpp b/clang/test/SemaCXX/cxx11-user-defined-literals.cpp index 4cfd4d382bb..4bbecdb5b8e 100644 --- a/clang/test/SemaCXX/cxx11-user-defined-literals.cpp +++ b/clang/test/SemaCXX/cxx11-user-defined-literals.cpp @@ -126,3 +126,12 @@ template<char...Cs> constexpr unsigned operator"" _hash() { } static_assert(0x1234_hash == 0x103eff5e, ""); static_assert(hash<'0', 'x', '1', '2', '3', '4'>(0) == 0x103eff5e, ""); + +// Functions and literal suffixes go in separate namespaces. +namespace Namespace { + template<char...> int operator"" _x(); + int k = _x(); // expected-error {{undeclared identifier '_x'}} + + int _y(unsigned long long); + int k2 = 123_y; // expected-error {{no matching literal operator for call to 'operator "" _y'}} +} |

