<div dir="ltr"><div>Also, how does this stage2 bot work?<br></div><div>I clearly see which revision is being compiled from the logs but it is not apparent to me what is the version of the compiler that is used to compiler it. Is it possible that due to some race condition a compiler before my fix is picked up and that is causing the failures? <br></div><div><br></div><div>Thanks,</div><div>Gabor<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, 9 Aug 2019 at 15:05, Gábor Horváth <<a href="mailto:xazax.hun@gmail.com">xazax.hun@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div>I tried both with libc++ instead of libstdc++ and modules but none of them reproduced in my local machine I would be glad if you could try it locally as well!</div><div><br></div><div>Thanks in advance,</div><div>Gabor<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, 9 Aug 2019 at 13:10, Jonas Devlieghere <<a href="mailto:jonas@devlieghere.com" target="_blank">jonas@devlieghere.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">The bot is a little special in that it has modules enabled. Maybe that<br>
explains it? Let me know if that doesn't work and I can try<br>
reproducing locally.<br>
<br>
On Fri, Aug 9, 2019 at 12:02 PM Gábor Horváth <<a href="mailto:xazax.hun@gmail.com" target="_blank">xazax.hun@gmail.com</a>> wrote:<br>
><br>
> I reverted but I cannot reproduce this locally on a linux box. Is there any way to get more information from the build bot (like preprocessed files?)?<br>
><br>
> On Fri, 9 Aug 2019 at 11:38, Gábor Horváth <<a href="mailto:xazax.hun@gmail.com" target="_blank">xazax.hun@gmail.com</a>> wrote:<br>
>><br>
>> Hmm, strange. Looking into it! If I do not manage to find the root cause in a few minutes I will revert!<br>
>><br>
>> On Fri, 9 Aug 2019 at 11:32, Jonas Devlieghere <<a href="mailto:jonas@devlieghere.com" target="_blank">jonas@devlieghere.com</a>> wrote:<br>
>>><br>
>>> I think this is causing a stage2 failure:<br>
>>> <a href="http://green.lab.llvm.org/green/view/LLDB/job/lldb-cmake/124/consoleFull#-95886206949ba4694-19c4-4d7e-bec5-911270d8a58c" rel="noreferrer" target="_blank">http://green.lab.llvm.org/green/view/LLDB/job/lldb-cmake/124/consoleFull#-95886206949ba4694-19c4-4d7e-bec5-911270d8a58c</a><br>
>>><br>
>>> On Fri, Aug 9, 2019 at 10:41 AM Gabor Horvath via cfe-commits<br>
>>> <<a href="mailto:cfe-commits@lists.llvm.org" target="_blank">cfe-commits@lists.llvm.org</a>> wrote:<br>
>>> ><br>
>>> > Author: xazax<br>
>>> > Date: Fri Aug  9 10:42:41 2019<br>
>>> > New Revision: 368459<br>
>>> ><br>
>>> > URL: <a href="http://llvm.org/viewvc/llvm-project?rev=368459&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project?rev=368459&view=rev</a><br>
>>> > Log:<br>
>>> > Fix a build bot failure and multiple warnings instances for range base for loops<br>
>>> ><br>
>>> > Modified:<br>
>>> >     cfe/trunk/lib/Sema/SemaInit.cpp<br>
>>> >     cfe/trunk/test/Sema/warn-lifetime-analysis-nocfg.cpp<br>
>>> ><br>
>>> > Modified: cfe/trunk/lib/Sema/SemaInit.cpp<br>
>>> > URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaInit.cpp?rev=368459&r1=368458&r2=368459&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaInit.cpp?rev=368459&r1=368458&r2=368459&view=diff</a><br>
>>> > ==============================================================================<br>
>>> > --- cfe/trunk/lib/Sema/SemaInit.cpp (original)<br>
>>> > +++ cfe/trunk/lib/Sema/SemaInit.cpp Fri Aug  9 10:42:41 2019<br>
>>> > @@ -6616,7 +6616,7 @@ static void handleGslAnnotatedTypes(Indi<br>
>>> >      return;<br>
>>> >    } else if (auto *OCE = dyn_cast<CXXOperatorCallExpr>(Call)) {<br>
>>> >      FunctionDecl *Callee = OCE->getDirectCallee();<br>
>>> > -    if (Callee->isCXXInstanceMember() &&<br>
>>> > +    if (Callee && Callee->isCXXInstanceMember() &&<br>
>>> >          shouldTrackImplicitObjectArg(cast<CXXMethodDecl>(Callee)))<br>
>>> >        VisitPointerArg(Callee, OCE->getArg(0));<br>
>>> >      return;<br>
>>> > @@ -7070,8 +7070,11 @@ static SourceRange nextPathEntryRange(co<br>
>>> >        // supporting lifetime extension.<br>
>>> >        break;<br>
>>> ><br>
>>> > -    case IndirectLocalPathEntry::DefaultInit:<br>
>>> >      case IndirectLocalPathEntry::VarInit:<br>
>>> > +      if (cast<VarDecl>(Path[I].D)->isImplicit())<br>
>>> > +        return SourceRange();<br>
>>> > +      LLVM_FALLTHROUGH;<br>
>>> > +    case IndirectLocalPathEntry::DefaultInit:<br>
>>> >        return Path[I].E->getSourceRange();<br>
>>> >      }<br>
>>> >    }<br>
>>> > @@ -7133,7 +7136,7 @@ void Sema::checkInitializerLifetime(cons<br>
>>> >          return false;<br>
>>> >        }<br>
>>> ><br>
>>> > -      if (IsGslPtrInitWithGslTempOwner) {<br>
>>> > +      if (IsGslPtrInitWithGslTempOwner && DiagLoc.isValid()) {<br>
>>> >          Diag(DiagLoc, diag::warn_dangling_lifetime_pointer) << DiagRange;<br>
>>> >          return false;<br>
>>> >        }<br>
>>> ><br>
>>> > Modified: cfe/trunk/test/Sema/warn-lifetime-analysis-nocfg.cpp<br>
>>> > URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/warn-lifetime-analysis-nocfg.cpp?rev=368459&r1=368458&r2=368459&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/warn-lifetime-analysis-nocfg.cpp?rev=368459&r1=368458&r2=368459&view=diff</a><br>
>>> > ==============================================================================<br>
>>> > --- cfe/trunk/test/Sema/warn-lifetime-analysis-nocfg.cpp (original)<br>
>>> > +++ cfe/trunk/test/Sema/warn-lifetime-analysis-nocfg.cpp Fri Aug  9 10:42:41 2019<br>
>>> > @@ -201,6 +201,13 @@ void danglingReferenceFromTempOwner() {<br>
>>> >  std::vector<int> getTempVec();<br>
>>> >  std::optional<std::vector<int>> getTempOptVec();<br>
>>> ><br>
>>> > +void testLoops() {<br>
>>> > +  for (auto i : getTempVec()) // ok<br>
>>> > +    ;<br>
>>> > +  for (auto i : *getTempOptVec()) // expected-warning {{object backing the pointer will be destroyed at the end of the full-expression}}<br>
>>> > +    ;<br>
>>> > +}<br>
>>> > +<br>
>>> >  int &usedToBeFalsePositive(std::vector<int> &v) {<br>
>>> >    std::vector<int>::iterator it = v.begin();<br>
>>> >    int& value = *it;<br>
>>> ><br>
>>> ><br>
>>> > _______________________________________________<br>
>>> > cfe-commits mailing list<br>
>>> > <a href="mailto:cfe-commits@lists.llvm.org" target="_blank">cfe-commits@lists.llvm.org</a><br>
>>> > <a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits</a><br>
</blockquote></div>
</blockquote></div>