Mercurial > projects > ldc
view runtime/internal/typeinfo/ti_float.d @ 978:6a32d2e18175
Fix a latent bug in the asm code.
I think that technically, using "*m0" instead of "*0" allows LLVM to pick
between using the same memory as output 0 and using a new memory location.
(So far I haven't been able to construct a testcase that actually breaks
because of this, though)
author | Frits van Bommel <fvbommel wxs.nl> |
---|---|
date | Wed, 18 Feb 2009 03:38:12 +0100 |
parents | 44f08170f4ef |
children |
line wrap: on
line source
// float module typeinfo.ti_float; class TypeInfo_f : TypeInfo { char[] toString() { return "float"; } hash_t getHash(void *p) { return *cast(uint *)p; } static int _equals(float f1, float f2) { return f1 == f2 || (f1 !<>= f1 && f2 !<>= f2); } static int _compare(float d1, float d2) { if (d1 !<>= d2) // if either are NaN { if (d1 !<>= d1) { if (d2 !<>= d2) return 0; return -1; } return 1; } return (d1 == d2) ? 0 : ((d1 < d2) ? -1 : 1); } int equals(void *p1, void *p2) { return _equals(*cast(float *)p1, *cast(float *)p2); } int compare(void *p1, void *p2) { return _compare(*cast(float *)p1, *cast(float *)p2); } size_t tsize() { return float.sizeof; } void swap(void *p1, void *p2) { float t; t = *cast(float *)p1; *cast(float *)p1 = *cast(float *)p2; *cast(float *)p2 = t; } void[] init() { static float r; return (cast(float *)&r)[0 .. 1]; } }