<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Wed, May 4, 2016 at 3:34 PM, Stanislav Manilov <span dir="ltr"><<a href="mailto:stanislav.manilov@gmail.com" target="_blank">stanislav.manilov@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 dir="ltr">I've been looking at the generated IR (together with the IR language reference and the docs for the API), but I could figure out how to generate it myself.</div><span>
</span><p dir="ltr">But your suggestion to look at the clang source is a good idea. Thanks!<br></p></blockquote><div>Bonus tip: Once you know the IR you want, you can probably find/guess the instruction or other llvm value you're interested in. Set a breakpoint in the ctor of that type (eg: break llvm::StoreInst::StoreInst) & then look at the backtrace to see how/where it's built inside clang. </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><p dir="ltr">
</p><div class="HOEnZb"><div class="h5"><span>
</span><br><div class="gmail_quote"><div dir="ltr">On Wed, May 4, 2016, 23:12 David Blaikie <<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Wed, May 4, 2016 at 3:10 PM, Stanislav Manilov <span dir="ltr"><<a href="mailto:stanislav.manilov@gmail.com" target="_blank">stanislav.manilov@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><p dir="ltr">As in "look at the source of clang" or as in "look at the -S -emit-llvm" output? If you mean the former, then would that be easy for someone who hasn't seen the clang source before?</p></blockquote></div></div></div><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div>Generally the latter - then potentially set some breakpoints & look at the clang source if you're looking for the right APIs.<br><br>It's not as easy as the CppBackend (if the CppBackend were up to date) but not too bad, I don't think.</div></div></div></div><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div>
<br><div class="gmail_quote"><div dir="ltr">On Wed, May 4, 2016, 22:48 David Blaikie <<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">The usual advice I provide people is "see what Clang does with an equivalent C construct"</div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, May 4, 2016 at 12:18 PM, Stanislav Manilov <span dir="ltr"><<a href="mailto:stanislav.manilov@gmail.com" target="_blank">stanislav.manilov@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 dir="ltr">Hi,<br><br>There is another benefit to keeping the CppBackend: it's great for learning how to use the IR and the C++ API in particular, as can be seen from this SO Q&A: <a href="http://stackoverflow.com/questions/16656855/llvm-ir-string-initialization" target="_blank">http://stackoverflow.com/questions/16656855/llvm-ir-string-initialization</a><div><br></div><div>But I'll understand if it's considered too much of a burden to keep. I can send a patch for the part that I was trying to use, but there's probably a lot to fix for it to fully work.</div><div><br></div><div>Cheers,</div><div> - Stan</div></div><div><div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, May 4, 2016 at 4:21 PM, David Blaikie <span dir="ltr"><<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@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 dir="ltr">+1</div><div><div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, May 4, 2016 at 3:10 AM, Filipe Cabecinhas via llvm-dev <span dir="ltr"><<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@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">Hi,<br>
<span><br>
On Wed, May 4, 2016 at 9:35 AM, Ronan KERYELL via llvm-dev<br>
<<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
>>>>>> On Tue, 3 May 2016 16:36:01 -0400, Rafael Espíndola via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> said:<br>
><br>
>     Rafael> Care to send a patch deleting it? :-)<br>
><br>
> On the other hand these requests come back from time to time on the<br>
> mailing list and it is still used in many attics of various projects as<br>
> a de-facto internal representation to interface with other tools for<br>
> technical/marketing/political/... reasons.<br>
</span>Doesn't seem like it is, if it seems to be broken since some 2013 changes.<br>
It might be in use for projects using older llvm releases, of course.<br>
But those haven't updated their llvm library for a long time, so this<br>
wouldn't be their major problem.<br>
<span><br>
> So sending a patch to resurrect it in a more modern new life might be<br>
> also considered instead of many people crafting some half-working<br>
> ashamed kludges far from the sight... :-)<br>
</span>Not really. There's no reason to spend the effort just because "in the<br>
future someone might use it".<br>
If you're saying "I have some half-working things and CppBackend would<br>
be awesome for me", then I guess no one would object to you working on<br>
it, and people would actually help if you needed advice/patch review,<br>
etc.<br>
<br>
But if we have no one actively interested, and there has been no<br>
active development to the point where it's plain broken since a long<br>
time ago, then we probably want to start proposing its deletion.<br>
There's no point in having people who aren't interested in maintaining<br>
it do all this work if the backend can be so out of date and no one<br>
notices.<br>
If it's not usable now and almost no one complains about it being<br>
broken (outside the occasional "Is this working? No.", will those<br>
people notice if it's gone? :-)<br>
<br>
Thank you,<br>
<br>
  Filipe<br>
<div><div><br>
> --<br>
>   Ronan KERYELL<br>
>   Xilinx Research Labs, Dublin, Ireland<br>
> _______________________________________________<br>
> LLVM Developers mailing list<br>
> <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
> <a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</div></div></blockquote></div><br></div>
</div></div></blockquote></div><br></div>
</div></div></blockquote></div><br></div>
</blockquote></div>
</div></div></blockquote></div></div></div></blockquote></div>
</div></div></blockquote></div><br></div></div>