Skip to content

Commit

Permalink
Generating VTT symbols for public virtual base classes
Browse files Browse the repository at this point in the history
  • Loading branch information
mattkae committed Apr 24, 2024
1 parent fbca7af commit 948f24a
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 3 deletions.
5 changes: 3 additions & 2 deletions src/server/symbols.map
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,10 @@ MIR_SERVER_INTERNAL_2.17 {
global:
extern "C++" {
VTT?for?mir::DefaultServerConfiguration;
VTT?for?mir::scene::ApplicationNotRespondingDetectorWrapper;
VTT?for?mir::DefaultServerStatusListener;
VTT?for?mir::shell::AbstractShell;
VTT?for?mir::shell::Shell;
VTT?for?mir::shell::ShellWrapper;
VTT?for?mir::shell::SystemCompositorWindowManager;
mir::BasicCallback::BasicCallback*;
mir::BasicCallback::lock*;
mir::BasicCallback::operator*;
Expand Down
27 changes: 26 additions & 1 deletion tools/symbols_map_generator/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,29 @@ def has_vtable(node: clang.cindex.Cursor):
return False


def derived_virtual_base_class(node: clang.cindex.Cursor):
# This method assumes that the node is a class/struct

result = False
for child in node.get_children():
if child.kind != clang.cindex.CursorKind.CXX_BASE_SPECIFIER:
continue

if clang.cindex.conf.lib.clang_isVirtualBase(child):
result = True
else:
class_or_struct_node = clang.cindex.conf.lib.clang_getCursorDefinition(child)
if class_or_struct_node is None:
continue

result = derived_virtual_base_class(class_or_struct_node)

if result:
break

return result


def is_function_inline(node: clang.cindex.CursorKind):
# This method assumes that the node is a FUNCTION_DECL.
# There is no explicit way to check if a function is inlined
Expand All @@ -125,7 +148,7 @@ def get_namespace_str(node: clang.cindex.Cursor) -> list[str]:
return get_namespace_str(node.semantic_parent) + [spelling]


def traverse_ast(node: clang.cindex.Cursor, filename: str, result: set[str]) -> set[str]:
def traverse_ast(node: clang.cindex.Cursor, filename: str, result: set[str]) -> set[str]:
# Ignore private and protected variables
if (node.access_specifier == clang.cindex.AccessSpecifier.PRIVATE):
return result
Expand All @@ -150,6 +173,8 @@ def traverse_ast(node: clang.cindex.Cursor, filename: str, result: set[str]) ->
or node.kind == clang.cindex.CursorKind.STRUCT_DECL):
if has_vtable(node):
result.add(f"vtable?for?{namespace_str};")
if derived_virtual_base_class(node):
result.add(f"VTT?for?{namespace_str};")
result.add(f"typeinfo?for?{namespace_str};")
else:
def add_internal(s: str):
Expand Down

0 comments on commit 948f24a

Please sign in to comment.