view tests/mini/vararg1.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

module vararg1;

import tango.stdc.stdarg;

extern(C) int add(int n, ...)
{
    va_list ap=void;
    va_start(ap, n);
    int r;
    for (int i=0; i<n; i++)
        r += va_arg!(int)(ap);
    va_end(ap);
    return r;
}

void main()
{
    int i = add(4, 1,2,3,4);
    assert(i == 10);
}