source: tests/array-container/dimexpr-match-cfa.cfa@ 43109ce

Last change on this file since 43109ce was e0332dd3, checked in by Andrew Beach <ajbeach@…>, 2 years ago

Modified the dimexpr-match tests. This is because dimexpr-match-cfa had a weird case (nested polymorphic function using the array macro) that generates bad code internally and working around that in the invariants is hard. The expect files may only change line numbers, all of those should be updated.

  • Property mode set to 100644
File size: 4.1 KB
Line 
1// These "-cfa" test cases run the dimexpr-match framework (see the hfa) on the CFA "new array."
2// The test is not runnable in gcc.
3// Essentially parallels dimexpr-match.cfa, but uses array(float, 17), of array.hfa, in place of `float[17]`.
4
5#ifndef __cforall
6#error This test is CFA-only
7#endif
8
9#ifdef INCLUDE_MINIMAL
10#define POUNDINCLUDE #include
11POUNDINCLUDE <containers/array.hfa>
12#else
13#include <containers/array.hfa> // part of SUT
14#endif
15
16#include "dimexpr-match.hfa" // test framework
17
18// CFA "classic" behaviour is inconsistent between "C array" and "new array."
19// The impelementation of "non classic" rules makes C arrays and new arrays work the same.
20#ifdef CFA_IS_CLASSIC
21
22 // CFA "classic" allows mismatched static lengths on "new arrays," which is a bug.
23 // For cfacc-classic compiling C arrays, the (expected) rejection of mismatched static lenghts happens in gcc, not cfa-cpp.
24 // When the CFA input is a C array, the cfa-cc handling is passthrough, so GCC sees the error.
25 // When the CFA input is a new array, the cfa-cpp handling is nontrivial; this rewriting hides the error from GCC, causing the case to be accepted.
26 // This issue is fixed in the implementation of the "non classic" rules.
27 #undef RULE_CF_NE_STA_STA
28 #define RULE_CF_NE_STA_STA ACC
29
30 // CFA "classic" rejects mismatched `[N]`s on "new arrays," which is the original signature featere of "new arrays."
31 // But it is unable to do the same with `n`s. So CFA "classic" treats `n` and `[N]` differently.
32 // The impelementation of "non classic" rules extends this safety to `n`s, and to C arrays.
33 #undef GRP_K_DIM // reclassify dim7/dim42 as group XXX, instead of group DYN
34 #define GRP_K_DIM XXX
35 #define RULE_CF_EQ_XXX_XXX ACC // these rules correspond with non-"classic" DYN
36 #define RULE_CF_NE_XXX_XXX REJ
37 #define RULE_CF_NE_XXX_STA REJ
38 #define RULE_CF_NE_STA_XXX REJ
39 #define RULE_CF_NE_XXX_DYN REJ
40 #define RULE_CF_NE_DYN_XXX REJ
41 #define RULE_CF_NE_XXX_UNS REJ
42 #define RULE_CF_NE_UNS_XXX REJ
43
44#endif
45
46forall( [N] )
47void zip( array(float, N) & a, array(float, N) & b ) {}
48
49DECLN_runTests {
50
51 enum { enu7 = 7, enu42 = 42 };
52 int mut7 = 7, mut42 = 42;
53
54 #define TRY_COMPAT( LV, RV ) \
55 { \
56 void f( array(float, LV) * x ) {} \
57 array(float, RV) a; \
58 f( & a ); \
59 }
60 ARRANGEMENT( PTRPARM_CALL )
61 #undef TRY_COMPAT
62
63 #define TRY_COMPAT( LV, RV ) \
64 { \
65 array(float, RV) a; \
66 array(float, LV) * b = & a; \
67 }
68 ARRANGEMENT( PTRVAR_INIT )
69 #undef TRY_COMPAT
70
71 #define TRY_COMPAT( LV, RV ) \
72 { \
73 array(float, RV) a; \
74 array(float, LV) * b = NULL; \
75 b = & a; \
76 }
77 ARRANGEMENT( PTRVAR_ASGN )
78 #undef TRY_COMPAT
79
80 #define TRY_COMPAT( LV, RV ) \
81 { \
82 void f( array(float, LV) & x ) {} \
83 array(float, RV) a; \
84 f( a ); \
85 }
86 ARRANGEMENT( REFPARM_CALL )
87 #undef TRY_COMPAT
88
89 #define TRY_COMPAT( LV, RV ) \
90 { \
91 array(float, RV) a; \
92 array(float, LV) & b = a; \
93 }
94 ARRANGEMENT( REFVAR_INIT )
95 #undef TRY_COMPAT
96
97 #define TRY_COMPAT( LV, RV ) \
98 { \
99 array(float, RV) a; \
100 array(float, LV) & b = *0p; \
101 & b = & a; \
102 }
103 ARRANGEMENT( REFVAR_ASGN )
104 #undef TRY_COMPAT
105
106 #define TRY_COMPAT( LV, RV ) \
107 { \
108 array(float, LV) a; \
109 array(float, RV) b; \
110 zip( a, b ); \
111 }
112 ARRANGEMENT( CALLZIP )
113 #undef TRY_COMPAT
114
115}
Note: See TracBrowser for help on using the repository browser.