summaryrefslogtreecommitdiffstats
path: root/Tests/SwigTest/runme.php4
diff options
context:
space:
mode:
authorAndy Cedilnik <andy.cedilnik@kitware.com>2004-04-30 16:17:06 (GMT)
committerAndy Cedilnik <andy.cedilnik@kitware.com>2004-04-30 16:17:06 (GMT)
commita828368232fe08e0065c26e07c38f4dafc78aadf (patch)
tree4d241763e626a7af5d127864e3afff22953d2633 /Tests/SwigTest/runme.php4
parent257daa4635ed9b88035c84c5cb1fcc689268a949 (diff)
downloadCMake-a828368232fe08e0065c26e07c38f4dafc78aadf.zip
CMake-a828368232fe08e0065c26e07c38f4dafc78aadf.tar.gz
CMake-a828368232fe08e0065c26e07c38f4dafc78aadf.tar.bz2
ENH: Here is test for swig module
Diffstat (limited to 'Tests/SwigTest/runme.php4')
-rw-r--r--Tests/SwigTest/runme.php458
1 files changed, 58 insertions, 0 deletions
diff --git a/Tests/SwigTest/runme.php4 b/Tests/SwigTest/runme.php4
new file mode 100644
index 0000000..653ced2
--- /dev/null
+++ b/Tests/SwigTest/runme.php4
@@ -0,0 +1,58 @@
+<?php
+
+# This file illustrates the low-level C++ interface
+# created by SWIG. In this case, all of our C++ classes
+# get converted into function calls.
+
+require("example.php");
+
+# ----- Object creation -----
+
+print "Creating some objects:\n";
+$c = new_Circle(10);
+print " Created circle $c\n";
+$s = new_Square(10);
+print " Created square $s\n";
+
+# ----- Access a static member -----
+
+print "\nA total of " . nshapes() . " shapes were created\n";
+
+# ----- Member data access -----
+
+# Set the location of the object.
+# Note: methods in the base class Shape are used since
+# x and y are defined there.
+
+Shape_x_set($c, 20);
+Shape_y_set($c, 30);
+Shape_x_set($s,-10);
+Shape_y_set($s,5);
+
+print "\nHere is their current position:\n";
+print " Circle = (" . Shape_x_get($c) . "," . Shape_y_get($c) . ")\n";
+print " Square = (" . Shape_x_get($s) . "," . Shape_y_get($s) . ")\n";
+
+# ----- Call some methods -----
+
+print "\nHere are some properties of the shapes:\n";
+foreach (array($c,$s) as $o) {
+ print " $o\n";
+ print " area = " . Shape_area($o) . "\n";
+ print " perimeter = " . Shape_perimeter($o) . "\n";
+ }
+# Notice how the Shape_area() and Shape_perimeter() functions really
+# invoke the appropriate virtual method on each object.
+
+# ----- Delete everything -----
+
+print "\nGuess I'll clean up now\n";
+
+# Note: this invokes the virtual destructor
+delete_Shape($c);
+delete_Shape($s);
+
+print nshapes() . " shapes remain\n";
+print "Goodbye\n";
+
+?>