[PATCH] D52321: [CUDA] Fixed parsing of optional template-argument-list.
Artem Belevich via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Fri Sep 21 10:50:42 PDT 2018
This revision was automatically updated to reflect the committed changes.
Closed by commit rC342752: [CUDA] Fixed parsing of optional template-argument-list. (authored by tra, committed by ).
Changed prior to commit:
https://reviews.llvm.org/D52321?vs=166509&id=166512#toc
Repository:
rC Clang
https://reviews.llvm.org/D52321
Files:
lib/Parse/ParseTemplate.cpp
test/Parser/cuda-kernel-call-c++11.cu
test/Parser/cuda-kernel-call.cu
Index: test/Parser/cuda-kernel-call-c++11.cu
===================================================================
--- test/Parser/cuda-kernel-call-c++11.cu
+++ test/Parser/cuda-kernel-call-c++11.cu
@@ -1,6 +1,6 @@
// RUN: %clang_cc1 -fsyntax-only -std=c++11 -verify %s
-template<typename> struct S {};
+template<typename T=int> struct S {};
template<typename> void f();
@@ -11,10 +11,14 @@
// expected-no-diagnostics
S<S<S<int>>> s3;
+ S<S<S<>>> s30;
S<S<S<S<int>>>> s4;
+ S<S<S<S<>>>> s40;
S<S<S<S<S<int>>>>> s5;
+ S<S<S<S<S<>>>>> s50;
(void)(&f<S<S<int>>>==0);
+ (void)(&f<S<S<>>>==0);
}
Index: test/Parser/cuda-kernel-call.cu
===================================================================
--- test/Parser/cuda-kernel-call.cu
+++ test/Parser/cuda-kernel-call.cu
@@ -1,6 +1,6 @@
// RUN: %clang_cc1 -fsyntax-only -verify %s
-template<typename> struct S {};
+template<typename T=int> struct S {};
template<typename> void f();
void foo(void) {
@@ -13,5 +13,7 @@
// The following two are parse errors because -std=c++11 is not enabled.
S<S<S<int>>> s; // expected-error 2{{use '> >'}}
+ S<S<S<>>> s1; // expected-error 2{{use '> >'}}
(void)(&f<S<S<int>>>==0); // expected-error 2{{use '> >'}}
+ (void)(&f<S<S<>>>==0); // expected-error 2{{use '> >'}}
}
Index: lib/Parse/ParseTemplate.cpp
===================================================================
--- lib/Parse/ParseTemplate.cpp
+++ lib/Parse/ParseTemplate.cpp
@@ -946,7 +946,9 @@
bool Invalid = false;
{
GreaterThanIsOperatorScope G(GreaterThanIsOperator, false);
- if (Tok.isNot(tok::greater) && Tok.isNot(tok::greatergreater))
+ if (!Tok.isOneOf(tok::greater, tok::greatergreater,
+ tok::greatergreatergreater, tok::greaterequal,
+ tok::greatergreaterequal))
Invalid = ParseTemplateArgumentList(TemplateArgs);
if (Invalid) {
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D52321.166512.patch
Type: text/x-patch
Size: 1916 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20180921/82482f02/attachment-0001.bin>
More information about the cfe-commits
mailing list