diff options
Diffstat (limited to 'src/test/run-pass')
| -rw-r--r-- | src/test/run-pass/expr-alt-generic-box1.rs | 25 | ||||
| -rw-r--r-- | src/test/run-pass/expr-alt-generic-box2.rs | 26 | ||||
| -rw-r--r-- | src/test/run-pass/expr-alt-generic.rs | 35 | ||||
| -rw-r--r-- | src/test/run-pass/expr-block-generic-box1.rs | 23 | ||||
| -rw-r--r-- | src/test/run-pass/expr-block-generic-box2.rs | 22 | ||||
| -rw-r--r-- | src/test/run-pass/expr-block-generic.rs | 20 | ||||
| -rw-r--r-- | src/test/run-pass/expr-if-generic-box1.rs | 21 | ||||
| -rw-r--r-- | src/test/run-pass/expr-if-generic-box2.rs | 22 | ||||
| -rw-r--r-- | src/test/run-pass/expr-if-generic.rs | 20 |
9 files changed, 174 insertions, 40 deletions
diff --git a/src/test/run-pass/expr-alt-generic-box1.rs b/src/test/run-pass/expr-alt-generic-box1.rs new file mode 100644 index 00000000..314ae7fd --- /dev/null +++ b/src/test/run-pass/expr-alt-generic-box1.rs @@ -0,0 +1,25 @@ +// xfail-boot +// -*- rust -*- + +type compare[T] = fn(@T t1, @T t2) -> bool; + +fn test_generic[T](@T expected, &compare[T] eq) { + let @T actual = alt (true) { + case (true) { + expected + } + }; + check (eq(expected, actual)); +} + +fn test_box() { + fn compare_box(@bool b1, @bool b2) -> bool { + ret *b1 == b2; + } + auto eq = bind compare_box(_, _); + test_generic[bool](@true, eq); +} + +fn main() { + test_box(); +} diff --git a/src/test/run-pass/expr-alt-generic-box2.rs b/src/test/run-pass/expr-alt-generic-box2.rs new file mode 100644 index 00000000..196ceafc --- /dev/null +++ b/src/test/run-pass/expr-alt-generic-box2.rs @@ -0,0 +1,26 @@ +// xfail-boot +// xfail-stage0 +// -*- rust -*- + +type compare[T] = fn(&T t1, &T t2) -> bool; + +fn test_generic[T](&T expected, &compare[T] eq) { + let T actual = alt (true) { + case (true) { + expected + } + }; + check (eq(expected, actual)); +} + +fn test_vec() { + fn compare_vec(vec[int] v1, vec[int] v2) -> bool { + ret v1 == v2; + } + auto eq = bind compare_vec(_, _); + test_generic[vec[int]](vec(1, 2, 3), eq); +} + +fn main() { + test_vec(); +} diff --git a/src/test/run-pass/expr-alt-generic.rs b/src/test/run-pass/expr-alt-generic.rs new file mode 100644 index 00000000..66681059 --- /dev/null +++ b/src/test/run-pass/expr-alt-generic.rs @@ -0,0 +1,35 @@ +// xfail-boot +// -*- rust -*- + +type compare[T] = fn(&T t1, &T t2) -> bool; + +fn test_generic[T](&T expected, &compare[T] eq) { + let T actual = alt (true) { + case (true) { + expected + } + }; + check (eq(expected, actual)); +} + +fn test_bool() { + fn compare_bool(&bool b1, &bool b2) -> bool { + ret b1 == b2; + } + auto eq = bind compare_bool(_, _); + test_generic[bool](true, eq); +} + +fn test_tup() { + type t = tup(int, int); + fn compare_tup(&t t1, &t t2) -> bool { + ret t1 == t2; + } + auto eq = bind compare_tup(_, _); + test_generic[t](tup(1, 2), eq); +} + +fn main() { + test_bool(); + test_tup(); +}
\ No newline at end of file diff --git a/src/test/run-pass/expr-block-generic-box1.rs b/src/test/run-pass/expr-block-generic-box1.rs new file mode 100644 index 00000000..57487fd6 --- /dev/null +++ b/src/test/run-pass/expr-block-generic-box1.rs @@ -0,0 +1,23 @@ +// xfail-boot +// -*- rust -*- + +type compare[T] = fn(@T t1, @T t2) -> bool; + +fn test_generic[T](@T expected, &compare[T] eq) { + let @T actual = { expected }; + check (eq(expected, actual)); +} + +fn test_box() { + fn compare_box(@bool b1, @bool b2) -> bool { + log *b1; + log *b2; + ret *b1 == *b2; + } + auto eq = bind compare_box(_, _); + test_generic[bool](@true, eq); +} + +fn main() { + test_box(); +}
\ No newline at end of file diff --git a/src/test/run-pass/expr-block-generic-box2.rs b/src/test/run-pass/expr-block-generic-box2.rs new file mode 100644 index 00000000..a129755d --- /dev/null +++ b/src/test/run-pass/expr-block-generic-box2.rs @@ -0,0 +1,22 @@ +// xfail-boot +// xfail-stage0 +// -*- rust -*- + +type compare[T] = fn(&T t1, &T t2) -> bool; + +fn test_generic[T](&T expected, &compare[T] eq) { + let T actual = { expected }; + check (eq(expected, actual)); +} + +fn test_vec() { + fn compare_vec(&vec[int] v1, &vec[int] v2) -> bool { + ret v1 == v2; + } + auto eq = bind compare_vec(_, _); + test_generic[vec[int]](vec(1, 2), eq); +} + +fn main() { + test_vec(); +}
\ No newline at end of file diff --git a/src/test/run-pass/expr-block-generic.rs b/src/test/run-pass/expr-block-generic.rs index fc34d112..ded3b620 100644 --- a/src/test/run-pass/expr-block-generic.rs +++ b/src/test/run-pass/expr-block-generic.rs @@ -1,5 +1,4 @@ // xfail-boot -// xfail-stage0 // -*- rust -*- // Tests for standalone blocks as expressions with dynamic type sizes @@ -29,28 +28,9 @@ fn test_tup() { test_generic[t](tup(1, 2), eq); } -fn test_vec() { - fn compare_vec(&vec[int] v1, &vec[int] v2) -> bool { - ret v1 == v2; - } - auto eq = bind compare_vec(_, _); - test_generic[vec[int]](vec(1, 2), eq); -} - -fn test_box() { - fn compare_box(&@bool b1, &@bool b2) -> bool { - ret *b1 == *b2; - } - auto eq = bind compare_box(_, _); - test_generic[@bool](@true, eq); -} - fn main() { test_bool(); test_tup(); - // FIXME: These two don't pass yet - test_vec(); - test_box(); } diff --git a/src/test/run-pass/expr-if-generic-box1.rs b/src/test/run-pass/expr-if-generic-box1.rs new file mode 100644 index 00000000..32aea8bb --- /dev/null +++ b/src/test/run-pass/expr-if-generic-box1.rs @@ -0,0 +1,21 @@ +// xfail-boot +// -*- rust -*- + +type compare[T] = fn(@T t1, @T t2) -> bool; + +fn test_generic[T](@T expected, @T not_expected, &compare[T] eq) { + let @T actual = if (true) { expected } else { not_expected }; + check (eq(expected, actual)); +} + +fn test_box() { + fn compare_box(@bool b1, @bool b2) -> bool { + ret *b1 == *b2; + } + auto eq = bind compare_box(_, _); + test_generic[bool](@true, @false, eq); +} + +fn main() { + test_box(); +}
\ No newline at end of file diff --git a/src/test/run-pass/expr-if-generic-box2.rs b/src/test/run-pass/expr-if-generic-box2.rs new file mode 100644 index 00000000..a1559cf9 --- /dev/null +++ b/src/test/run-pass/expr-if-generic-box2.rs @@ -0,0 +1,22 @@ +// xfail-boot +// xfail-stage0 +// -*- rust -*- + +type compare[T] = fn(&T t1, &T t2) -> bool; + +fn test_generic[T](&T expected, &T not_expected, &compare[T] eq) { + let T actual = if (true) { expected } else { not_expected }; + check (eq(expected, actual)); +} + +fn test_vec() { + fn compare_vec(&vec[int] v1, &vec[int] v2) -> bool { + ret v1 == v2; + } + auto eq = bind compare_vec(_, _); + test_generic[vec[int]](vec(1, 2), vec(2, 3), eq); +} + +fn main() { + test_vec(); +}
\ No newline at end of file diff --git a/src/test/run-pass/expr-if-generic.rs b/src/test/run-pass/expr-if-generic.rs index f23ce23a..0a0db2dd 100644 --- a/src/test/run-pass/expr-if-generic.rs +++ b/src/test/run-pass/expr-if-generic.rs @@ -1,5 +1,4 @@ // xfail-boot -// xfail-stage0 // -*- rust -*- // Tests for if as expressions with dynamic type sizes @@ -28,26 +27,7 @@ fn test_tup() { test_generic[t](tup(1, 2), tup(2, 3), eq); } -fn test_vec() { - fn compare_vec(&vec[int] v1, &vec[int] v2) -> bool { - ret v1 == v2; - } - auto eq = bind compare_vec(_, _); - test_generic[vec[int]](vec(1, 2), vec(2, 3), eq); -} - -fn test_box() { - fn compare_box(&@bool b1, &@bool b2) -> bool { - ret *b1 == *b2; - } - auto eq = bind compare_box(_, _); - test_generic[@bool](@true, @false, eq); -} - fn main() { test_bool(); test_tup(); - // FIXME: These two don't pass yet - test_vec(); - test_box(); }
\ No newline at end of file |