From 8f2a97a562916a882ec0818e6295d41971aad5f1 Mon Sep 17 00:00:00 2001 From: Brian Anderson Date: Sun, 27 Mar 2011 20:20:12 -0400 Subject: Add partial support for if expressions resulting in generic types --- src/test/run-pass/expr-if-generic.rs | 53 ++++++++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) create mode 100644 src/test/run-pass/expr-if-generic.rs (limited to 'src/test') diff --git a/src/test/run-pass/expr-if-generic.rs b/src/test/run-pass/expr-if-generic.rs new file mode 100644 index 00000000..f23ce23a --- /dev/null +++ b/src/test/run-pass/expr-if-generic.rs @@ -0,0 +1,53 @@ +// xfail-boot +// xfail-stage0 +// -*- rust -*- + +// Tests for if as expressions with dynamic type sizes + +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_bool() { + fn compare_bool(&bool b1, &bool b2) -> bool { + ret b1 == b2; + } + auto eq = bind compare_bool(_, _); + test_generic[bool](true, false, 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), 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 -- cgit v1.2.3