Python clang.cindex.CursorKind.CXX_METHOD Examples
The following are 7
code examples of clang.cindex.CursorKind.CXX_METHOD().
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example.
You may also want to check out all available functions/classes of the module
clang.cindex.CursorKind
, or try the search function
.
Example #1
Source File: clang-callgraph.py From clang-callgraph with Apache License 2.0 | 6 votes |
def show_info(node, xfiles, xprefs, cur_fun=None): if node.kind == CursorKind.FUNCTION_TEMPLATE: if not is_excluded(node, xfiles, xprefs): cur_fun = node FULLNAMES[fully_qualified(cur_fun)].add( fully_qualified_pretty(cur_fun)) if node.kind == CursorKind.CXX_METHOD or \ node.kind == CursorKind.FUNCTION_DECL: if not is_excluded(node, xfiles, xprefs): cur_fun = node FULLNAMES[fully_qualified(cur_fun)].add( fully_qualified_pretty(cur_fun)) if node.kind == CursorKind.CALL_EXPR: if node.referenced and not is_excluded(node.referenced, xfiles, xprefs): CALLGRAPH[fully_qualified_pretty(cur_fun)].append(node.referenced) for c in node.get_children(): show_info(c, xfiles, xprefs, cur_fun)
Example #2
Source File: parser.py From pyopenvr with BSD 3-Clause "New" or "Revised" License | 6 votes |
def parse_copenvrcontext(self, cursor): name = cursor.type.spelling class_ = model.COpenVRContext(name=name, docstring=clean_comment(cursor)) for child in cursor.get_children(): if child.kind == CursorKind.CXX_ACCESS_SPEC_DECL: continue # no such thing in python elif child.kind == CursorKind.CONSTRUCTOR: continue # I will translate this manually elif child.kind == CursorKind.CXX_METHOD: if child.spelling == 'Clear': continue # I will translate this manually elif child.spelling == 'CheckClear': continue # I will translate this manually elif child.spelling.startswith('VR'): class_.add_vr_method_name(child.spelling) else: self.report_unparsed(child) elif child.kind == CursorKind.FIELD_DECL: if child.spelling.startswith('m_pVR'): class_.add_vr_member_name(child.spelling) else: self.report_unparsed(child) else: self.report_unparsed(child) return class_
Example #3
Source File: stepping.py From gdb_python_api with MIT License | 5 votes |
def _getMethodBodies(node): methods = [] for m in node.get_children(): if m.kind is CursorKind.CXX_METHOD: body = next(m.get_children()) if body.kind is CursorKind.COMPOUND_STMT: methods.append(body) return methods # set breakpoints on downstream
Example #4
Source File: libclang_parser.py From AutoWIG with Apache License 2.0 | 5 votes |
def read_cursor(asg, cursor, scope): if cursor.kind is CursorKind.UNEXPOSED_DECL: if cursor.spelling == '': children = [] for child in cursor.get_children(): children.extend(read_cursor(asg, child, scope)) return children else: warnings.warn('Named unexposed cursor not read') return [] elif cursor.kind is CursorKind.TYPEDEF_DECL: return read_typedef(asg, cursor, scope) elif cursor.kind in [CursorKind.VAR_DECL, CursorKind.PARM_DECL]: return read_variable(asg, cursor, scope) elif cursor.kind in [CursorKind.FUNCTION_DECL, CursorKind.CXX_METHOD, CursorKind.DESTRUCTOR, CursorKind.CONSTRUCTOR]: return read_function(asg, cursor, scope) elif cursor.kind is CursorKind.FIELD_DECL: return read_field(asg, cursor, scope) elif cursor.kind in [CursorKind.ENUM_DECL, CursorKind.STRUCT_DECL, CursorKind.UNION_DECL, CursorKind.CLASS_DECL]: return read_tag(asg, cursor, scope) elif cursor.kind is CursorKind.NAMESPACE: return read_namespace(asg, cursor, scope) elif cursor.kind in [CursorKind.NAMESPACE_ALIAS, CursorKind.FUNCTION_TEMPLATE, CursorKind.USING_DECLARATION, CursorKind.USING_DIRECTIVE, CursorKind.UNEXPOSED_ATTR, CursorKind.CLASS_TEMPLATE, CursorKind.CLASS_TEMPLATE_PARTIAL_SPECIALIZATION, CursorKind.CXX_ACCESS_SPEC_DECL, CursorKind.CONVERSION_FUNCTION]: return [] else: warnings.warn('Undefined behaviour for \'' + str(cursor.kind) + '\' cursor') return []
Example #5
Source File: parser.py From pyopenvr with BSD 3-Clause "New" or "Revised" License | 5 votes |
def parse_ivrclass(self, cursor): name = cursor.type.spelling class_ = model.IVRClass(name=name, docstring=clean_comment(cursor)) for child in cursor.get_children(): if child.kind == CursorKind.CXX_METHOD: method = self.parse_method(child) class_.add_method(method) elif child.kind == CursorKind.CXX_ACCESS_SPEC_DECL: continue # no such thing in python elif child.kind == CursorKind.FIELD_DECL: print(f'*** WARNING *** skipping class member {cursor.spelling}::{child.spelling}') continue else: self.report_unparsed(child) return class_
Example #6
Source File: parser.py From pyopenvr with BSD 3-Clause "New" or "Revised" License | 5 votes |
def parse_namespace(self, cursor): assert str(cursor.spelling) == 'vr' for child in cursor.get_children(): if child.kind == CursorKind.VAR_DECL: self.parse_var_decl(child) elif child.kind == CursorKind.TYPEDEF_DECL: self.parse_typedef(child) elif child.kind == CursorKind.STRUCT_DECL: self.items.append(self.parse_struct(child)) elif child.kind == CursorKind.UNION_DECL: union = self.parse_struct(child) union.base = 'Union' self.items.append(union) elif child.kind == CursorKind.ENUM_DECL: self.parse_enum(child) elif child.kind == CursorKind.FUNCTION_DECL: self.parse_function(child) elif child.kind == CursorKind.UNEXPOSED_DECL: self.parse_unexposed_decl(child) elif child.kind == CursorKind.CLASS_DECL: if child.spelling.startswith('IVR'): self.items.append(self.parse_ivrclass(child)) elif child.spelling.startswith('COpenVRContext'): self.items.append(self.parse_copenvrcontext(child)) else: print(f'*** WARNING *** skipping class {child.spelling}(...)') elif child.kind == CursorKind.CXX_METHOD: cn = child.semantic_parent.spelling mn = child.spelling if cn == 'COpenVRContext' and mn == 'Clear': pass # OK - we manually wrap this one else: print(f'*** WARNING *** skipping class method implementation {child.spelling}(...)') else: self.report_unparsed(child)
Example #7
Source File: libclang_parser.py From AutoWIG with Apache License 2.0 | 4 votes |
def read_function(asg, cursor, scope): spelling = scope if spelling.startswith('class '): spelling = spelling[6:] elif spelling.startswith('union '): spelling = spelling[6:] elif spelling.startswith('struct '): spelling = spelling[7:] if not scope.endswith('::'): spelling = spelling + "::" + cursor.spelling else: spelling = spelling + cursor.spelling if cursor.kind in [CursorKind.DESTRUCTOR, CursorKind.CXX_METHOD, CursorKind.CONSTRUCTOR] and cursor.lexical_parent.kind is CursorKind.NAMESPACE: return [] else: if cursor.kind is not CursorKind.DESTRUCTOR: spelling = spelling + '::' + str(uuid.uuid4()) if cursor.kind is CursorKind.FUNCTION_DECL: asg._nodes[spelling] = dict(_proxy=FunctionProxy, _comment="") if cursor.location is not None: filename = str(Path(str(cursor.location.file)).abspath()) asg.add_file(filename, proxy=HeaderProxy, _language=asg._language) asg._nodes[spelling]['_header'] = filename elif cursor.kind is CursorKind.CXX_METHOD: asg._nodes[spelling] = dict(_proxy=MethodProxy, _is_static=cursor.is_static_method(), _is_volatile=False, _is_virtual=True, _is_const=cursor.is_const_method(), _is_pure=True, _comment="") elif cursor.kind is CursorKind.CONSTRUCTOR: asg._nodes[spelling] = dict(_proxy=ConstructorProxy, _is_virtual=False, #TODO _comment="") else: asg._nodes[spelling] = dict(_proxy=DestructorProxy, is_virtual=True, _comment="") asg._parameter_edges[spelling] = [] asg._syntax_edges[scope].append(spelling) try: with warnings.catch_warnings(): warnings.simplefilter("error") if cursor.kind in [CursorKind.FUNCTION_DECL, CursorKind.CXX_METHOD]: target, specifiers = read_qualified_type(asg, cursor.result_type) asg._type_edges[spelling] = dict(target=target, qualifiers=specifiers) for child in [child for child in cursor.get_children() if child.kind is CursorKind.PARM_DECL]: target, specifiers = read_qualified_type(asg, child.type) asg._parameter_edges[spelling].append(dict(name = child.spelling, target=target, qualifiers=specifiers)) except Warning as warning: asg._syntax_edges[scope].remove(spelling) asg._type_edges.pop(spelling, None) asg._parameter_edges.pop(spelling, None) asg._nodes.pop(spelling) warnings.warn(str(warning), warning.__class__) return [] else: read_access(asg, cursor.access_specifier, spelling) return [spelling]