Details
Diff Detail
Event Timeline
Is this intended to not handle all the binary operators in this patch? And also, is this intended to only impact initializers?
clang/lib/AST/Interp/ByteCodeExprGen.cpp | ||
---|---|---|
587–588 | Should we be getting the canonical type because of the assertion below? I'm wondering specifically about a case where the LHS is a complex type and the RHS is a typedef to a complex type, that kind of thing. |
Yes, just a subset for now.
And also, is this intended to only impact initializers?
Yes, due to problems with (non-)initializers. This should work after https://reviews.llvm.org/D156027 though.
Okay, thanks for confirmation! The only outstanding thing is adding coverage for typedef types:
using Frobble = float; using Bobble = _Complex float; using Gobble = _Complex Frobble; constexpr _Complex Frobble A = { 13.0, 2.0 }; constexpr Bobble B = { 2.0, 1.0 }; constexpr Gobble C = { 3.0, 5.0 }; constexpr _Complex float D = A - B; constexpr _Complex float E = C - B; static_assert(__real(D) == 11.0, ""); static_assert(__imag(D) == 1.0, ""); static_assert(__real(E) == 1.0, ""); static_assert(__imag(E) == 4.0, "");
Hmmm, I think the answer is "no"... and "maybe." _Complex can only be followed by float, double, or long double specifically per the C standard. However, we also support _Complex int (and others) as an extension, which starts to make _Complex look more like _Atomic in that it augments an existing type, and so typedefs seem quite reasonable.
But that's not your issue to worry about. Instead, let's go with this test:
using Bobble = _Complex float; constexpr _Complex float A = { 13.0, 2.0 }; constexpr Bobble B = { 2.0, 1.0 }; constexpr _Complex float D = A - B; static_assert(__real(D) == 11.0, ""); static_assert(__imag(D) == 1.0, "");
I know that much, I guess I was confused by the diagnostics:
../clang/test/AST/Interp/complex.cpp:121:18: warning: plain '_Complex' requires a type specifier; assuming '_Complex double' 121 | using Gobble = _Complex Frobble; | ^ | double
Yeah, that diagnostic could stand to be improved; but is orthogonal to your patch.
LGTM though there's a comment on the test cases you should peek at.
clang/test/AST/Interp/complex.cpp | ||
---|---|---|
119–124 | Should this be under the Sub namespace instead of hanging out by itself? |
clang/test/AST/Interp/complex.cpp | ||
---|---|---|
119–124 | Yeah I guess it should. |
Should we be getting the canonical type because of the assertion below? I'm wondering specifically about a case where the LHS is a complex type and the RHS is a typedef to a complex type, that kind of thing.