aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBrian Anderson <[email protected]>2011-03-31 21:47:53 -0400
committerBrian Anderson <[email protected]>2011-03-31 23:15:11 -0400
commitcf16f4f7e5bf5d37fc0e254e3c7ccdf0623c50d3 (patch)
treecbff493127cfc131b6e3b0f2d230392ee8168804
parentAdd another test for blocks as expressions (diff)
downloadrust-cf16f4f7e5bf5d37fc0e254e3c7ccdf0623c50d3.tar.xz
rust-cf16f4f7e5bf5d37fc0e254e3c7ccdf0623c50d3.zip
Add a test for block expressions of generic types. XFAILed
-rw-r--r--src/test/run-pass/expr-block-generic.rs56
1 files changed, 56 insertions, 0 deletions
diff --git a/src/test/run-pass/expr-block-generic.rs b/src/test/run-pass/expr-block-generic.rs
new file mode 100644
index 00000000..fc34d112
--- /dev/null
+++ b/src/test/run-pass/expr-block-generic.rs
@@ -0,0 +1,56 @@
+// xfail-boot
+// xfail-stage0
+// -*- rust -*-
+
+// Tests for standalone blocks as expressions with dynamic type sizes
+
+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_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 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();
+}
+
+