summaryrefslogtreecommitdiff
path: root/Examples/php/cpointer
diff options
context:
space:
mode:
Diffstat (limited to 'Examples/php/cpointer')
-rw-r--r--Examples/php/cpointer/Makefile24
-rw-r--r--Examples/php/cpointer/example.c16
-rw-r--r--Examples/php/cpointer/example.i26
-rw-r--r--Examples/php/cpointer/runme.php45
4 files changed, 111 insertions, 0 deletions
diff --git a/Examples/php/cpointer/Makefile b/Examples/php/cpointer/Makefile
new file mode 100644
index 0000000..0862ce5
--- /dev/null
+++ b/Examples/php/cpointer/Makefile
@@ -0,0 +1,24 @@
+TOP = ../..
+SWIG = $(TOP)/../preinst-swig
+SRCS = example.c
+TARGET = example
+INTERFACE = example.i
+LIBS =
+SWIGOPT =
+
+all::
+ $(MAKE) -f $(TOP)/Makefile SRCS='$(SRCS)' SWIG='$(SWIG)' \
+ SWIGOPT='$(SWIGOPT)' TARGET='$(TARGET)' INTERFACE='$(INTERFACE)' \
+ php
+
+static::
+ $(MAKE) -f $(TOP)/Makefile SRCS='$(SRCS)' SWIG='$(SWIG)' \
+ SWIGOPT='$(SWIGOPT)' TARGET='myphp' INTERFACE='$(INTERFACE)' \
+ php_static
+
+clean::
+ $(MAKE) -f $(TOP)/Makefile php_clean
+ rm -f $(TARGET).php
+
+check: all
+ $(MAKE) -f $(TOP)/Makefile php_run
diff --git a/Examples/php/cpointer/example.c b/Examples/php/cpointer/example.c
new file mode 100644
index 0000000..3326dec
--- /dev/null
+++ b/Examples/php/cpointer/example.c
@@ -0,0 +1,16 @@
+/* File : example.c */
+
+void add(double *x, double *y, double *result) {
+ *result = *x + *y;
+}
+
+void sub(int *x, int *y, int *result) {
+ *result = *x - *y;
+}
+
+int divide(int n, int d, int *r) {
+ int q;
+ q = n/d;
+ *r = n - q*d;
+ return q;
+}
diff --git a/Examples/php/cpointer/example.i b/Examples/php/cpointer/example.i
new file mode 100644
index 0000000..52e6df1
--- /dev/null
+++ b/Examples/php/cpointer/example.i
@@ -0,0 +1,26 @@
+/* File : example.i */
+%module example
+
+/* This example illustrates a couple of different techniques
+ for manipulating C pointers */
+
+/* First we'll use the pointer library */
+extern void add(int *x, int *y, int *result);
+
+%include cpointer.i
+%pointer_functions(int, intp);
+
+/* Next we'll use some typemaps */
+
+%include typemaps.i
+extern void sub(int *INPUT, int *INPUT, int *OUTPUT);
+
+/* Next we'll use typemaps and the %apply directive */
+
+//%apply int *OUTPUT { int *r };
+//extern int divide(int n, int d, int *r);
+
+
+
+
+
diff --git a/Examples/php/cpointer/runme.php b/Examples/php/cpointer/runme.php
new file mode 100644
index 0000000..f5ef08a
--- /dev/null
+++ b/Examples/php/cpointer/runme.php
@@ -0,0 +1,45 @@
+<?php
+
+ require "example.php";
+
+ # First create some objects using the pointer library.
+
+ print "Testing the pointer library\n";
+
+ $a = new_intp();
+ $b = new_intp();
+ $c = new_intp();
+ intp_assign($a,37);
+ intp_assign($b,42);
+
+ print " a = $a\n";
+ print " b = $b\n";
+ print " c = $c\n";
+
+ # Call the add() function wuth some pointers
+ add($a,$b,$c);
+
+ # Now get the result
+ $r = intp_value($c);
+
+ print " 38 + 42 = $r\n";
+
+ # Clean up the pointers
+ delete_intp($a);
+ delete_intp($b);
+ delete_intp($c);
+
+ # Now try the typemap library
+ # This should be much easier. Now how it is no longer
+ # necessary to manufacture pointers.
+
+ print "Trying the typemap library\n";
+ $r = sub(37,42);
+ print " 37 - 42 = $r\n";
+
+ # Now try the version with multiple return values
+ # print "Testing multiple return values\n";
+ # ($q,$r) = divide(42,37);
+ # print " 42/37 = $q remainder $r\n";
+
+?>