view tests/mini/calls1.d @ 351:f273f5c58a9a trunk

[svn r372] Fixed extern(C++) handling now same as DMD, which is to treat it like extern(C). Fixed a problem in resolving struct types where the size of elements might not yet be known. Switched to using DMD size() instead of LLVM ABI size (TargetData).
author lindquist
date Mon, 14 Jul 2008 03:23:43 +0200
parents 1bb99290e03a
children
line wrap: on
line source

module calls1;
import tango.core.Vararg;
extern(C) int printf(char*, ...);
void main()
{
    {int a = byVal1(3);}
    {int a = void; byRef1(a);}
    {char[] c = void; refType(c);}
    {char[] c = void; refTypeByRef(c);}
    {S s = void; structByVal(s);}
    {S s = void; structByRef(s);}
    {S s = void; structByPtr(&s);}
    {printf("c-varargs %d %d %d\n", 1,2,3);}
    {int i=3; float f=24.7; dvararg(i,f);}
    {char[] s = "hello"; dvarargRefTy(s);}
    {char[] ss = "hello world!"; dvarargRefTy(ss);}
}

int byVal1(int a)
{
    return a;
}

void byRef1(ref int a)
{
    a = 3;
}

void refType(char[] s)
{
}

void refTypeByRef(ref char[] s)
{
}

struct S
{
    float f;
    double d;
    long l;
    byte b;
}

void structByVal(S s)
{
}

void structByRef(ref S s)
{
}

void structByPtr(S* s)
{
}

void dvararg(...)
{
    printf("%d %.1f\n", va_arg!(int)(_argptr), va_arg!(float)(_argptr));
}

void dvarargRefTy(...)
{
    char[] s = va_arg!(char[])(_argptr);
    printf("%.*s\n", s.length, s.ptr);
}