Mercurial > projects > ldc
diff tests/mini/bug33.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/bug33.d@28e99b04a132 |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tests/mini/bug33.d Sun Jul 13 02:51:19 2008 +0200 @@ -0,0 +1,33 @@ +module bug33; + +extern(C) int memcmp(void*,void*,size_t); + +private int string_cmp(char[] s1, char[] s2) +{ + auto len = s1.length; + if (s2.length < len) + len = s2.length; + int result = memcmp(s1.ptr, s2.ptr, len); + if (result == 0) + result = cast(int)(cast(ptrdiff_t)s1.length - cast(ptrdiff_t)s2.length); + return result; +} + +struct S +{ + char[] toString() + { + return "S"; + } +} + +int func() +{ + S a,b; + return string_cmp(a.toString(),b.toString()); +} + +void main() +{ + assert(func() == 0); +}