view tests/minicomplex/vararg2.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 1bb99290e03a
children
line wrap: on
line source

module tangotests.vararg2;

extern(C) int printf(char*, ...);

import tango.core.Vararg;

void main()
{
    func(0xf00, 1, " ", 2, " ", 3, "\n", 0.3, "\n");
}

void func(int foo, ...)
{
    foreach(t; _arguments)
    {
        if (t == typeid(char[]))
        {
            char[] str = va_arg!(char[])(_argptr);
            printf("%.*s", str.length, str.ptr);
        }
        else if (t == typeid(int))
        {
            printf("%d", va_arg!(int)(_argptr));
        }
        else if (t == typeid(float))
        {
            printf("%f", va_arg!(float)(_argptr));
        }
        else if (t == typeid(double))
        {
            printf("%f", va_arg!(double)(_argptr));
        }
        else if (t == typeid(real))
        {
            printf("%f", va_arg!(real)(_argptr));
        }
        else
        {
            assert(0, "not int");
        }
    }
}