
On 3/28/2012 2:58 PM, Michel Morin wrote:
Eric Niebler wrote:
Hmm…, my N3290 does not have such a wording in 7.1.6.2 (dcl.type.simple) p4.
The (non-normative) note in 7.1.6.2 about this is in p5, not p4. But the normative text is in 5.2.2 p11.
I don't see any text about about how decltype of a function call expression is determined in 5.2.2 p11 or 7.1.6.2 p5.
Sorry, my post may be misleading and not clear. The subject of this thread should be: "Test fails on clang trunk and gcc-4.7 due to changes *made* in FDIS" and I'm talking about the changes *made* in FDIS.
OK.
Specifically, the change is about how decltype of a function call expression is determined. * N3242 says that in 7.1.6.2 p4: if e is a function call or an invocation of an overloaded operator (parentheses around e are ignored), decltype(e) is the return type of the statically chosen function;
* N3290 (FDIS) does not have such a wording. For a function call expression, decltype(e) is determined by the last rule in 7.1.6.2 p4: otherwise, decltype(e) is the type of e.
So, for "const int f();", * In N3242, decltype(f()) is const int; * In N3290, decltype(f()) is int.
Ah. *Now* I see what you're saying. <palmface> I think I agree with your analysis, but I'm going to check with somebody real quick. It's funny, I don't remember this change being discussed as part of the decltype 1.1 discussion. It was probably changed at the very last pre-FDIS committee meeting, which I didn't attend. Stay tuned ... -- Eric Niebler BoostPro Computing http://www.boostpro.com