Mercurial > projects > ldc
diff tests/mini/arrays11.d @ 341:1bb99290e03a trunk
[svn r362] Started merging the old 'test' dir as well as the newer 'tangotests' dir into 'tests/mini' and 'tests/minicomplex'.
author | lindquist |
---|---|
date | Sun, 13 Jul 2008 02:51:19 +0200 |
parents | test/arrays11.d@6789050b5ad1 |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tests/mini/arrays11.d Sun Jul 13 02:51:19 2008 +0200 @@ -0,0 +1,51 @@ +module arrays11; + +void ints() +{ + int[] a = [1,2,3,4,5,6]; + {assert(a == a);} + + int[] b = [4,5,6,7,8,9]; + {assert(a != b);} + {assert(a[3..$] == b[0..3]);} +} + +void floats() +{ + float[] a = [1.0f, 2.0f, 3.0f, 4.0f]; + {assert(a == a);} + + float[] b = [2.0f, 3.0f, 5.0f]; + {assert(a != b);} + {assert(a[1..3] == b[0..2]);} +} + +struct S +{ + int i; + int j; + + int opEquals(S s) + { + return (i == s.i) && (j == s.j); + } +} + +void structs() +{ + S[] a = [S(0,0), S(1,0), S(2,0), S(3,0)]; + {assert(a == a);} + S[] b = [S(0,1), S(1,0), S(2,0), S(3,1)]; + {assert(a != b);} + {assert(a[1..3] == b[1..3]);} + + S[2] c = [S(2,0), S(3,1)]; + {assert(c == b[2..$]);} +} + +void main() +{ + ints(); + floats(); + structs(); +}