Fixed in r155293.<br><br><div class="gmail_quote">On Fri, Apr 20, 2012 at 1:25 PM, Richard Smith <span dir="ltr"><<a href="mailto:richard@metafoo.co.uk">richard@metafoo.co.uk</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
This change causes a regression in C++11 mode:<div><br></div><div><div>struct A {</div><div>  virtual ~A();</div><div><br></div><div>  struct Inner {</div><div>    ~Inner() throw();</div><div>  };</div><div>  Inner inner;</div>

<div>};</div><div><br></div><div>We don't parse A::Inner's exception specification until after we call ActOnFields for A and try to compute A::~A's exception specification. Consequently, since A::~A calls Inner::~Inner, A::~A's exception specification is computed as EST_Delayed, and never fixed. That causes a rejects-valid for code like this:</div>

<div><br></div><div>struct B {</div><div>  virtual ~B() {}</div><div>};</div><div><br></div><div>struct C : B {</div><div>  virtual ~C() {}</div><div>  A a;</div><div>};</div><div><br></div><div>Here, we assert when checking that C's exception specification is no looser than B's, because we can't compute C's exception spec.</div>
<div><div class="h5">
<br><div class="gmail_quote">On Mon, Apr 16, 2012 at 5:24 PM, Douglas Gregor <span dir="ltr"><<a href="mailto:dgregor@apple.com" target="_blank">dgregor@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">

<div style="word-wrap:break-word"><div><div><br><div><div>On Apr 16, 2012, at 12:44 PM, Richard Smith <<a href="mailto:richard@metafoo.co.uk" target="_blank">richard@metafoo.co.uk</a>> wrote:</div><br><blockquote type="cite">

<div class="gmail_quote">On Mon, Apr 16, 2012 at 11:27 AM, Douglas Gregor <span dir="ltr"><<a href="mailto:dgregor@apple.com" target="_blank">dgregor@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">


Author: dgregor<br>
Date: Mon Apr 16 13:27:27 2012<br>
New Revision: 154844<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=154844&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=154844&view=rev</a><br>
Log:<br>
Implement the last part of C++ [class.mem]p2, delaying the parsing of<br>
exception specifications on member functions until after the closing<br>
'}' for the containing class. This allows, for example, a member<br>
function to throw an instance of its own class. Fixes PR12564 and a<br>
fairly embarassing oversight in our C++98/03 support.<br></blockquote><div><br></div><div>This feature was removed from the language in DR1308 (which was voted into the WP at Kona).</div></div>
</blockquote></div><br></div></div><div>Richard and I have discussed this, and we think that removing this feature from the language is in error. We'll continue to implement the pre-DR1308 wording and bring the issue up for discussion again at the new committee meeting.</div>

<div><br></div><div><span style="white-space:pre-wrap"> </span>- Doug</div></div>
</blockquote></div><br></div></div></div>
</blockquote></div><br>