[cfe-commits] [patch][3.2] Visibility cleanup and fixes
John McCall
rjmccall at apple.com
Wed Apr 18 21:56:35 PDT 2012
On Apr 18, 2012, at 8:35 PM, Chandler Carruth wrote:
> On Wed, Apr 18, 2012 at 8:09 PM, Rafael EspĂndola <rafael.espindola at gmail.com> wrote:
> I have a small concern that if a users writes an explicit
> attribute in a class member, he will find it surprising when it gets
> overwritten.
>
> I'm not sufficiently well versed in visibility rules to really chime in on what the right model is, but there is a simple solution to this problem at least: add a warning about explicit member visibility attributes that get overridden?
But all of the attributes here have an effect. If you instantiated
Rafael's template at a type with non-hidden visibility, e.g. int,
the member's attribute still takes precedence. The attribute is
only "overridden" in the specific case of instantiating the
template at a hidden argument. I'm not convinced this is
actually a problem that bears a warning, vs. something that
we should defer to some hypothetical "explain everything that's
happening with this symbol" IDE query.
John.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20120418/fc8c77f7/attachment.html>
More information about the cfe-commits
mailing list