<div dir="ltr"><div>Thanks Richard, I have closed the bug.<br></div>Thanks to Suyog Sarda for working with me on this!<br></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Jan 31, 2014 at 4:36 AM, Richard Smith <span dir="ltr"><<a href="mailto:metafoo@gmail.com" target="_blank">metafoo@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im"><div>On Thu Jan 30 2014 at 2:07:48 PM, rahul <<a href="mailto:1989.rahuljain@gmail.com" target="_blank">1989.rahuljain@gmail.com</a>> wrote:</div>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div dir="auto"><div><br>Thanks Richard! </div><div><br></div><div>Yes, please if you could commit it for me.</div><div>I will go ahead and close the bug once the </div><div>fix is committed!</div></div></blockquote><div>
<br></div></div><div>Thanks, committed as r200496.</div><div class="HOEnZb"><div class="h5"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="auto">
<div>Thanks,<div>Rahul</div><div><br></div>
</div></div><div dir="auto"><div><br>On 31-Jan-2014, at 3:26 am, Richard Smith <<a href="mailto:metafoo@gmail.com" target="_blank">metafoo@gmail.com</a>> wrote:<br><br></div><blockquote type="cite"><div>LGTM, thanks. The new test coverage looks great. Do you need someone to commit this for you?<br>
<br><div>On Thu Jan 30 2014 at 1:48:13 PM, Rahul Jain <<a href="mailto:1989.rahuljain@gmail.com" target="_blank">1989.rahuljain@gmail.com</a>> wrote:</div>
<blockquote style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><br><div>Hi Richard,</div><div><br></div><div>Thanks for the inputs.</div><div><br></div><div>I have updated the patch as per your review comments.</div>
<div>Please if you could help by reviewing the same!</div>
<div><br></div><div><br></div><div><div>Index: lib/Sema/SemaDeclCXX.cpp</div><div>===================================================================</div><div>--- lib/Sema/SemaDeclCXX.cpp<span style="white-space:pre-wrap"> </span>(revision 200475)</div>
<div>+++ lib/Sema/SemaDeclCXX.cpp<span style="white-space:pre-wrap"> </span>(working copy)</div><div>@@ -10909,11 +10909,10 @@</div><div> // increment operator ++ for objects of that type.</div><div> if ((Op == OO_PlusPlus || Op == OO_MinusMinus) && NumParams == 2) {</div>
<div> ParmVarDecl *LastParam = FnDecl->getParamDecl(FnDecl->getNumParams() - 1);</div><div>- bool ParamIsInt = false;</div><div>- if (const BuiltinType *BT = LastParam->getType()->getAs<BuiltinType>())</div>
<div>- ParamIsInt = BT->getKind() == BuiltinType::Int;</div><div>+ QualType ParamType = LastParam->getType();</div><div> </div><div>- if (!ParamIsInt)</div><div>+ if (!ParamType->isSpecificBuiltinType(BuiltinType::Int) &&</div>
<div>+ !ParamType->isDependentType())</div></div></div><div dir="ltr"><div><div> return Diag(LastParam->getLocation(),</div><div> diag::err_operator_overload_post_incdec_must_be_int)</div>
<div> << LastParam->getType() << (Op == OO_MinusMinus);</div>
<div>Index: test/SemaCXX/overloaded-operator.cpp</div><div>===================================================================</div></div></div><div dir="ltr"><div><div>--- test/SemaCXX/overloaded-operator.cpp<span style="white-space:pre-wrap"> </span>(revision 200475)</div>
<div>+++ test/SemaCXX/overloaded-operator.cpp<span style="white-space:pre-wrap"> </span>(working copy)</div><div>@@ -452,3 +452,58 @@</div></div></div><div dir="ltr"><div><div> Result = 1; // expected-error {{no viable overloaded '='}} // expected-note {{type 'PointerUnion<int *, float *>' is incomplete}}</div>
<div> }</div><div> }</div><div>+</div><div>+namespace PR14995 {</div></div></div><div dir="ltr"><div><div>+ struct B {};</div></div></div><div dir="ltr"><div><div>+ template<typename ...T> void operator++(B, T...) {}</div>
<div>+</div><div>+ void f() {</div><div>+ B b;</div>
<div>+ b++; // ok</div><div>+ ++b; // ok</div><div>+ }</div><div>+</div></div></div><div dir="ltr"><div><div>+ template<typename... T></div><div>+ struct C {</div><div>+ void operator-- (T...) {}</div>
<div>+ };</div><div>+</div><div>
+ void g() {</div><div>+ C<int> postfix;</div><div>+ C<> prefix;</div><div>+ postfix--; // ok</div><div>+ --prefix; // ok</div><div>+ }</div><div>+</div><div>+ struct D {};</div><div>+ template<typename T> void operator++(D, T) {}</div>
<div>+</div><div>+ void h() {</div><div>+ D d;</div><div>+ d++; // ok</div><div>+ ++d; // expected-error{{cannot increment value of type 'PR14995::D'}}</div><div>+ }</div><div>+</div><div>+ template<typename...T> struct E {</div>
<div>+ void operator++(T...) {} // expected-error{{parameter of overloaded post-increment operator must have type 'int' (not 'char')}}</div><div>+ };</div><div>+</div><div>+ E<char> e; // expected-note {{in instantiation of template class 'PR14995::E<char>' requested here}}</div>
<div>+ </div><div>+ struct F {</div><div>+ template<typename... T></div><div>+ int operator++ (T...) {}</div><div>+ };</div><div>+</div><div>+ int k1 = F().operator++(0, 0);</div><div>+ int k2 = F().operator++('0');</div>
<div>+ // expected-error@-5 {{overloaded 'operator++' must be a unary or binary operator}}</div><div>+ // expected-note@-3 {{in instantiation of function template specialization 'PR14995::F::operator++<int, int>' requested here}}</div>
<div>+ // expected-error@-4 {{no matching member function for call to 'operator++'}}</div><div>+ // expected-note@-8 {{candidate template ignored: substitution failure}}</div><div>+ // expected-error@-9 {{parameter of overloaded post-increment operator must have type 'int' (not 'char')}}</div>
<div>+ // expected-note@-6 {{in instantiation of function template specialization 'PR14995::F::operator++<char>' requested here}}</div><div>+ // expected-error@-7 {{no matching member function for call to 'operator++'}}</div>
<div>+ // expected-note@-12 {{candidate template ignored: substitution failure}}</div><div>+} // namespace PR14995</div><div><br></div></div><div><br></div><div>Thanks,</div><div>Rahul</div></div><div>
<br><br><div>On Fri, Jan 31, 2014 at 12:35 AM, Richard Smith <span dir="ltr"><<a href="mailto:metafoo@gmail.com" target="_blank">metafoo@gmail.com</a>></span> wrote:<br><blockquote style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Please do add those other testcases. Please also add some tests which fail when we come to instantiate the operator++, such as:<br><br>template<typename...T> struct A { void operator++(T...); };<div>A<char> a;<br>
</div><div><br></div><div>... and ...</div><div><br></div><div>struct A { template<typename...T> int operator++(T...); };</div><div>int k1 = A().operator++(0, 0);</div><div>int k2 = A().operator++('0');</div>
<div><br></div><div><br></div><div>Also:</div><div><div><br></div><div><div>- if (!ParamIsInt)</div><div>+ bool ParamIsDependent = false;</div><div>+ if (LastParam->getType()->isDependentType())</div>
<div>+ ParamIsDependent = true;</div>
<div>+</div><div>+ if (!ParamIsInt && !ParamIsDependent)</div></div><div><br></div></div><div>This seems overly verbose. Please tidy this up; something like:</div><div><br></div><div> QualType ParamType = LastParam->getType();</div>
<div> if (!ParamType->isSpecificBuiltinType(BuiltinType::Int) && !ParamType->isDependentType())</div><div><br></div><div>... would be better.</div><div><div><br><div>On Thu Jan 30 2014 at 10:07:33 AM, rahul <<a href="mailto:1989.rahuljain@gmail.com" target="_blank">1989.rahuljain@gmail.com</a>> wrote:</div>
<blockquote style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="auto"><div>Hi Arthur,</div><div><br></div><div>Yes it does fix the other two examples as well. I did check them too while working out the fix. </div>
<div><br></div><div>I will add those too once I get a green signal for the fix :)<br><br>Thanks,<div>Rahul</div><div><br></div></div></div><div dir="auto"><div><br>On 30-Jan-2014, at 11:29 pm, "Arthur O'Dwyer" <<a href="mailto:arthur.j.odwyer@gmail.com" target="_blank">arthur.j.odwyer@gmail.com</a>> wrote:<br>
<br></div></div><blockquote type="cite"><div><div dir="auto"><div dir="ltr">Hi Rahul,<div><br></div><div> Does your patch fix the other two examples given in PR14995? Perhaps they should also be added as regression tests.</div>
<div>(Just from eyeballing the code, I think your patch *does* fix them, including my example where the T is dependent on a class template instead of on a function template; but it might be nice to test explicitly.)</div>
<div><br></div><div>LGTM.</div><div><br></div><div>–Arthur</div><div><br></div></div></div></div></blockquote><div><div><blockquote type="cite"><div><div dir="auto">On Thu, Jan 30, 2014 at 6:55 AM, Rahul Jain <span dir="ltr"><<a href="mailto:rahul1.jain@samsung.com" target="_blank">rahul1.jain@samsung.com</a>></span> wrote:<br>
</div></div></blockquote></div></div><blockquote style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div><div><blockquote type="cite"><div><div dir="auto">
<p> </p>
<p>Hi,</p>
<p>This patch fixes PR14995 - <span><span>Too eagerly rejects operator function templates.</span></span></p>
<p><span><span>Please help review the same.</span></span></p>
<p><span><span></span></span> </p>
<p><span><span>Index: lib/Sema/SemaDeclCXX.cpp<br>===================================================================<br>--- lib/Sema/SemaDeclCXX.cpp (revision 200465)<br>+++ lib/Sema/SemaDeclCXX.cpp (working copy)<br>@@ -10913,7 +10913,11 @@<br>
if (const BuiltinType *BT = LastParam->getType()->getAs<BuiltinType>())<br> ParamIsInt = BT->getKind() == BuiltinType::Int;<br> <br>- if (!ParamIsInt)<br>+ bool ParamIsDependent = false;<br>
+ if (LastParam->getType()->isDependentType())<br>+ ParamIsDependent = true;<br>+<br>+ if (!ParamIsInt && !ParamIsDependent)<br> return Diag(LastParam->getLocation(),<br> diag::err_operator_overload_post_incdec_must_be_int)<br>
<< LastParam->getType() << (Op == OO_MinusMinus);<br>Index: test/SemaCXX/overloaded-operator.cpp<br>===================================================================<br>--- test/SemaCXX/overloaded-operator.cpp (revision 200465)<br>
+++ test/SemaCXX/overloaded-operator.cpp (working copy)<br>@@ -452,3 +452,16 @@<br> Result = 1; // expected-error {{no viable overloaded '='}} // expected-note {{type 'PointerUnion<int *, float *>' is incomplete}}<br>
}<br> }<br>+<br>+namespace PR14995 {<br>+<br>+ struct B {};<br>+ template<typename ...T> void operator++(B, T...) {}<br>+<br>+ void f() {<br>+ B b;<br>+ b++; // ok<br>+ ++b; // ok<br>+ }<br>+}<br>
+</span></span></p>
<p><span><span></span></span> </p>
<p><span><span></span></span> </p>
<p><span><span>Thanks,</span></span></p>
<p><span><span>Rahul</span></span></p>
<p> </p>
</div></div></blockquote></div></div></div></blockquote><blockquote style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div><div><blockquote type="cite"><div><div dir="auto"><table>
<tbody>
<tr>
<td>
<p><201401302024474_BGFC2LL5.gif></p></td></tr></tbody></table></div></div></blockquote></div></div></div></blockquote><blockquote style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div><div>
<blockquote type="cite"><div><img src="http://ext.samsung.net/mailcheck/SeenTimeChecker?do=d39c7ebe3c5c4be3b749e4adb16ef39adfe1b2c7effbe582e56225dd835e375f5f887f84397989de4b5562a776ba3bf30029dc535ebebcd3326bbdfb2ea96a2fcf878f9a26ce15a0" border="0" height="0" width="0"><br>
_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
<br></div></blockquote></div></div></div></blockquote><blockquote style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div><div><blockquote type="cite"><div><span>_______________________________________________</span><br>
<span>cfe-commits mailing list</span><br><span><a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a></span><br><span><a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a></span><br>
</div></blockquote></div></div></div></blockquote></blockquote>
</div></div></blockquote></div><br></div>
</blockquote>
</div></blockquote></div></blockquote>
</div></div></blockquote></div><br></div>