diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2015-07-05 14:23:59 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2015-07-05 14:23:59 +0000 | 
| commit | c192b3dcffd5e672a2b2e1730e2440febb4fb192 (patch) | |
| tree | ac719b5984165053bf83d71142e4d96b609b9784 /lib/Parse/ParseDecl.cpp | |
| parent | 2e645aa5697838f16ec570eb07c2bee7e13d0e0b (diff) | |
Notes
Diffstat (limited to 'lib/Parse/ParseDecl.cpp')
| -rw-r--r-- | lib/Parse/ParseDecl.cpp | 40 | 
1 files changed, 24 insertions, 16 deletions
| diff --git a/lib/Parse/ParseDecl.cpp b/lib/Parse/ParseDecl.cpp index 1c52552ea15d..d843e801b634 100644 --- a/lib/Parse/ParseDecl.cpp +++ b/lib/Parse/ParseDecl.cpp @@ -691,9 +691,9 @@ void Parser::ParseNullabilityTypeSpecifiers(ParsedAttributes &attrs) {    // Treat these like attributes, even though they're type specifiers.    while (true) {      switch (Tok.getKind()) { -    case tok::kw___nonnull: -    case tok::kw___nullable: -    case tok::kw___null_unspecified: { +    case tok::kw__Nonnull: +    case tok::kw__Nullable: +    case tok::kw__Null_unspecified: {        IdentifierInfo *AttrName = Tok.getIdentifierInfo();        SourceLocation AttrNameLoc = ConsumeToken();        if (!getLangOpts().ObjC1) @@ -2173,7 +2173,7 @@ void Parser::ParseSpecifierQualifierList(DeclSpec &DS, AccessSpecifier AS,    }    // Issue diagnostic and remove constexpr specfier if present. -  if (DS.isConstexprSpecified()) { +  if (DS.isConstexprSpecified() && DSC != DSC_condition) {      Diag(DS.getConstexprSpecLoc(), diag::err_typename_invalid_constexpr);      DS.ClearConstexprSpec();    } @@ -3076,9 +3076,9 @@ void Parser::ParseDeclarationSpecifiers(DeclSpec &DS,        continue;      // Nullability type specifiers. -    case tok::kw___nonnull: -    case tok::kw___nullable: -    case tok::kw___null_unspecified: +    case tok::kw__Nonnull: +    case tok::kw__Nullable: +    case tok::kw__Null_unspecified:        ParseNullabilityTypeSpecifiers(DS.getAttributes());        continue; @@ -3192,6 +3192,11 @@ void Parser::ParseDeclarationSpecifiers(DeclSpec &DS,        isInvalid = DS.SetConstexprSpec(Loc, PrevSpec, DiagID);        break; +    // concept +    case tok::kw_concept: +      isInvalid = DS.SetConceptSpec(Loc, PrevSpec, DiagID); +      break; +      // type-specifier      case tok::kw_short:        isInvalid = DS.SetTypeSpecWidth(DeclSpec::TSW_short, Loc, PrevSpec, @@ -4326,9 +4331,9 @@ bool Parser::isTypeSpecifierQualifier() {    case tok::kw___pascal:    case tok::kw___unaligned: -  case tok::kw___nonnull: -  case tok::kw___nullable: -  case tok::kw___null_unspecified: +  case tok::kw__Nonnull: +  case tok::kw__Nullable: +  case tok::kw__Null_unspecified:    case tok::kw___private:    case tok::kw___local: @@ -4475,6 +4480,9 @@ bool Parser::isDeclarationSpecifier(bool DisambiguatingWithExpression) {    case tok::annot_decltype:    case tok::kw_constexpr: +    // C++ Concepts TS - concept +  case tok::kw_concept: +      // C11 _Atomic    case tok::kw__Atomic:      return true; @@ -4503,9 +4511,9 @@ bool Parser::isDeclarationSpecifier(bool DisambiguatingWithExpression) {    case tok::kw___pascal:    case tok::kw___unaligned: -  case tok::kw___nonnull: -  case tok::kw___nullable: -  case tok::kw___null_unspecified: +  case tok::kw__Nonnull: +  case tok::kw__Nullable: +  case tok::kw__Null_unspecified:    case tok::kw___private:    case tok::kw___local: @@ -4738,9 +4746,9 @@ void Parser::ParseTypeQualifierListOpt(DeclSpec &DS, unsigned AttrReqs,        goto DoneWithTypeQuals;      // Nullability type specifiers. -    case tok::kw___nonnull: -    case tok::kw___nullable: -    case tok::kw___null_unspecified: +    case tok::kw__Nonnull: +    case tok::kw__Nullable: +    case tok::kw__Null_unspecified:        ParseNullabilityTypeSpecifiers(DS.getAttributes());        continue; | 
