Mercurial > pub > dyncall > dyncall
comparison test/suite_aggrs/cases.c @ 432:167faab0c0be
first usable version of test suite for aggregates, handling only non-nested struct params, at the moment;
still missing:
- unions
- arrays
- aggregates as return values
author | Tassilo Philipp |
---|---|
date | Fri, 21 Jan 2022 15:42:29 +0100 |
parents | |
children | 45662241d9cd |
comparison
equal
deleted
inserted
replaced
431:1cb8a65ea27f | 432:167faab0c0be |
---|---|
1 /* | |
2 | |
3 Package: dyncall | |
4 Library: test | |
5 File: test/call_aggrs/cases.c | |
6 Description: | |
7 License: | |
8 | |
9 Copyright (c) 2022 Tassilo Philipp <tphilipp@potion-studios.com> | |
10 | |
11 Permission to use, copy, modify, and distribute this software for any | |
12 purpose with or without fee is hereby granted, provided that the above | |
13 copyright notice and this permission notice appear in all copies. | |
14 | |
15 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | |
16 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | |
17 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | |
18 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | |
19 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | |
20 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | |
21 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | |
22 | |
23 */ | |
24 | |
25 #include "globals.h" | |
26 | |
27 #define ret_v(X) | |
28 #define ret_c(X) return(K_c[X]); | |
29 #define ret_s(X) return(K_s[X]); | |
30 #define ret_i(X) return(K_i[X]); | |
31 #define ret_j(X) return(K_j[X]); | |
32 #define ret_l(X) return(K_l[X]); | |
33 #define ret_p(X) return(K_p[X]); | |
34 #define ret_f(X) return(K_f[X]); | |
35 #define ret_d(X) return(K_d[X]); | |
36 #define ret_a(X) return(K_a[X]); | |
37 | |
38 #define v void | |
39 #define c char | |
40 #define s short | |
41 #define i int | |
42 #define j long | |
43 #define l long long | |
44 #define p void* | |
45 #define f float | |
46 #define d double | |
47 #define a void* /* all generated aggregates */ | |
48 | |
49 #include "dyncall_struct.h" | |
50 #include "cases.h" | |
51 | |
52 int G_ncases = sizeof(G_sigtab)/sizeof(G_sigtab[0]); | |
53 int G_naggs = sizeof(G_agg_sigs)/sizeof(G_agg_sigs[0]); | |
54 |