summaryrefslogtreecommitdiff
path: root/Examples/test-suite/using_namespace.i
diff options
context:
space:
mode:
authorDave Beazley <dave-swig@dabeaz.com>2002-11-30 22:01:28 +0000
committerDave Beazley <dave-swig@dabeaz.com>2002-11-30 22:01:28 +0000
commit12a43edc2df8853e8e0315f742e57be88f0c4269 (patch)
treee3237f5f8c0a67c9bfa9bb5d6d095a739a49e4b2 /Examples/test-suite/using_namespace.i
parent5fcae5eb66d377e1c3f81da7465c44a62295a72b (diff)
downloadswig-12a43edc2df8853e8e0315f742e57be88f0c4269.tar.gz
The great merge
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@4141 626c5289-ae23-0410-ae9c-e8d60b6d4f22
Diffstat (limited to 'Examples/test-suite/using_namespace.i')
-rw-r--r--Examples/test-suite/using_namespace.i56
1 files changed, 56 insertions, 0 deletions
diff --git a/Examples/test-suite/using_namespace.i b/Examples/test-suite/using_namespace.i
new file mode 100644
index 000000000..886dd2a3e
--- /dev/null
+++ b/Examples/test-suite/using_namespace.i
@@ -0,0 +1,56 @@
+%module using_namespace
+
+%warnfilter(801) hi::hi0; /* Ruby, wrong class name */
+%warnfilter(801) hi::hi1; /* Ruby, wrong class name */
+
+%warnfilter(802, 813) Hi<hello::Hello, hi::hi0>; // Ruby, Java multiple inheritance
+
+%inline %{
+ namespace hello
+ {
+ struct Hello
+ {
+ };
+
+ template <class _T1, class _T2>
+ struct Hi : _T1, _T2
+ {
+ int value1() const
+ {
+ return 1;
+ }
+ };
+ }
+
+ namespace hi
+ {
+
+ struct hi0
+ {
+ };
+
+ }
+%}
+
+namespace hello
+{
+ %template(Hi_hi0) Hi<hello::Hello, hi::hi0>;
+}
+
+
+%inline %{
+ namespace hi
+ {
+ struct hi1 : private hello::Hi< hello::Hello, hi0 >
+ {
+ // This works
+ // using hello::Hi< hello::Hello, hi::hi0 >::value1;
+
+ // This doesn't
+ using hello::Hi< hello::Hello, hi0 >::value1;
+
+ };
+
+ }
+
+%}