annotate test/callback_suite/globals.c @ 509:f3d44195dbdf

callback_suite: - further, big refactoring to make the test data setup be a lot more in line with call_suite and call_suite_aggrs - added support to test void return values (was missing in prev version)
author Tassilo Philipp
date Sat, 09 Apr 2022 23:00:24 +0200
parents 5a3c07a0f376
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
1 /*
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
2
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
3 Package: dyncall
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
4 Library: test
505
049e04af13c8 test/callback_suite:
Tassilo Philipp
parents: 489
diff changeset
5 File: test/callback_suite/globals.c
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
7 License:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
8
505
049e04af13c8 test/callback_suite:
Tassilo Philipp
parents: 489
diff changeset
9 Copyright (c) 2011-2022 Daniel Adler <dadler@uni-goettingen.de>,
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
10 Tassilo Philipp <tphilipp@potion-studios.com>
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
11
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
12 Permission to use, copy, modify, and distribute this software for any
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
13 purpose with or without fee is hereby granted, provided that the above
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
14 copyright notice and this permission notice appear in all copies.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
15
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
16 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
17 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
18 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
19 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
20 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
21 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
22 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
23
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
24 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
25
505
049e04af13c8 test/callback_suite:
Tassilo Philipp
parents: 489
diff changeset
26 #include <stdlib.h>
049e04af13c8 test/callback_suite:
Tassilo Philipp
parents: 489
diff changeset
27 #include "globals.h"
509
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
28 #include <float.h>
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
29 #include <assert.h>
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30
509
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
31 #define X(CH,T) T *V_##CH; T *K_##CH;
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
32 DEF_TYPES
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
33 #undef X
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34
509
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
35 static double rand_d() { return ( ( (double) rand() ) / ( (double) RAND_MAX ) ); }
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36
505
049e04af13c8 test/callback_suite:
Tassilo Philipp
parents: 489
diff changeset
37 void init_test_data()
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38 {
509
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
39 int i;
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
40 #define X(CH,T) V_##CH = (T*) malloc(sizeof(T)*(G_maxargs+1)); K_##CH = (T*) malloc(sizeof(T)*(G_maxargs+1));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
41 DEF_TYPES
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
42 #undef X
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
43 for(i=0;i<G_maxargs+1;++i) {
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
44 K_B[i] = (DCbool) ((int)rand_d() & 1);
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
45 K_c[i] = (char) (((rand_d()-0.5)*2) * (1<<7));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
46 K_s[i] = (short) (((rand_d()-0.5)*2) * (1<<(sizeof(short)*8-1)));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
47 K_i[i] = (int) (((rand_d()-0.5)*2) * (1<<(sizeof(int)*8-2)));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
48 K_j[i] = (long) (((rand_d()-0.5)*2) * (1L<<(sizeof(long)*8-2)));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
49 K_l[i] = (long long) (((rand_d()-0.5)*2) * (1LL<<(sizeof(long long)*8-2)));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
50 K_C[i] = (unsigned char) (((rand_d()-0.5)*2) * (1<<7));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
51 K_S[i] = (unsigned short) (((rand_d()-0.5)*2) * (1<<(sizeof(short)*8-1)));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
52 K_I[i] = (unsigned int) (((rand_d()-0.5)*2) * (1<<(sizeof(int)*8-2)));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
53 K_J[i] = (unsigned long) (((rand_d()-0.5)*2) * (1L<<(sizeof(long)*8-2)));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
54 K_L[i] = (unsigned long long)(((rand_d()-0.5)*2) * (1LL<<(sizeof(long long)*8-2)));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
55 K_p[i] = (void*)(long) (((rand_d()-0.5)*2) * (1LL<<(sizeof(void*)*8-1)));
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
56 K_f[i] = (float) (rand_d() * FLT_MAX);
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
57 K_d[i] = (double) (((rand_d()-0.5)*2) * DBL_MAX);
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
58 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
59 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60
509
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
61 void clear_V()
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
62 {
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
63 int i;
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
64 for(i=0;i<G_maxargs+1;++i) {
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
65 #define X(CH,T) V_##CH[i] = (T) 0;
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
66 DEF_TYPES
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
67 #undef X
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
68 }
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
69 }
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
70
505
049e04af13c8 test/callback_suite:
Tassilo Philipp
parents: 489
diff changeset
71 void deinit_test_data()
049e04af13c8 test/callback_suite:
Tassilo Philipp
parents: 489
diff changeset
72 {
509
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
73 #define X(CH,T) free(V_##CH); free(K_##CH);
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
74 DEF_TYPES
f3d44195dbdf callback_suite:
Tassilo Philipp
parents: 507
diff changeset
75 #undef X
505
049e04af13c8 test/callback_suite:
Tassilo Philipp
parents: 489
diff changeset
76 }
049e04af13c8 test/callback_suite:
Tassilo Philipp
parents: 489
diff changeset
77