summaryrefslogtreecommitdiff
path: root/tests/headers/namespace.hpp
diff options
context:
space:
mode:
authorbors-servo <lbergstrom+bors@mozilla.com>2017-01-23 01:24:08 -0800
committerGitHub <noreply@github.com>2017-01-23 01:24:08 -0800
commitab6117c6b486cfcbf65adf8702dbc8472b4eb8c0 (patch)
treea57c9fab0e4c5498247465cca69f9e0b0e3cad24 /tests/headers/namespace.hpp
parent7373a4258f652c23e5fe00ad14740393caa40082 (diff)
parentaad93a81bb2ceeeeffc94c856a6d0d37c5ac6aec (diff)
Auto merge of #414 - emilio:crates-io, r=fitzgen,Yamakaky
Reorganize the crate and rename to bindgen. Fixes #398 Fixes #21 r? @fitzgen
Diffstat (limited to 'tests/headers/namespace.hpp')
-rw-r--r--tests/headers/namespace.hpp47
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/headers/namespace.hpp b/tests/headers/namespace.hpp
new file mode 100644
index 00000000..65788539
--- /dev/null
+++ b/tests/headers/namespace.hpp
@@ -0,0 +1,47 @@
+// bindgen-flags: --enable-cxx-namespaces
+
+void top_level();
+
+namespace whatever {
+ typedef int whatever_int_t;
+
+ void in_whatever();
+}
+
+namespace {
+ namespace empty {}
+
+ void foo();
+ struct A {
+ whatever::whatever_int_t b;
+ public:
+ int lets_hope_this_works();
+ };
+}
+
+template<typename T>
+class C: public A {
+ T m_c;
+ T* m_c_ptr;
+ T m_c_arr[10];
+};
+
+
+template<>
+class C<int>;
+
+
+namespace w {
+ typedef unsigned int whatever_int_t;
+
+ template<typename T>
+ class D {
+ C<T> m_c;
+ };
+
+ whatever_int_t heh(); // this should return w::whatever_int_t, and not whatever::whatever_int_t
+
+ C<int> foo();
+
+ C<float> barr(); // <- This is the problematic one
+}