<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><div dir="auto" style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On May 20, 2020, at 5:53 PM, Richard Smith <<a href="mailto:richard@metafoo.co.uk" class="">richard@metafoo.co.uk</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" style="caret-color: rgb(0, 0, 0); font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration: none;" class=""><div dir="ltr" class="">On Wed, 20 May 2020 at 16:30, Akira Hatanaka via cfe-commits <<a href="mailto:cfe-commits@lists.llvm.org" class="">cfe-commits@lists.llvm.org</a>> wrote:<br class=""></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div style="overflow-wrap: break-word;" class=""><div dir="auto" style="overflow-wrap: break-word;" class="">Hi Richard,<div class=""><br class=""></div><div class="">It looks like this patch will reject the following code, which used to compile fine:</div><div class=""><br class=""></div><div class="">$ cat test.cpp</div><div class=""><div style="margin: 0px; font-stretch: normal; font-size: 11px; line-height: normal; font-family: Menlo;" class=""><span style="font-variant-ligatures: no-common-ligatures;" class="">#include <CoreFoundation/CoreFoundation.h></span></div><div style="margin: 0px; font-stretch: normal; font-size: 11px; line-height: normal; font-family: Menlo; min-height: 13px;" class=""><span style="font-variant-ligatures: no-common-ligatures;" class=""></span><br class=""></div><div style="margin: 0px; font-stretch: normal; font-size: 11px; line-height: normal; font-family: Menlo;" class=""><span style="font-variant-ligatures: no-common-ligatures;" class="">typedef CF_ENUM(unsigned, TestEnum) {</span></div><div style="margin: 0px; font-stretch: normal; font-size: 11px; line-height: normal; font-family: Menlo;" class=""><span style="font-variant-ligatures: no-common-ligatures;" class=""> <span class="Apple-converted-space"> </span>A = 2,</span></div><div style="margin: 0px; font-stretch: normal; font-size: 11px; line-height: normal; font-family: Menlo;" class=""><span style="font-variant-ligatures: no-common-ligatures;" class=""> <span class="Apple-converted-space"> </span>B = 3,</span></div><div style="margin: 0px; font-stretch: normal; font-size: 11px; line-height: normal; font-family: Menlo;" class=""><span style="font-variant-ligatures: no-common-ligatures;" class="">};</span></div></div><div class=""><br class=""></div><div class="">$ clang++ -std=c++11 -c test.cpp</div><div class=""><br class=""></div><div class=""><div style="margin: 0px; font-stretch: normal; font-size: 11px; line-height: normal; font-family: Menlo;" class=""><span style="font-variant-ligatures: no-common-ligatures;" class=""><b class="">test.cpp:3:9:<span class="Apple-converted-space"> </span></b></span><span style="font-variant-ligatures: no-common-ligatures; color: rgb(202, 51, 35);" class=""><b class="">error:<span class="Apple-converted-space"> </span></b></span><span style="font-variant-ligatures: no-common-ligatures;" class=""><b class="">non-defining declaration of enumeration with a fixed underlying type is only permitted as a standalone declaration; missing list of enumerators? [-Welaborated-enum-base]</b></span></div><div style="margin: 0px; font-stretch: normal; font-size: 11px; line-height: normal; font-family: Menlo;" class=""><span style="font-variant-ligatures: no-common-ligatures;" class="">typedef CF_ENUM(unsigned, TestEnum) {</span></div><div style="margin: 0px; font-stretch: normal; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(57, 192, 38);" class=""><br class=""></div><div class="">The macro is defined in CFAvailability.h:</div><div class=""><br class=""></div><div class=""><a href="https://opensource.apple.com/source/CF/CF-855.17/CFAvailability.h.auto.html" target="_blank" class="">https://opensource.apple.com/source/CF/CF-855.17/CFAvailability.h.auto.html</a></div><div class=""><br class=""></div><div class="">What’s the best way to fix this?</div></div></div></div></blockquote><div class=""><br class=""></div><div class="">Assuming this macro is always preceded by 'typedef', how about this:</div><div class=""><br class=""></div><div class="">-#define CF_ENUM(_type, _name) enum _name : _type _name; enum _name : _type<br class=""></div><div class=""><div class="">+#define CF_ENUM(_type, _name) int _dummy_##_name; enum _name : _type _name; typedef enum _name _name; enum _name : _type<br class=""></div><div class=""><br class=""></div><div class="">Or this:</div><div class=""><br class=""></div><div class="">+#ifdef __cplusplus<br class=""></div><div class=""> #define CF_ENUM(_type, _name) int _dummy_##_name; enum _name : _type<br class=""></div><div class=""></div><div class="">+#else<br class=""></div><div class=""><div class=""> #define CF_ENUM(_type, _name) enum _name : _type _name; enum _name : _type<br class=""></div><div class="">+#endif</div></div><div class=""><br class=""></div><div class="">(One wonders why the 'typedef' is not part of the macro definition.)</div></div></div></div></div></blockquote><div><br class=""></div><div>Thanks! Is there a way to avoid the dummy typedef so that it doesn’t show up in completions and stuff or some way in C++ to undef the typedef? </div><div><br class=""></div><blockquote type="cite" class=""><div class=""><div dir="ltr" style="caret-color: rgb(0, 0, 0); font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration: none;" class=""><div class="gmail_quote"><div class=""><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div style="overflow-wrap: break-word;" class=""><div dir="auto" style="overflow-wrap: break-word;" class=""><div class=""><div class=""><blockquote type="cite" class=""><div class=""></div></blockquote></div></div></div></div></blockquote></div><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;"><div style="overflow-wrap: break-word;" class=""><div dir="auto" style="overflow-wrap: break-word;" class=""><div class=""><div class=""><blockquote type="cite" class=""><div class="">On May 11, 2020, at 1:37 PM, Richard Smith via cfe-commits <<a href="mailto:cfe-commits@lists.llvm.org" target="_blank" class="">cfe-commits@lists.llvm.org</a>> wrote:</div><br class=""><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; text-decoration: none;" class=""><div dir="ltr" class="">On Mon, 11 May 2020 at 06:37, Hans Wennborg via cfe-commits <<a href="mailto:cfe-commits@lists.llvm.org" target="_blank" class="">cfe-commits@lists.llvm.org</a>> wrote:<br class=""></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;">On Sat, May 9, 2020 at 4:32 AM Richard Smith via cfe-commits<br class=""><<a href="mailto:cfe-commits@lists.llvm.org" target="_blank" class="">cfe-commits@lists.llvm.org</a>> wrote:<br class="">><br class="">><br class="">> Author: Richard Smith<br class="">> Date: 2020-05-08T19:32:00-07:00<br class="">> New Revision: c90e198107431f64b73686bdce31c293e3380ac7<br class="">><br class="">> URL:<span class=""> </span><a href="https://github.com/llvm/llvm-project/commit/c90e198107431f64b73686bdce31c293e3380ac7" rel="noreferrer" target="_blank" class="">https://github.com/llvm/llvm-project/commit/c90e198107431f64b73686bdce31c293e3380ac7</a><br class="">> DIFF:<span class=""> </span><a href="https://github.com/llvm/llvm-project/commit/c90e198107431f64b73686bdce31c293e3380ac7.diff" rel="noreferrer" target="_blank" class="">https://github.com/llvm/llvm-project/commit/c90e198107431f64b73686bdce31c293e3380ac7.diff</a><br class="">><br class="">> LOG: Fix parsing of enum-base to follow C++11 rules.<br class="">><br class="">> Previously we implemented non-standard disambiguation rules to<br class="">> distinguish an enum-base from a bit-field but otherwise treated a :<br class="">> after an elaborated-enum-specifier as introducing an enum-base. That<br class="">> misparses various examples (anywhere an elaborated-type-specifier can<br class="">> appear followed by a colon, such as within a ternary operator or<br class="">> _Generic).<br class="">><br class="">> We now implement the C++11 rules, with the old cases accepted as<br class="">> extensions where that seemed reasonable. These amount to:<br class="">> * an enum-base must always be accompanied by an enum definition (except<br class="">> in a standalone declaration of the form 'enum E : T;')<br class="">> * in a member-declaration, 'enum E :' always introduces an enum-base,<br class="">> never a bit-field<br class="">> * in a type-specifier (or similar context), 'enum E :' is not<br class="">> permitted; the colon means whatever else it would mean in that<br class="">> context.<br class="">><br class="">> Fixed underlying types for enums are also permitted in Objective-C and<br class="">> under MS extensions, plus as a language extension in all other modes.<br class="">> The behavior in ObjC and MS extensions modes is unchanged (but the<br class="">> bit-field disambiguation is a bit better); remaining language modes<br class="">> follow the C++11 rules.<br class="">><br class="">> Fixes PR45726, PR39979, PR19810, PR44941, and most of PR24297, plus C++<br class="">> core issues 1514 and 1966.<br class=""><br class="">Hello from Chromium :-)<br class=""><br class="">We saw new errors from some code in a header that looked like this:<br class=""><br class=""> <span class=""> </span>// Adapted from NSPathUtilities.h and NSObjCRuntime.h.<br class=""> <span class=""> </span>typedef enum NSSearchPathDirectory : unsigned long NSSearchPathDirectory;<br class=""><br class="">For us we think the enum itself is enough, so we'll fix it by dropping<br class="">the typedef, but this raised the question of how your change affects<br class="">the Mac system headers. IIUC your change makes an exception for Obj-C,<br class="">but the headers can be used from regular C/C++ too. Do you think there<br class="">might be issues there?<br class=""></blockquote><div class=""><br class=""></div><div class="">The errors are DefaultError ExtWarns, so they will be suppressed by default in system headers. Even then:</div><div class=""> * In Objective-C (and Objective-C++), the prior rule is unchanged.</div><div class=""> * In (non-Objective) C++11 onwards, we now enforce the standard rules. (System headers should ideally be valid code, but if not, the system header exclusion will kick in. And the errors can be disabled by warning flag in user code written against old Clang.)</div><div class=""> * In any other language mode, system headers should really not be using this functionality, since it's a non-standard language extension, and not supported by (for example) GCC. (With the same provisos as in the prior bullet.)</div><div class=""><br class=""></div><div class="">We can make the C++ side of things more permissive if necessary, but I'm hopeful that we will be able to enforce the standard rules by default in this instance.</div><div class=""><br class=""></div><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-style: solid; border-left-color: rgb(204, 204, 204); padding-left: 1ex;">(See<span class=""> </span><a href="https://chromium-review.googlesource.com/c/chromium/src/+/2193673" rel="noreferrer" target="_blank" class="">https://chromium-review.googlesource.com/c/chromium/src/+/2193673</a><br class="">for the Chromium discussion.)<br class="">_______________________________________________<br class="">cfe-commits mailing list<br class=""><a href="mailto:cfe-commits@lists.llvm.org" target="_blank" class="">cfe-commits@lists.llvm.org</a><br class=""><a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" rel="noreferrer" target="_blank" class="">https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits</a><br class=""></blockquote></div></div><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; text-decoration: none; float: none; display: inline;" class="">_______________________________________________</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; text-decoration: none;" class=""><span style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; text-decoration: none; float: none; display: inline;" class="">cfe-commits mailing list</span><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; text-decoration: none;" class=""><a href="mailto:cfe-commits@lists.llvm.org" target="_blank" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;" class="">cfe-commits@lists.llvm.org</a><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; text-decoration: none;" class=""><a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" target="_blank" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;" class="">https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits</a></div></blockquote></div><br class=""></div></div></div>_______________________________________________<br class="">cfe-commits mailing list<br class=""><a href="mailto:cfe-commits@lists.llvm.org" target="_blank" class="">cfe-commits@lists.llvm.org</a><br class=""><a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" rel="noreferrer" target="_blank" class="">https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits</a></blockquote></div></div></div></blockquote></div><br class=""></div></body></html>