view tests/mini/arrayops4.d @ 1134:152bd2c804d0

Update comments now that LLVM PR3861 has been fixed. However, since conditionally removing the workaround makes the ABI dependent on LLVM version, I reconsidered that. (The same revision of LDC compiling for the same target should probably produce code that follows the same ABI, right?)
author Frits van Bommel <fvbommel wxs.nl>
date Tue, 24 Mar 2009 02:46:57 +0100
parents 06576ece1a1b
children
line wrap: on
line source

void main()
{
    auto a = new float[1024];
    auto b = new float[1024];
    auto c = new float[1024];

    for (auto i=0; i<1024; i++)
    {
        a[i] = i;
        b[i] = i*2;
        c[i] = i*4;
    }

    a[] = b[] + c[] / 2;

    foreach(i,v; a)
    {
        assert(eq(v, b[i] + c[i] / 2));
    }
}

float abs(float x)
{
    return x<0?-x:x;
}
bool eq(float a, float b)
{
    return abs(a-b) <= float.epsilon;
}