factor/native/ffi_test.c

69 lines
1.2 KiB
C
Raw Normal View History

2006-01-20 21:37:38 -05:00
/* This file is linked into the runtime for the sole purpose
* of testing FFI code. */
2006-01-24 20:20:20 -05:00
#include <stdio.h>
2006-01-20 21:37:38 -05:00
void ffi_test_0(void)
{
printf("ffi_test_0()\n");
}
int ffi_test_1(void)
{
printf("ffi_test_1()\n");
return 3;
}
int ffi_test_2(int x, int y)
{
printf("ffi_test_2(%d,%d)\n",x,y);
return x + y;
}
2006-01-24 19:56:08 -05:00
int ffi_test_3(int x, int y, int z, int t)
{
printf("ffi_test_3(%d,%d,%d,%d)\n",x,y,z,t);
return x + y + z * t;
}
2006-01-24 20:20:20 -05:00
float ffi_test_4(void)
{
printf("ffi_test_4()\n");
return 1.5;
}
double ffi_test_5(void)
{
printf("ffi_test_5()\n");
return 1.5;
}
double ffi_test_6(float x, float y)
{
printf("ffi_test_6(%f,%f)\n",x,y);
return x * y;
}
2006-01-25 01:18:12 -05:00
double ffi_test_7(double x, double y)
2006-01-24 20:20:20 -05:00
{
2006-01-25 01:18:12 -05:00
printf("ffi_test_7(%f,%f)\n",x,y);
return x * y;
}
double ffi_test_8(double x, float y, double z, float t, int w)
{
printf("ffi_test_8(%f,%f,%f,%f,%d)\n",x,y,z,t,w);
return x * y + z * t + w;
2006-01-24 20:20:20 -05:00
}
int ffi_test_9(int a, int b, int c, int d, int e, int f, int g)
{
printf("ffi_test_9(%d,%d,%d,%d,%d,%d,%d)\n",a,b,c,d,e,f,g);
return a + b + c + d + e + f + g;
}
int ffi_test_10(int a, int b, double c, int d, float e, int f, int g, int h)
{
printf("ffi_test_10(%d,%d,%f,%d,%f,%d,%d,%d)\n",a,b,c,d,e,f,g,h);
return a - b - c - d - e - f - g - h;
}