本文整理匯總了Python中clang.cindex.CursorKind.CXX_METHOD屬性的典型用法代碼示例。如果您正苦於以下問題:Python CursorKind.CXX_METHOD屬性的具體用法?Python CursorKind.CXX_METHOD怎麽用?Python CursorKind.CXX_METHOD使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類clang.cindex.CursorKind
的用法示例。
在下文中一共展示了CursorKind.CXX_METHOD屬性的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: show_info
# 需要導入模塊: from clang.cindex import CursorKind [as 別名]
# 或者: from clang.cindex.CursorKind import CXX_METHOD [as 別名]
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)
示例2: parse_copenvrcontext
# 需要導入模塊: from clang.cindex import CursorKind [as 別名]
# 或者: from clang.cindex.CursorKind import CXX_METHOD [as 別名]
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_
示例3: _getMethodBodies
# 需要導入模塊: from clang.cindex import CursorKind [as 別名]
# 或者: from clang.cindex.CursorKind import CXX_METHOD [as 別名]
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
示例4: read_cursor
# 需要導入模塊: from clang.cindex import CursorKind [as 別名]
# 或者: from clang.cindex.CursorKind import CXX_METHOD [as 別名]
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 []
示例5: parse_ivrclass
# 需要導入模塊: from clang.cindex import CursorKind [as 別名]
# 或者: from clang.cindex.CursorKind import CXX_METHOD [as 別名]
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_
示例6: parse_namespace
# 需要導入模塊: from clang.cindex import CursorKind [as 別名]
# 或者: from clang.cindex.CursorKind import CXX_METHOD [as 別名]
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)
示例7: read_function
# 需要導入模塊: from clang.cindex import CursorKind [as 別名]
# 或者: from clang.cindex.CursorKind import CXX_METHOD [as 別名]
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]