From: Alexey Bataev Date: Tue, 5 May 2015 09:53:25 +0000 (+0000) Subject: [OPENMP] Allow use of macros in OpenMP directives/clauses. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8382bdc131aba586db57b5b6ed62195fa081dd38;p=clang [OPENMP] Allow use of macros in OpenMP directives/clauses. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@236493 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Parse/ParsePragma.cpp b/lib/Parse/ParsePragma.cpp index 96484b496d..a8641efb70 100644 --- a/lib/Parse/ParsePragma.cpp +++ b/lib/Parse/ParsePragma.cpp @@ -1489,7 +1489,7 @@ PragmaOpenMPHandler::HandlePragma(Preprocessor &PP, Token *Toks = new Token[Pragma.size()]; std::copy(Pragma.begin(), Pragma.end(), Toks); PP.EnterTokenStream(Toks, Pragma.size(), - /*DisableMacroExpansion=*/true, /*OwnsTokens=*/true); + /*DisableMacroExpansion=*/false, /*OwnsTokens=*/true); } /// \brief Handle '#pragma pointers_to_members' diff --git a/test/OpenMP/parallel_num_threads_messages.cpp b/test/OpenMP/parallel_num_threads_messages.cpp index facca5e358..e82683893f 100644 --- a/test/OpenMP/parallel_num_threads_messages.cpp +++ b/test/OpenMP/parallel_num_threads_messages.cpp @@ -9,6 +9,8 @@ bool foobool(int argc) { struct S1; // expected-note {{declared here}} +#define redef_num_threads(a, b) num_threads(a) + template // expected-note {{declared here}} T tmain(T argc, S **argv) { #pragma omp parallel num_threads // expected-error {{expected '(' after 'num_threads'}} @@ -22,6 +24,7 @@ T tmain(T argc, S **argv) { #pragma omp parallel num_threads (argv[1]=2) // expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error 2 {{expression must have integral or unscoped enumeration type, not 'char *'}} #pragma omp parallel num_threads (argc) #pragma omp parallel num_threads (N) // expected-error {{argument to 'num_threads' clause must be a positive integer value}} + #pragma omp parallel redef_num_threads (argc, argc) foo(); return argc; @@ -38,6 +41,7 @@ int main(int argc, char **argv) { #pragma omp parallel num_threads (S1) // expected-error {{'S1' does not refer to a value}} #pragma omp parallel num_threads (argv[1]=2) // expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error {{expression must have integral or unscoped enumeration type, not 'char *'}} #pragma omp parallel num_threads (num_threads(tmain(argc, argv) // expected-error 2 {{expected ')'}} expected-note 2 {{to match this '('}} expected-note {{in instantiation of function template specialization 'tmain' requested here}} + #pragma omp parallel redef_num_threads (argc, argc) foo(); return tmain(argc, argv); // expected-note {{in instantiation of function template specialization 'tmain' requested here}}