annotate liboctave/MArray-defs.h @ 3580:2923f52d8fda

[project @ 2000-02-05 07:14:21 by jwe]
author jwe
date Sat, 05 Feb 2000 07:14:25 +0000
parents 787bb9d8f60e
children aa8f5aa90c25
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
1 // Nothing like a little CPP abuse to brighten everyone's day. Would
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
2 // have been nice to do this with template functions but as of 2.5.x,
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
3 // g++ seems to fail to resolve them properly.
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
4
3504
5eef8a2294bd [project @ 2000-02-01 10:06:51 by jwe]
jwe
parents: 3243
diff changeset
5 #define DO_VS_OP(r, l, v, OP, s) \
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
6 if (l > 0) \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
7 { \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
8 for (int i = 0; i < l; i++) \
3504
5eef8a2294bd [project @ 2000-02-01 10:06:51 by jwe]
jwe
parents: 3243
diff changeset
9 r[i] = v[i] OP s; \
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
10 }
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
11
3504
5eef8a2294bd [project @ 2000-02-01 10:06:51 by jwe]
jwe
parents: 3243
diff changeset
12 #define DO_SV_OP(r, l, s, OP, v) \
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
13 if (l > 0) \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
14 { \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
15 for (int i = 0; i < l; i++) \
3504
5eef8a2294bd [project @ 2000-02-01 10:06:51 by jwe]
jwe
parents: 3243
diff changeset
16 r[i] = s OP v[i]; \
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
17 }
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
18
3504
5eef8a2294bd [project @ 2000-02-01 10:06:51 by jwe]
jwe
parents: 3243
diff changeset
19 #define DO_VV_OP(r, l, x, OP, y) \
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
20 if (l > 0) \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
21 { \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
22 for (int i = 0; i < l; i++) \
3504
5eef8a2294bd [project @ 2000-02-01 10:06:51 by jwe]
jwe
parents: 3243
diff changeset
23 r[i] = x[i] OP y[i]; \
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
24 }
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
25
3504
5eef8a2294bd [project @ 2000-02-01 10:06:51 by jwe]
jwe
parents: 3243
diff changeset
26 #define NEG_V(r, l, x) \
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
27 if (l > 0) \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
28 { \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
29 for (int i = 0; i < l; i++) \
3504
5eef8a2294bd [project @ 2000-02-01 10:06:51 by jwe]
jwe
parents: 3243
diff changeset
30 r[i] = -x[i]; \
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
31 }
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
32
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
33 #define DO_VS_OP2(OP) \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
34 int l = a.length (); \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
35 if (l > 0) \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
36 { \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
37 T *tmp = a.fortran_vec (); \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
38 for (int i = 0; i < l; i++) \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
39 tmp[i] OP s; \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
40 }
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
41
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
42 #define DO_VV_OP2(OP) \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
43 do \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
44 { \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
45 T *a_tmp = a.fortran_vec (); \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
46 const T *b_tmp = b.data (); \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
47 for (int i = 0; i < l; i++) \
3243
dd00769643ae [project @ 1999-05-28 04:19:00 by jwe]
jwe
parents: 1988
diff changeset
48 a_tmp[i] OP b_tmp[i]; \
1988
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
49 } \
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
50 while (0)
7b56630a1e05 [project @ 1996-03-02 00:33:22 by jwe]
jwe
parents:
diff changeset
51
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
52 // A macro that can be used to declare and instantiate OP= operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
53 #define MARRAY_OP_ASSIGN_DECL(A_T, E_T, OP, PFX, LTGT, RHS_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
54 PFX A_T<E_T>& \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
55 operator OP LTGT (A_T<E_T>&, const RHS_T&)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
56
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
57 // All the OP= operators that we care about.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
58 #define MARRAY_OP_ASSIGN_DECLS(A_T, E_T, PFX, LTGT, RHS_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
59 MARRAY_OP_ASSIGN_DECL (A_T, E_T, +=, PFX, LTGT, RHS_T); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
60 MARRAY_OP_ASSIGN_DECL (A_T, E_T, -=, PFX, LTGT, RHS_T);
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
61
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
62 // Generate forward declarations for OP= operators.
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
63 #define MARRAY_OP_ASSIGN_FWD_DECLS(A_T, RHS_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
64 MARRAY_OP_ASSIGN_DECLS (A_T, T, template <typename T>, , RHS_T)
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
65
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
66 // Generate friend declarations for the OP= operators.
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
67 #define MARRAY_OP_ASSIGN_FRIENDS(A_T, RHS_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
68 MARRAY_OP_ASSIGN_DECLS (A_T, T, friend, <>, RHS_T)
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
69
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
70 // Instantiate the OP= operators.
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
71 #define MARRAY_OP_ASSIGN_DEFS(A_T, E_T, RHS_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
72 MARRAY_OP_ASSIGN_DECLS (A_T, E_T, template, , RHS_T)
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
73
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
74 // A function that can be used to forward OP= operations from derived
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
75 // classes back to us.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
76 #define MARRAY_OP_ASSIGN_FWD_FCN(R, F, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
77 inline R \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
78 F (X_T& x, const Y_T& y) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
79 { \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
80 return R (F (C_X (x), C_Y (y))); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
81 }
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
82
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
83 // All the OP= operators that we care about forwarding.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
84 #define MARRAY_OP_ASSIGN_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
85 MARRAY_OP_ASSIGN_FWD_FCN (R, operator +=, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
86 MARRAY_OP_ASSIGN_FWD_FCN (R, operator -=, T, C_X, X_T, C_Y, Y_T)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
87
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
88 // A macro that can be used to declare and instantiate unary operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
89 #define MARRAY_UNOP(A_T, E_T, F, PFX, LTGT) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
90 PFX A_T<E_T> \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
91 F LTGT (const A_T<E_T>&)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
92
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
93 // All the unary operators that we care about.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
94 #define MARRAY_UNOP_DECLS(A_T, E_T, PFX, LTGT) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
95 MARRAY_UNOP (A_T, E_T, operator +, PFX, LTGT); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
96 MARRAY_UNOP (A_T, E_T, operator -, PFX, LTGT);
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
97
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
98 // Generate forward declarations for unary operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
99 #define MARRAY_UNOP_FWD_DECLS(A_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
100 MARRAY_UNOP_DECLS (A_T, T, template <typename T>, )
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
101
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
102 // Generate friend declarations for the unary operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
103 #define MARRAY_UNOP_FRIENDS(A_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
104 MARRAY_UNOP_DECLS (A_T, T, friend, <>)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
105
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
106 // Instantiate the unary operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
107 #define MARRAY_UNOP_DEFS(A_T, E_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
108 MARRAY_UNOP_DECLS (A_T, E_T, template, )
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
109
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
110 // A function that can be used to forward unary operations from derived
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
111 // classes back to us.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
112 #define MARRAY_UNOP_FWD_FCN(R, F, T, C_X, X_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
113 inline R \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
114 F (const X_T& x) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
115 { \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
116 return R (F (C_X (x))); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
117 }
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
118
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
119 // All the unary operators that we care about forwarding.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
120 #define MARRAY_UNOP_FWD_DEFS(R, T, C_X, X_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
121 MARRAY_UNOP_FWD_FCN (R, operator +, T, C_X, X_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
122 MARRAY_UNOP_FWD_FCN (R, operator -, T, C_X, X_T)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
123
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
124 // A macro that can be used to declare and instantiate binary operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
125 #define MARRAY_BINOP_DECL(A_T, E_T, F, PFX, LTGT, X_T, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
126 PFX A_T<E_T> \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
127 F LTGT (const X_T&, const Y_T&)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
128
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
129 // All the binary operators that we care about. We have two
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
130 // sets of macros since the MArray OP MArray operations use functions
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
131 // (product and quotient) instead of operators (*, /).
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
132 #define MARRAY_BINOP_DECLS(A_T, E_T, PFX, LTGT, X_T, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
133 MARRAY_BINOP_DECL (A_T, E_T, operator +, PFX, LTGT, X_T, Y_T); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
134 MARRAY_BINOP_DECL (A_T, E_T, operator -, PFX, LTGT, X_T, Y_T); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
135 MARRAY_BINOP_DECL (A_T, E_T, operator *, PFX, LTGT, X_T, Y_T); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
136 MARRAY_BINOP_DECL (A_T, E_T, operator /, PFX, LTGT, X_T, Y_T);
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
137
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
138 #define MARRAY_AA_BINOP_DECLS(A_T, E_T, PFX, LTGT) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
139 MARRAY_BINOP_DECL (A_T, E_T, operator +, PFX, LTGT, A_T<E_T>, A_T<E_T>); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
140 MARRAY_BINOP_DECL (A_T, E_T, operator -, PFX, LTGT, A_T<E_T>, A_T<E_T>); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
141 MARRAY_BINOP_DECL (A_T, E_T, quotient, PFX, LTGT, A_T<E_T>, A_T<E_T>); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
142 MARRAY_BINOP_DECL (A_T, E_T, product, PFX, LTGT, A_T<E_T>, A_T<E_T>);
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
143
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
144 #define MDIAGARRAY2_DAS_BINOP_DECLS(A_T, E_T, PFX, LTGT, X_T, Y_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
145 MARRAY_BINOP_DECL (A_T, E_T, operator *, PFX, LTGT, X_T, Y_T); \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
146 MARRAY_BINOP_DECL (A_T, E_T, operator /, PFX, LTGT, X_T, Y_T);
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
147
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
148 #define MDIAGARRAY2_SDA_BINOP_DECLS(A_T, E_T, PFX, LTGT, X_T, Y_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
149 MARRAY_BINOP_DECL (A_T, E_T, operator *, PFX, LTGT, X_T, Y_T);
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
150
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
151 #define MDIAGARRAY2_DADA_BINOP_DECLS(A_T, E_T, PFX, LTGT) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
152 MARRAY_BINOP_DECL (A_T, E_T, operator +, PFX, LTGT, A_T<E_T>, A_T<E_T>); \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
153 MARRAY_BINOP_DECL (A_T, E_T, operator -, PFX, LTGT, A_T<E_T>, A_T<E_T>); \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
154 MARRAY_BINOP_DECL (A_T, E_T, product, PFX, LTGT, A_T<E_T>, A_T<E_T>);
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
155
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
156 // Generate forward declarations for binary operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
157 #define MARRAY_BINOP_FWD_DECLS(A_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
158 MARRAY_BINOP_DECLS (A_T, T, template <typename T>, , A_T<T>, T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
159 MARRAY_BINOP_DECLS (A_T, T, template <typename T>, , T, A_T<T>) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
160 MARRAY_AA_BINOP_DECLS (A_T, T, template <typename T>, )
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
161
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
162 #define MDIAGARRAY2_BINOP_FWD_DECLS(A_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
163 MDIAGARRAY2_DAS_BINOP_DECLS (A_T, T, template <typename T>, , A_T<T>, T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
164 MDIAGARRAY2_SDA_BINOP_DECLS (A_T, T, template <typename T>, , T, A_T<T>) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
165 MDIAGARRAY2_DADA_BINOP_DECLS (A_T, T, template <typename T>, )
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
166
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
167 // Generate friend declarations for the binary operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
168 #define MARRAY_BINOP_FRIENDS(A_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
169 MARRAY_BINOP_DECLS (A_T, T, friend, <>, A_T<T>, T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
170 MARRAY_BINOP_DECLS (A_T, T, friend, <>, T, A_T<T>) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
171 MARRAY_AA_BINOP_DECLS (A_T, T, friend, <>)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
172
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
173 #define MDIAGARRAY2_BINOP_FRIENDS(A_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
174 MDIAGARRAY2_DAS_BINOP_DECLS (A_T, T, friend, <>, A_T<T>, T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
175 MDIAGARRAY2_SDA_BINOP_DECLS (A_T, T, friend, <>, T, A_T<T>) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
176 MDIAGARRAY2_DADA_BINOP_DECLS (A_T, T, friend, <>)
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
177
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
178 // Instantiate the binary operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
179 #define MARRAY_BINOP_DEFS(A_T, E_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
180 MARRAY_BINOP_DECLS (A_T, E_T, template, , A_T<E_T>, E_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
181 MARRAY_BINOP_DECLS (A_T, E_T, template, , E_T, A_T<E_T>) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
182 MARRAY_AA_BINOP_DECLS (A_T, E_T, template, )
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
183
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
184 #define MDIAGARRAY2_BINOP_DEFS(A_T, E_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
185 MDIAGARRAY2_DAS_BINOP_DECLS (A_T, E_T, template, , A_T<E_T>, E_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
186 MDIAGARRAY2_SDA_BINOP_DECLS (A_T, E_T, template, , E_T, A_T<E_T>) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
187 MDIAGARRAY2_DADA_BINOP_DECLS (A_T, E_T, template, )
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
188
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
189 // A function that can be used to forward binary operations from derived
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
190 // classes back to us.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
191 #define MARRAY_BINOP_FWD_FCN(R, F, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
192 inline R \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
193 F (const X_T& x, const Y_T& y) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
194 { \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
195 return R (F (C_X (x), C_Y (y))); \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
196 }
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
197
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
198 // The binary operators that we care about forwarding. We have two
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
199 // sets of macros since the MArray OP MArray operations use functions
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
200 // (product and quotient) instead of operators (*, /).
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
201 #define MARRAY_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
202 MARRAY_BINOP_FWD_FCN (R, operator +, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
203 MARRAY_BINOP_FWD_FCN (R, operator -, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
204 MARRAY_BINOP_FWD_FCN (R, operator *, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
205 MARRAY_BINOP_FWD_FCN (R, operator /, T, C_X, X_T, C_Y, Y_T)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
206
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
207 #define MARRAY_AA_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
208 MARRAY_BINOP_FWD_FCN (R, operator +, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
209 MARRAY_BINOP_FWD_FCN (R, operator -, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
210 MARRAY_BINOP_FWD_FCN (R, product, T, C_X, X_T, C_Y, Y_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
211 MARRAY_BINOP_FWD_FCN (R, quotient, T, C_X, X_T, C_Y, Y_T)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
212
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
213 #define MDIAGARRAY2_DAS_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
214 MARRAY_BINOP_FWD_FCN (R, operator *, T, C_X, X_T, C_Y, Y_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
215 MARRAY_BINOP_FWD_FCN (R, operator /, T, C_X, X_T, C_Y, Y_T)
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
216
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
217 #define MDIAGARRAY2_SDA_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
218 MARRAY_BINOP_FWD_FCN (R, operator *, T, C_X, X_T, C_Y, Y_T)
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
219
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
220 #define MDIAGARRAY2_DADA_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
221 MARRAY_BINOP_FWD_FCN (R, operator +, T, C_X, X_T, C_Y, Y_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
222 MARRAY_BINOP_FWD_FCN (R, operator -, T, C_X, X_T, C_Y, Y_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
223 MARRAY_BINOP_FWD_FCN (R, product, T, C_X, X_T, C_Y, Y_T)
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
224
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
225 // Forward declarations for the MArray operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
226 #define MARRAY_OPS_FORWARD_DECLS(A_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
227 template <class T> \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
228 class A_T; \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
229 \
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
230 MARRAY_OP_ASSIGN_FWD_DECLS (A_T, T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
231 MARRAY_OP_ASSIGN_FWD_DECLS (A_T, A_T<T>) \
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
232 MARRAY_UNOP_FWD_DECLS (A_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
233 MARRAY_BINOP_FWD_DECLS (A_T)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
234
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
235 #define MDIAGARRAY2_OPS_FORWARD_DECLS(A_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
236 template <class T> \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
237 class A_T; \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
238 \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
239 MARRAY_OP_ASSIGN_FWD_DECLS (A_T, A_T<T>) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
240 MARRAY_UNOP_FWD_DECLS (A_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
241 MDIAGARRAY2_BINOP_FWD_DECLS (A_T)
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
242
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
243 // Friend declarations for the MArray operators.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
244 #define MARRAY_OPS_FRIEND_DECLS(A_T) \
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
245 MARRAY_OP_ASSIGN_FRIENDS (A_T, T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
246 MARRAY_OP_ASSIGN_FRIENDS (A_T, A_T<T>) \
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
247 MARRAY_UNOP_FRIENDS (A_T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
248 MARRAY_BINOP_FRIENDS (A_T)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
249
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
250 #define MDIAGARRAY2_OPS_FRIEND_DECLS(A_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
251 MARRAY_OP_ASSIGN_FRIENDS (A_T, A_T<T>) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
252 MARRAY_UNOP_FRIENDS (A_T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
253 MDIAGARRAY2_BINOP_FRIENDS (A_T)
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
254
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
255 // The following macros are for external use.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
256
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
257 // Instantiate all the MArray friends for MArray element type T.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
258 #define INSTANTIATE_MARRAY_FRIENDS(T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
259 MARRAY_OP_ASSIGN_DEFS (MArray, T) \
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
260 MARRAY_OP_ASSIGN_DEFS (MArray, MArray<T>) \
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
261 MARRAY_UNOP_DEFS (MArray, T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
262 MARRAY_BINOP_DEFS (MArray, T)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
263
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
264 // Instantiate all the MArray friends for MArray element type T.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
265 #define INSTANTIATE_MARRAY2_FRIENDS(T) \
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
266 MARRAY_OP_ASSIGN_DEFS (MArray2, T, T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
267 MARRAY_OP_ASSIGN_DEFS (MArray2, T, MArray2<T>) \
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
268 MARRAY_UNOP_DEFS (MArray2, T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
269 MARRAY_BINOP_DEFS (MArray2, T)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
270
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
271 // Instantiate all the MArray friends for MArray element type T.
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
272 #define INSTANTIATE_MDIAGARRAY2_FRIENDS(T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
273 MARRAY_OP_ASSIGN_DEFS (MArray2, T, MArray2<T>) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
274 MARRAY_UNOP_DEFS (MArray2, T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
275 MDIAGARRAY2_BINOP_DEFS (MArray2, T)
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
276
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
277 // Define all the MArray forwarding functions for return type R and
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
278 // MArray element type T
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
279 #define MARRAY_FORWARD_DEFS(B, R, T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
280 MARRAY_OP_ASSIGN_FWD_DEFS \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
281 (R, T, dynamic_cast<B<T>&>, R, , T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
282 \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
283 MARRAY_OP_ASSIGN_FWD_DEFS \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
284 (R, T, \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
285 dynamic_cast<B<T>&>, R, dynamic_cast<const B<T>&>, R) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
286 \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
287 MARRAY_UNOP_FWD_DEFS \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
288 (R, T, dynamic_cast<const B<T>&>, R) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
289 \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
290 MARRAY_BINOP_FWD_DEFS \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
291 (R, T, dynamic_cast<const B<T>&>, R, , T) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
292 \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
293 MARRAY_BINOP_FWD_DEFS \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
294 (R, T, , T, dynamic_cast<const B<T>&>, R) \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
295 \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
296 MARRAY_AA_BINOP_FWD_DEFS \
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
297 (R, T, dynamic_cast<const B<T>&>, R, dynamic_cast<const B<T>&>, R)
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
298
3580
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
299 #define MDIAGARRAY2_FORWARD_DEFS(B, R, T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
300 MARRAY_OP_ASSIGN_FWD_DEFS \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
301 (R, T, \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
302 dynamic_cast<B<T>&>, R, dynamic_cast<const B<T>&>, R) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
303 \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
304 MARRAY_UNOP_FWD_DEFS \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
305 (R, T, dynamic_cast<const B<T>&>, R) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
306 \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
307 MDIAGARRAY2_DAS_BINOP_FWD_DEFS \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
308 (R, T, dynamic_cast<const B<T>&>, R, , T) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
309 \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
310 MDIAGARRAY2_SDA_BINOP_FWD_DEFS \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
311 (R, T, , T, dynamic_cast<const B<T>&>, R) \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
312 \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
313 MDIAGARRAY2_DADA_BINOP_FWD_DEFS \
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
314 (R, T, dynamic_cast<const B<T>&>, R, dynamic_cast<const B<T>&>, R)
2923f52d8fda [project @ 2000-02-05 07:14:21 by jwe]
jwe
parents: 3574
diff changeset
315
3573
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
316 // Now we have all the definitions we need.
6ae6f1180e62 [project @ 2000-02-04 09:01:59 by jwe]
jwe
parents: 3504
diff changeset
317