<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Tue, Nov 3, 2015 at 4:37 PM, Aaron Ballman via cfe-commits <span dir="ltr"><<a href="mailto:cfe-commits@lists.llvm.org" target="_blank">cfe-commits@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5">On Tue, Nov 3, 2015 at 7:23 PM, Richard Smith <<a href="mailto:richard@metafoo.co.uk">richard@metafoo.co.uk</a>> wrote:<br>
> rsmith added inline comments.<br>
><br>
> ================<br>
> Comment at: include/clang/Basic/AttrDocs.td:1628<br>
> @@ +1627,3 @@<br>
> +The ``internal_linkage`` attribute changes the linkage type of the declaration to internal.<br>
> +This is similar to C-style ``static``, but can be used on classes and class methods<br>
> +This can be used to contain the ABI of a C++ library by excluding unwanted class methods from the export tables.<br>
> ----------------<br>
> Missing period at end of sentence.<br>
><br>
> ================<br>
> Comment at: include/clang/Basic/AttrDocs.td:1628<br>
> @@ +1627,3 @@<br>
> +The ``internal_linkage`` attribute changes the linkage type of the declaration to internal.<br>
> +This is similar to C-style ``static``, but can be used on classes and class methods<br>
> +This can be used to contain the ABI of a C++ library by excluding unwanted class methods from the export tables.<br>
> ----------------<br>
> rsmith wrote:<br>
>> Missing period at end of sentence.<br>
> Please also say what it means if the attribute is applied to a class.<br>
><br>
> ================<br>
> Comment at: lib/AST/Decl.cpp:635-641<br>
> @@ -634,2 +634,9 @@<br>
>    assert(!isa<FieldDecl>(D) && "Didn't expect a FieldDecl!");<br>
><br>
> +  for (const DeclContext *DC = D->getDeclContext();<br>
> +       !isa<TranslationUnitDecl>(DC); DC = DC->getParent()) {<br>
> +    const NamespaceDecl *ND = dyn_cast<NamespaceDecl>(DC);<br>
> +    if (ND && ND->getAttr<InternalLinkageAttr>())<br>
> +      return LinkageInfo::internal();<br>
> +  }<br>
> +<br>
> ----------------<br>
> Dead code?<br>
><br>
> ================<br>
> Comment at: lib/AST/Decl.cpp:1362-1367<br>
> @@ -1346,4 +1361,8 @@<br>
>      }<br>
> -    assert(!Old || Old->getCachedLinkage() == D->getCachedLinkage());<br>
> +    // Linkages may also differ if one of the declarations has<br>
> +    // InternalLinkageAttr.<br>
> +    assert(!Old || Old->getCachedLinkage() == D->getCachedLinkage() ||<br>
> +           (Old->hasAttr<InternalLinkageAttr>() !=<br>
> +            D->hasAttr<InternalLinkageAttr>()));<br>
>  #endif<br>
><br>
> ----------------<br>
> We should not introduce another case where the linkage of an entity can change after its first declaration. It seems reasonable to require this attribute to be on the first declaration of the function.<br>
><br>
> ================<br>
> Comment at: lib/Sema/SemaDeclAttr.cpp:3391<br>
> @@ +3390,3 @@<br>
> +                                  unsigned AttrSpellingListIndex) {<br>
> +  if (checkAttrMutualExclusion<InternalLinkageAttr>(*this, D, Range, Ident))<br>
> +    return nullptr;<br>
> ----------------<br>
> Aaron, could we move the mutual exclusion functionality to TableGen? (Separately from this patch, of course.) It looks like there are now 6 attributes that could use the "simple attribute" codepath if we did so.<br>
<br>
</div></div>Yes, I think that would be a good idea. Ideally, I would like the<br>
tablegen to look like:<br>
<br>
class Attr {<br>
  // ...<br>
  list<Attr> MutuallyExclusive = [];<br>
}<br>
<br>
def Hot {<br>
  // ...<br>
  let MutuallyExclusive = [Cold];<br>
}<br>
<br>
def Cold {<br>
  // ...<br>
  let MutuallyExclusive = [Hot];<br>
}<br>
<br>
I'll put this on my list of refactorings to do.<br></blockquote><div><br></div><div>It'd be nice if we could also diagnose inconsistencies in this (eg, Hot says it's exclusive with Cold and Cold doesn't agree).</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
~Aaron<br>
<div class="HOEnZb"><div class="h5"><br>
><br>
><br>
> Repository:<br>
>   rL LLVM<br>
><br>
> <a href="http://reviews.llvm.org/D13925" rel="noreferrer" target="_blank">http://reviews.llvm.org/D13925</a><br>
><br>
><br>
><br>
_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@lists.llvm.org">cfe-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits</a><br>
</div></div></blockquote></div><br></div></div>