aboutsummaryrefslogtreecommitdiff
path: root/Examples/test-suite/typedef_funcptr.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/typedef_funcptr.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/typedef_funcptr.i')
-rw-r--r--Examples/test-suite/typedef_funcptr.i26
1 files changed, 26 insertions, 0 deletions
diff --git a/Examples/test-suite/typedef_funcptr.i b/Examples/test-suite/typedef_funcptr.i
new file mode 100644
index 000000000..9ef220282
--- /dev/null
+++ b/Examples/test-suite/typedef_funcptr.i
@@ -0,0 +1,26 @@
+// Tests typedef through function pointers
+
+%module typedef_funcptr
+
+%warnfilter(801) addf; /* Ruby, wrong constant name */
+%warnfilter(801) subf; /* Ruby, wrong constant name */
+
+%{
+int addf(int x, int y) {
+ return x+y;
+}
+int subf(int x, int y) {
+ return x-y;
+}
+%}
+
+%inline %{
+typedef int Integer;
+
+Integer do_op(Integer x, Integer y, Integer (*op)(Integer, Integer)) {
+ return (*op)(x,y);
+}
+%}
+
+%constant int addf(int x, int y);
+%constant Integer subf(Integer x, Integer y);