[prev in list] [next in list] [prev in thread] [next in thread]
List: cfe-commits
Subject: Re: [PATCH] D10732: [OPENMP 4.0] Initial support for array sections.
From: Richard Smith <richard () metafoo ! co ! uk>
Date: 2015-07-22 22:33:59
Message-ID: a81c2dddec8b58a3439e0462c5707c7b () localhost ! localdomain
[Download RAW message or body]
rsmith added a comment.
OK, I think what's specified in the OpenMP spec is a little different from what we \
have here. In particular, an array section does not appear to be a general-purpose \
expression, it's just a special syntax that can appear only at the top level in \
certain OpenMP clauses to describe a section of a (possibly multidimensional) array. \
As such, it doesn't need a real type, doesn't need to be incorporated into normal \
expression parsing, and so on.
The most straightforward representation would be to give this expression a \
placeholder type, and make `CheckPlaceholderExpr` reject it. Then, in the places \
where it's valid (some OpenMP clause arguments, and on the left-hand side of array \
indexing and array sections), check for this special case before calling \
`CheckPlaceholderExpr` on the base. That's how we deal with other special-case \
constructs that can only appear in a few places (bound member functions, overloaded \
function names, and the like). You can then parse it anywhere (when `OpenMP` is \
enabled) and it'll get automatically rejected if it appears in a context where it's \
not permitted.
Please also rename it to `OMPArraySectionExpr` or similar, since this is not a \
general-purpose construct and is unlikely to be useful anywhere outside OpenMP.
http://reviews.llvm.org/D10732
_______________________________________________
cfe-commits mailing list
cfe-commits@cs.uiuc.edu
http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
[prev in list] [next in list] [prev in thread] [next in thread]
Configure |
About |
News |
Add a list |
Sponsored by KoreLogic