aboutsummaryrefslogtreecommitdiff
path: root/Examples/test-suite/template_ns4.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/template_ns4.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/template_ns4.i')
-rw-r--r--Examples/test-suite/template_ns4.i66
1 files changed, 66 insertions, 0 deletions
diff --git a/Examples/test-suite/template_ns4.i b/Examples/test-suite/template_ns4.i
new file mode 100644
index 000000000..3769f8d0b
--- /dev/null
+++ b/Examples/test-suite/template_ns4.i
@@ -0,0 +1,66 @@
+%module template_ns4
+
+%inline %{
+ namespace hello {
+
+ class Double {
+ };
+
+ template <class ArgType, class ResType>
+ struct Function
+ {
+ char *test() { return (char *) "test"; }
+ };
+
+ template <class AF, class RF>
+ struct ArithFunction : Function<AF, RF>
+ {
+ };
+
+ template <class ArgType, class ResType>
+ struct traits
+ {
+ };
+
+ template <class ArgType>
+ struct traits<ArgType, double>
+ {
+ typedef ArgType arg_type;
+ typedef double res_type;
+ typedef ArithFunction<ArgType, double> base;
+ };
+
+ template <class ArgType>
+ struct traits<ArgType, Double>
+ {
+ typedef ArgType arg_type;
+ typedef Double res_type;
+ typedef ArithFunction<ArgType, Double> base;
+ };
+
+ template <class AF, class RF>
+ class Class : public ArithFunction< typename traits<AF, RF>::arg_type,
+ typename traits<AF, RF>::res_type >
+ {
+ };
+
+ template <class AF, class RF>
+ typename traits<AF, RF>::base
+ make_Class()
+ {
+ return Class<AF, RF>();
+ }
+
+ }
+%}
+ namespace hello {
+ //
+ // This complains only when using a namespace
+ //
+ %template() traits<Double,Double>;
+ %template(Function_DD) Function <Double, Double>;
+ %template(ArithFunction_DD) ArithFunction <Double, Double>;
+ %template(Class_DD) Class <Double, Double>;
+ %template(make_Class_DD) make_Class <Double, Double>;
+ }
+