summaryrefslogtreecommitdiff
path: root/Examples/test-suite/d/director_string_runme.2.d
diff options
context:
space:
mode:
Diffstat (limited to 'Examples/test-suite/d/director_string_runme.2.d')
-rw-r--r--Examples/test-suite/d/director_string_runme.2.d42
1 files changed, 42 insertions, 0 deletions
diff --git a/Examples/test-suite/d/director_string_runme.2.d b/Examples/test-suite/d/director_string_runme.2.d
new file mode 100644
index 000000000..950a34072
--- /dev/null
+++ b/Examples/test-suite/d/director_string_runme.2.d
@@ -0,0 +1,42 @@
+module director_string_runme;
+
+import std.conv;
+import std.exception;
+import director_string.A;
+
+void main() {
+ auto c = new director_string_A("hi");
+ for (int i=0; i<3; ++i) {
+ auto s = c.call_get(i);
+ auto expected = to!string(i);
+ enforce(s == expected, "director_string_A.get(" ~ expected ~ ") failed. Got:" ~ s);
+ }
+
+ auto b = new director_string_B("hello");
+ enforce(b.call_get_first() == "director_string_B.get_first", "call_get_first() failed");
+ enforce(b.call_get(0) == "director_string_B.get: hello", "get(0) failed");
+}
+
+class director_string_B : A {
+public:
+ this(string first) {
+ super(first);
+ }
+ override string get_first() const {
+ return "director_string_B.get_first";
+ }
+
+ override string get(int n) const {
+ return "director_string_B.get: " ~ super.get(n);
+ }
+}
+
+class director_string_A : A {
+public:
+ this(string first) {
+ super(first);
+ }
+ override string get(int n) const {
+ return to!string(n);
+ }
+}