<div dir="ltr">On 9 July 2016 at 16:27, Jonathan Coe via cfe-dev <span dir="ltr"><<a href="mailto:cfe-dev@lists.llvm.org" target="_blank">cfe-dev@lists.llvm.org</a>></span> wrote:<br><div class="gmail_extra"><div class="gmail_quote"><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"><br><div class="gmail_extra"><br><div class="gmail_quote"><span class="">On 9 July 2016 at 16:13, Stephen Kelly via cfe-dev <span dir="ltr"><<a href="mailto:cfe-dev@lists.llvm.org" target="_blank">cfe-dev@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span>Jonathan Müller via cfe-dev wrote:<br>
<br>
> On 08.07.2016 22:38, David Come wrote:<br>
>> Just go for the C++ API : libtooling<br>
>><br>
>> You will have all you need.<br>
<br>
</span>You will not have compatibility between versions.<br>
<span><br>
> So you're basically saying: the state of libclang is intentional, use<br>
> something else?<br>
<br>
</span>Jonathan, I have the same questions as you. I also have not encountered an<br>
authoritative answer.<br>
<br>
You might encounter the same problem I did if you want to determine the<br>
default values of method parameters:<br>
<br>
 <a href="http://thread.gmane.org/gmane.comp.compilers.clang.devel/48738" rel="noreferrer" target="_blank">http://thread.gmane.org/gmane.comp.compilers.clang.devel/48738</a><br>
<br>
Our solution is the same - try to parse the text ourselves because libclang<br>
and the python bindings do not expose it.<br>
<br></blockquote><div><br></div></span><div>I've written small extensions to libclang and to the python bindings to get a code generator I wrote working. If there is a small number of missing features maybe you could do the same?</div></div></div></div></blockquote><div><br></div><div>When I was writing by own libclang python bindings (<a href="https://github.com/rhdunn/libclangpy">https://github.com/rhdunn/libclangpy</a>) I had to write custom logic on top of the direct bindings to fix bugs in libclang (e.g. CursorKind_LinkageSpec is not mapped to the API, so `extern "C" ...` does not work) and some support for the newer APIs on older versions of libclang.<br><br>I also wrote my own tests for the binding to make sure the APIs worked consistently on the target and later versions of libclang.<br><br></div><div>My verdict was that it was a second class citizen to the unstable C++ API.<br></div><div><br></div><div>Thanks,<br></div><div>Reece<br></div><div><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 class="gmail_extra"><div class="gmail_quote"><div> </div><span class=""><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Hopefully there is a more authoritative answer about the state of libclang.<br>
<br>
Thanks,<br>
<br>
Steve.<br>
<div><div><br>
<br>
_______________________________________________<br>
cfe-dev mailing list<br>
<a href="mailto:cfe-dev@lists.llvm.org" target="_blank">cfe-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev</a><br>
</div></div></blockquote></span></div><br></div></div>
<br>_______________________________________________<br>
cfe-dev mailing list<br>
<a href="mailto:cfe-dev@lists.llvm.org">cfe-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev</a><br>
<br></blockquote></div><br></div></div>