diff options
author | Anders Carlsson <andersca@mac.com> | 2011-01-16 23:56:42 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2011-01-16 23:56:42 +0000 |
commit | 1f3b6fdabbb10779a473d6315154d7325ce20aea (patch) | |
tree | 1a81fa5cf3af3bf54977a0cbc6a8b225b9b6ae29 /lib/Parse/ParseDeclCXX.cpp | |
parent | 0dc5f9aea3597f2ed400dd0c1bf45ebbb4a051f3 (diff) |
Begin work on supporting "N3206: Override control: Eliminating Attributes", from
http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2010/n3206.htm
This lands support for parsing virt-specifier-seq after member functions, including the
contextual keywords 'final', and 'override'. The keywords are not yet used for anything.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@123606 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Parse/ParseDeclCXX.cpp')
-rw-r--r-- | lib/Parse/ParseDeclCXX.cpp | 46 |
1 files changed, 45 insertions, 1 deletions
diff --git a/lib/Parse/ParseDeclCXX.cpp b/lib/Parse/ParseDeclCXX.cpp index a5cdaa8674..960a9fab68 100644 --- a/lib/Parse/ParseDeclCXX.cpp +++ b/lib/Parse/ParseDeclCXX.cpp @@ -1261,6 +1261,39 @@ void Parser::HandleMemberFunctionDefaultArgs(Declarator& DeclaratorInfo, } } +/// isCXX0XVirtSpecifier - Determine whether the next token is a C++0x +/// virt-specifier. +/// +/// virt-specifier: +/// override +/// final +/// new +bool Parser::isCXX0XVirtSpecifier() const { + if (Tok.is(tok::kw_new)) + return true; + + if (Tok.isNot(tok::identifier)) + return false; + + const IdentifierInfo *II = Tok.getIdentifierInfo(); + return II == Ident_override || II == Ident_final; +} + +/// ParseOptionalCXX0XVirtSpecifierSeq - Parse a virt-specifier-seq. +/// +/// virt-specifier-seq: +/// virt-specifier +/// virt-specifier-seq virt-specifier +void Parser::ParseOptionalCXX0XVirtSpecifierSeq() { + if (!getLang().CPlusPlus0x) + return; + + while (isCXX0XVirtSpecifier()) { + // FIXME: Actually do something with the specifier. + ConsumeToken(); + } +} + /// ParseCXXClassMemberDeclaration - Parse a C++ class member declaration. /// /// member-declaration: @@ -1277,10 +1310,19 @@ void Parser::HandleMemberFunctionDefaultArgs(Declarator& DeclaratorInfo, /// member-declarator-list ',' member-declarator /// /// member-declarator: -/// declarator pure-specifier[opt] +/// declarator virt-specifier-seq[opt] pure-specifier[opt] /// declarator constant-initializer[opt] /// identifier[opt] ':' constant-expression /// +/// virt-specifier-seq: +/// virt-specifier +/// virt-specifier-seq virt-specifier +/// +/// virt-specifier: +/// override +/// final +/// new +/// /// pure-specifier: /// '= 0' /// @@ -1470,6 +1512,8 @@ void Parser::ParseCXXClassMemberDeclaration(AccessSpecifier AS, SkipUntil(tok::comma, true, true); } + ParseOptionalCXX0XVirtSpecifierSeq(); + // pure-specifier: // '= 0' // |