<div dir="ltr">"strong" was wrong/unnecessary, sorry.<br><br>*looks more closely*<br><br>Ah, totally my mistake - abi-breaking.h wasn't being built as a modular header, so it'd be included into two other modular headers, those two header modules would be imported together & the two definitions would conflict. But if it's actually built as its own module there's no duplication & it's fine (probably explains why the modules buildbots are fine).<br><br>Sorry for the noise! Carry on!<br><br>- Dave</div><br><div class="gmail_quote"><div dir="ltr">On Tue, Nov 28, 2017 at 9:31 PM Mehdi AMINI <<a href="mailto:joker.eph@gmail.com">joker.eph@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">How can a "weak" definition be a "strong" one!? ;)<div class="gmail_extra"><br></div><div class="gmail_extra">I think the reason for "weak" was to not duplicate it. A static would be duplicated in every translation unit that includes the header right? I don't know what it means in terms of extra number of relocation, etc.</div><div class="gmail_extra">Also the attribute used will prevent the linker from dead-stripping the symbol in case of static linking and/or when using LTO.</div></div><div dir="ltr"><div class="gmail_extra"><br></div><div class="gmail_extra">-- </div><div class="gmail_extra">Mehdi</div></div><div dir="ltr"><div class="gmail_extra"><br></div><div class="gmail_extra"><br><div class="gmail_quote">2017-11-28 14:35 GMT-08:00 David Blaikie <span dir="ltr"><<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">The abi-breaking.h seems to be incompatible with modules, owing to it having strong definitions in the header.<br><br>I'm wondering if I can make it compatible by changing the:<br><br>__attribute__((weak, visibility("hidden"))) variables to __attribute__((used)) static variables instead? It still seems to produce the desired link errors in my basic tests. Does that seem plausible to you?<br><br>(modules have a special case for static variables in headers to support things like the iostreams initializer)<br><br>Not sure why the modules buildbots don't see this but google's internal build system building with modules does... <br><br>- Dave</div>
</blockquote></div><br></div></div></blockquote></div>