Skip to content

Commit

Permalink
Remove vtable method class prefix with --disable-name-namespacing
Browse files Browse the repository at this point in the history
Fix for #2438
  • Loading branch information
Supreeeme committed Mar 19, 2023
1 parent 9f2d2d3 commit 849e4af
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 2 deletions.
38 changes: 38 additions & 0 deletions bindgen-tests/tests/expectations/tests/vtable_no_namespacing.rs

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 4 additions & 0 deletions bindgen-tests/tests/headers/vtable_no_namespacing.hpp
@@ -0,0 +1,4 @@
// bindgen-flags: --disable-name-namespacing
struct Interface {
virtual void Method() = 0;
};
6 changes: 4 additions & 2 deletions bindgen/codegen/mod.rs
Expand Up @@ -1137,8 +1137,10 @@ impl<'a> CodeGenerator for Vtable<'a> {
_ => panic!("Function signature type mismatch"),
};

// FIXME: Is there a canonical name without the class prepended?
let function_name = function_item.canonical_name(ctx);
let mut function_name = function_item.canonical_name(ctx);
if ctx.options().disable_name_namespacing {
function_name = function_name.rsplit_once('_').unwrap().1.to_string();
}

// FIXME: Need to account for overloading with times_seen (separately from regular function path).
let function_name = ctx.rust_ident(function_name);
Expand Down

0 comments on commit 849e4af

Please sign in to comment.