<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Wed, May 20, 2015 at 2:54 PM, Aaron Ballman <span dir="ltr"><<a href="mailto:aaron@aaronballman.com" target="_blank">aaron@aaronballman.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">While refactoring some attribute parsing code, I noticed that we do<br>
not guard __declspec as being a Microsoft-specific extension that we<br>
support. This is consistent with the behavior we have for<br>
__attribute__. In both cases, the keyword is available everywhere, and<br>
specific attributes determine their target requirements. However, I<br>
wonder if that's the behavior we want.<br>
<br>
With __attribute__, it makes some degree of sense that we support it<br>
everywhere and own it as a core language extension. For instance, we<br>
allow users to add GNU-style attribute spellings that GCC does not<br>
support and no one takes issue.<br>
<br>
Do we want the same level of ownership over __declspec? If someone<br>
wants to add a new attribute with a __declspec spelling that is not<br>
supported by MSVC, will we allow it? I struggle to imagine us allowing<br>
that as it can cause future compatibility issues if Microsoft were to<br>
use the same attribute name with different semantics.</blockquote><div><br></div><div>I think we should be free to add stuff to __declspec if we don't think it is likely that MSVC would repurpose the same attribute for a different purpose. Microsoft seems to be aware that others build tools with command lines and attributes compatible with their tooling. For example, they reused ICC's /Qvec-report flag for MSVC 2012.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">For that reason,<br>
I think __declspec should be guarded by -fms-extensions, but I wanted<br>
to get community feedback before making such a change.<br>
<br>
Thanks!<br>
<span class=""><font color="#888888"><br>
~Aaron<br>
</font></span></blockquote></div><br></div></div>