<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=us-ascii"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=EN-US link="#0563C1" vlink="#954F72"><div class=WordSection1><p class=MsoNormal>Hello,<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I’m using the Python libclang bindings for an experimental pybind11 binding generator for a large C++ library. All is working pretty well except template specializations and I’m wondering if there is a better way. When a type is defined from a template (e.g., typedef TemplateA<TypeA> TypeB), the cursor is a TYPEDEF_DECL and does not have any children except the template reference and the parameters. When I get the underlying/canonical type (TemplateA<TypeA>) it is recognized as a CLASS_DECL but it doesn’t have any children (no access to constructors, methods, etc.). The only way I am currently able to get this information is using “clang_getSpecializedCursorTemplate” which ultimately returns the class template cursor with all its children, but the template parameters are used instead of the specialized type (i.e., “TheItemType” instead of TypeA in this example). I’m generating the binding code using the raw class template then doing a string find/replace of the template parameters with the actual types. That isn’t too bad but has gotten pretty challenging if the class template itself references other templates and on and on.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>What I’d really love is a way to get the template specialization to essentially behave the same as a regular class declaration. That is, the cursor for either the typedef or the underlying/canonical type (which already seems to be recognized as a class declaration) to give access to the children of the class template but with all the template parameters already in place.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Is this possible or is there a better way? I’ve looked at the “clang_getSpecializedCursorTemplate” source in /tools/libclang/CIndexCXX.cpp and thought maybe I can cast the typedef declaration to the CXXRecordDecl and then return that as a cursor?<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thanks for the support.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Regards,<o:p></o:p></p><p class=MsoNormal>Trevor<o:p></o:p></p></div></body></html>