From 2824b0cbb66e715490e1ef13250bd675d87b32d9 Mon Sep 17 00:00:00 2001 From: William S Fulton Date: Wed, 2 Jun 2010 20:53:17 +0000 Subject: rel-2.0.0 git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/tags/rel-2.0.0@12089 626c5289-ae23-0410-ae9c-e8d60b6d4f22 --- trunk/Examples/php/enum/Makefile | 24 ++++++++++++++++++++++++ trunk/Examples/php/enum/example.cxx | 37 +++++++++++++++++++++++++++++++++++++ trunk/Examples/php/enum/example.h | 13 +++++++++++++ trunk/Examples/php/enum/example.i | 12 ++++++++++++ trunk/Examples/php/enum/runme.php | 32 ++++++++++++++++++++++++++++++++ 5 files changed, 118 insertions(+) create mode 100644 trunk/Examples/php/enum/Makefile create mode 100644 trunk/Examples/php/enum/example.cxx create mode 100644 trunk/Examples/php/enum/example.h create mode 100644 trunk/Examples/php/enum/example.i create mode 100644 trunk/Examples/php/enum/runme.php (limited to 'trunk/Examples/php/enum') diff --git a/trunk/Examples/php/enum/Makefile b/trunk/Examples/php/enum/Makefile new file mode 100644 index 000000000..252a72660 --- /dev/null +++ b/trunk/Examples/php/enum/Makefile @@ -0,0 +1,24 @@ +TOP = ../.. +SWIG = $(TOP)/../preinst-swig +CXXSRCS = example.cxx +TARGET = example +INTERFACE = example.i +LIBS = +SWIGOPT = -noproxy + +all:: + $(MAKE) -f $(TOP)/Makefile CXXSRCS='$(CXXSRCS)' SWIG='$(SWIG)' \ + SWIGOPT='$(SWIGOPT)' TARGET='$(TARGET)' INTERFACE='$(INTERFACE)' \ + php_cpp + +static:: + $(MAKE) -f $(TOP)/Makefile CXXSRCS='$(CXXSRCS)' SWIG='$(SWIG)' \ + SWIGOPT='$(SWIGOPT)' TARGET='myphp' INTERFACE='$(INTERFACE)' \ + php_cpp_static + +clean:: + $(MAKE) -f $(TOP)/Makefile php_clean + rm -f $(TARGET).php + +check: all + $(MAKE) -f $(TOP)/Makefile php_run diff --git a/trunk/Examples/php/enum/example.cxx b/trunk/Examples/php/enum/example.cxx new file mode 100644 index 000000000..df7bb6328 --- /dev/null +++ b/trunk/Examples/php/enum/example.cxx @@ -0,0 +1,37 @@ +/* File : example.cxx */ + +#include "example.h" +#include + +void Foo::enum_test(speed s) { + if (s == IMPULSE) { + printf("IMPULSE speed\n"); + } else if (s == WARP) { + printf("WARP speed\n"); + } else if (s == LUDICROUS) { + printf("LUDICROUS speed\n"); + } else { + printf("Unknown speed\n"); + } +} + +void enum_test(color c, Foo::speed s) { + if (c == RED) { + printf("color = RED, "); + } else if (c == BLUE) { + printf("color = BLUE, "); + } else if (c == GREEN) { + printf("color = GREEN, "); + } else { + printf("color = Unknown color!, "); + } + if (s == Foo::IMPULSE) { + printf("speed = IMPULSE speed\n"); + } else if (s == Foo::WARP) { + printf("speed = WARP speed\n"); + } else if (s == Foo::LUDICROUS) { + printf("speed = LUDICROUS speed\n"); + } else { + printf("speed = Unknown speed!\n"); + } +} diff --git a/trunk/Examples/php/enum/example.h b/trunk/Examples/php/enum/example.h new file mode 100644 index 000000000..525d62afc --- /dev/null +++ b/trunk/Examples/php/enum/example.h @@ -0,0 +1,13 @@ +/* File : example.h */ + +enum color { RED, BLUE, GREEN }; + +class Foo { + public: + Foo() { } + enum speed { IMPULSE, WARP, LUDICROUS }; + void enum_test(speed s); +}; + +void enum_test(color c, Foo::speed s); + diff --git a/trunk/Examples/php/enum/example.i b/trunk/Examples/php/enum/example.i new file mode 100644 index 000000000..abf254731 --- /dev/null +++ b/trunk/Examples/php/enum/example.i @@ -0,0 +1,12 @@ +/* File : example.i */ +%module example + +%{ +#include "example.h" +%} + + +/* Let's just grab the original header file here */ + +%include "example.h" + diff --git a/trunk/Examples/php/enum/runme.php b/trunk/Examples/php/enum/runme.php new file mode 100644 index 000000000..55b0bc4c3 --- /dev/null +++ b/trunk/Examples/php/enum/runme.php @@ -0,0 +1,32 @@ + -- cgit v1.2.1