[cfe-commits] r64994 - in /cfe/trunk/lib: AST/ExprConstant.cpp CodeGen/CGBlocks.cpp CodeGen/CGExprConstant.cpp CodeGen/CGExprScalar.cpp CodeGen/CodeGenModule.h

Eli Friedman eli.friedman at gmail.com
Wed Feb 18 19:41:33 PST 2009


On Wed, Feb 18, 2009 at 7:22 PM, Mike Stump <mrs at apple.com> wrote:
> On Feb 18, 2009, at 7:12 PM, Eli Friedman wrote:
>>
>> On Wed, Feb 18, 2009 at 5:01 PM, Mike Stump <mrs at apple.com> wrote:
>>>
>>> --- cfe/trunk/lib/AST/ExprConstant.cpp (original)
>>> +++ cfe/trunk/lib/AST/ExprConstant.cpp Wed Feb 18 19:01:04 2009
>>> @@ -260,6 +260,7 @@
>>>  APValue VisitAddrLabelExpr(AddrLabelExpr *E)
>>>     { return APValue(E, 0); }
>>>  APValue VisitCallExpr(CallExpr *E);
>>> +  APValue VisitBlockExpr(BlockExpr *E) { return APValue(E, 0); }
>>
>> Aren't there some missing checks here?
>
> Work in progress.  There is all sorts of checking, semantics and codegen
> missing.

That's fine, but it would be nice to at least put in a FIXME for the
missing checks.

>> Block expressions can't possibly be constant in general.
>
> They are?!  That is why they are called block literal expressions.  In the
> same way that 1 is a literal and unchanging, ^{} is a literal, constant and
> unchanging.  Now, I could easily have it wrong, it you could point out the
> part you thought would vary, I can contemplate it.

Hmm, I might be confused about something, but take something like the
following (I haven't checked if this particular example compiles, but
this sort of thing is legal):
int a(int x) {
static int (^y)(void) = ^{x;};
return y();
}

This initializer for y must be illegal because it can't be evaluated
at compile-time: the returned value changes!  Therefore, blocks aren't
constant in the general case.

I believe that file-scope block expressions are constant, but you need
some way to check that; the use of isFileScope for compund literals
would be a good example to follow.

-Eli



More information about the cfe-commits mailing list