summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/gen.rs3
-rw-r--r--tests/expectations/opaque_typedef.rs2
-rw-r--r--tests/headers/opaque_typedef.hpp10
3 files changed, 14 insertions, 1 deletions
diff --git a/src/gen.rs b/src/gen.rs
index 1e18557b..9873c24d 100644
--- a/src/gen.rs
+++ b/src/gen.rs
@@ -386,7 +386,8 @@ fn gen_global(mut ctx: &mut GenCtx,
GCompDecl(ci) => {
let c = ci.borrow().clone();
let name = comp_name(&ctx, c.kind, &c.name);
- if !c.args.is_empty() {
+ if !c.args.is_empty() &&
+ !c.args.iter().any(|a| a.name().map(|name| name.is_empty()).unwrap_or(true)) {
defs.extend(comp_to_rs(&mut ctx, &name, c).into_iter());
} else {
defs.push(opaque_to_rs(&mut ctx, &name, c.layout));
diff --git a/tests/expectations/opaque_typedef.rs b/tests/expectations/opaque_typedef.rs
index ebe5bedb..7dfa0ff9 100644
--- a/tests/expectations/opaque_typedef.rs
+++ b/tests/expectations/opaque_typedef.rs
@@ -10,6 +10,8 @@
pub struct Struct_RandomTemplate<T> {
pub _phantom0: ::std::marker::PhantomData<T>,
}
+pub enum Struct_Wat { }
+pub enum Struct_Wat3 { }
#[repr(C)]
pub struct ShouldBeOpaque;
pub type ShouldNotBeOpaque = Struct_RandomTemplate<::std::os::raw::c_int>;
diff --git a/tests/headers/opaque_typedef.hpp b/tests/headers/opaque_typedef.hpp
index a655fbcc..23bb363a 100644
--- a/tests/headers/opaque_typedef.hpp
+++ b/tests/headers/opaque_typedef.hpp
@@ -1,6 +1,16 @@
+// bindgen-flags: -std=c++11
template<typename T>
class RandomTemplate;
+template<int i>
+class Wat;
+
+template<int i>
+class Wat3;
+
+template<>
+class Wat3<3>;
+
/** <div rustbindgen opaque></div> */
typedef RandomTemplate<int> ShouldBeOpaque;