annotate src/main/java/fj/P6.java @ 0:fe80c1edf1be

add getLoop
author tatsuki
date Fri, 20 Mar 2015 21:04:03 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
1 package fj;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
2
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
3 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
4 * A product-6.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
5 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
6 * @version %build.number%
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
7 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
8 @SuppressWarnings({"UnnecessaryFullyQualifiedName"})
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
9 public abstract class P6<A, B, C, D, E, F> {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
10 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
11 * Access the first element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
12 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
13 * @return The first element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
14 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
15 public abstract A _1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
16
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
17 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
18 * Access the second element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
19 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
20 * @return The second element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
21 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
22 public abstract B _2();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
23
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
24 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
25 * Access the third element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
26 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
27 * @return The third element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
28 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
29 public abstract C _3();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
30
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
31 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
32 * Access the fourth element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
33 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
34 * @return The fourth element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
35 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
36 public abstract D _4();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
37
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
38 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
39 * Access the fifth element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
40 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
41 * @return The fifth element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
42 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
43 public abstract E _5();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
44
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
45 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
46 * Access the sixth element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
47 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
48 * @return The sixth element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
49 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
50 public abstract F _6();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
51
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
52 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
53 * Map the first element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
54 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
55 * @param f The function to map with.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
56 * @return A product with the given function applied.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
57 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
58 public final <X> P6<X, B, C, D, E, F> map1(final fj.F<A, X> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
59 return new P6<X, B, C, D, E, F>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
60 public X _1() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
61 return f.f(P6.this._1());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
62 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
63
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
64 public B _2() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
65 return P6.this._2();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
66 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
67
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
68 public C _3() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
69 return P6.this._3();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
70 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
71
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
72 public D _4() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
73 return P6.this._4();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
74 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
75
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
76 public E _5() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
77 return P6.this._5();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
78 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
79
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
80 public F _6() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
81 return P6.this._6();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
82 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
83 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
84 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
85
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
86 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
87 * Map the second element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
88 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
89 * @param f The function to map with.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
90 * @return A product with the given function applied.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
91 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
92 public final <X> P6<A, X, C, D, E, F> map2(final fj.F<B, X> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
93 return new P6<A, X, C, D, E, F>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
94 public A _1() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
95 return P6.this._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
96 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
97
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
98 public X _2() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
99 return f.f(P6.this._2());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
100 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
101
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
102 public C _3() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
103 return P6.this._3();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
104 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
105
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
106 public D _4() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
107 return P6.this._4();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
108 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
109
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
110 public E _5() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
111 return P6.this._5();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
112 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
113
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
114 public F _6() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
115 return P6.this._6();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
116 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
117 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
118 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
119
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
120 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
121 * Map the third element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
122 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
123 * @param f The function to map with.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
124 * @return A product with the given function applied.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
125 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
126 public final <X> P6<A, B, X, D, E, F> map3(final fj.F<C, X> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
127 return new P6<A, B, X, D, E, F>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
128 public A _1() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
129 return P6.this._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
130 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
131
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
132 public B _2() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
133 return P6.this._2();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
134 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
135
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
136 public X _3() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
137 return f.f(P6.this._3());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
138 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
139
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
140 public D _4() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
141 return P6.this._4();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
142 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
143
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
144 public E _5() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
145 return P6.this._5();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
146 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
147
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
148 public F _6() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
149 return P6.this._6();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
150 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
151 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
152 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
153
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
154 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
155 * Map the fourth element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
156 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
157 * @param f The function to map with.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
158 * @return A product with the given function applied.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
159 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
160 public final <X> P6<A, B, C, X, E, F> map4(final fj.F<D, X> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
161 return new P6<A, B, C, X, E, F>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
162 public A _1() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
163 return P6.this._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
164 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
165
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
166 public B _2() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
167 return P6.this._2();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
168 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
169
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
170 public C _3() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
171 return P6.this._3();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
172 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
173
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
174 public X _4() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
175 return f.f(P6.this._4());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
176 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
177
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
178 public E _5() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
179 return P6.this._5();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
180 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
181
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
182 public F _6() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
183 return P6.this._6();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
184 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
185 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
186 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
187
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
188 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
189 * Map the fifth element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
190 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
191 * @param f The function to map with.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
192 * @return A product with the given function applied.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
193 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
194 public final <X> P6<A, B, C, D, X, F> map5(final fj.F<E, X> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
195 return new P6<A, B, C, D, X, F>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
196 public A _1() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
197 return P6.this._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
198 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
199
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
200 public B _2() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
201 return P6.this._2();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
202 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
203
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
204 public C _3() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
205 return P6.this._3();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
206 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
207
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
208 public D _4() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
209 return P6.this._4();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
210 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
211
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
212 public X _5() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
213 return f.f(P6.this._5());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
214 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
215
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
216 public F _6() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
217 return P6.this._6();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
218 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
219 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
220 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
221
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
222 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
223 * Map the sixth element of the product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
224 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
225 * @param f The function to map with.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
226 * @return A product with the given function applied.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
227 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
228 public final <X> P6<A, B, C, D, E, X> map6(final fj.F<F, X> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
229 return new P6<A, B, C, D, E, X>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
230 public A _1() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
231 return P6.this._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
232 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
233
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
234 public B _2() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
235 return P6.this._2();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
236 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
237
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
238 public C _3() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
239 return P6.this._3();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
240 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
241
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
242 public D _4() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
243 return P6.this._4();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
244 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
245
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
246 public E _5() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
247 return P6.this._5();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
248 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
249
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
250 public X _6() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
251 return f.f(P6.this._6());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
252 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
253 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
254 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
255
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
256 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
257 * Returns the 1-product projection over the first element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
258 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
259 * @return the 1-product projection over the first element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
260 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
261 public final P1<A> _1_() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
262 return F1Functions.lazy(P6.<A, B, C, D, E, F>__1()).f(this);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
263 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
264
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
265 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
266 * Returns the 1-product projection over the second element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
267 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
268 * @return the 1-product projection over the second element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
269 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
270 public final P1<B> _2_() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
271 return F1Functions.lazy(P6.<A, B, C, D, E, F>__2()).f(this);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
272 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
273
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
274 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
275 * Returns the 1-product projection over the third element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
276 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
277 * @return the 1-product projection over the third element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
278 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
279 public final P1<C> _3_() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
280 return F1Functions.lazy(P6.<A, B, C, D, E, F>__3()).f(this);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
281 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
282
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
283 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
284 * Returns the 1-product projection over the fourth element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
285 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
286 * @return the 1-product projection over the fourth element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
287 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
288 public final P1<D> _4_() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
289 return F1Functions.lazy(P6.<A, B, C, D, E, F>__4()).f(this);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
290 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
291
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
292 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
293 * Returns the 1-product projection over the fifth element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
294 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
295 * @return the 1-product projection over the fifth element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
296 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
297 public final P1<E> _5_() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
298 return F1Functions.lazy(P6.<A, B, C, D, E, F>__5()).f(this);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
299 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
300
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
301 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
302 * Returns the 1-product projection over the sixth element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
303 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
304 * @return the 1-product projection over the sixth element.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
305 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
306 public final P1<F> _6_() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
307 return F1Functions.lazy(P6.<A, B, C, D, E, F>__6()).f(this);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
308 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
309
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
310 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
311 * Provides a memoising P6 that remembers its values.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
312 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
313 * @return A P6 that calls this P6 once for any given element and remembers the value for subsequent calls.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
314 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
315 public final P6<A, B, C, D, E, F> memo() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
316 P6<A, B, C, D, E, F> self = this;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
317 return new P6<A, B, C, D, E, F>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
318 private final P1<A> a = P1.memo(u -> self._1());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
319 private final P1<B> b = P1.memo(u -> self._2());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
320 private final P1<C> c = P1.memo(u -> self._3());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
321 private final P1<D> d = P1.memo(u -> self._4());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
322 private final P1<E> e = P1.memo(u -> self._5());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
323 private final P1<F> f = P1.memo(u -> self._6());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
324
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
325 public A _1() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
326 return a._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
327 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
328
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
329 public B _2() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
330 return b._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
331 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
332
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
333 public C _3() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
334 return c._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
335 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
336
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
337 public D _4() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
338 return d._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
339 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
340
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
341 public E _5() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
342 return e._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
343 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
344
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
345 public F _6() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
346 return f._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
347 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
348 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
349 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
350
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
351
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
352 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
353 * Returns a function that returns the first element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
354 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
355 * @return A function that returns the first element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
356 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
357 public static <A, B, C, D, E, F$> fj.F<P6<A, B, C, D, E, F$>, A> __1() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
358 return new fj.F<P6<A, B, C, D, E, F$>, A>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
359 public A f(final P6<A, B, C, D, E, F$> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
360 return p._1();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
361 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
362 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
363 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
364
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
365 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
366 * Returns a function that returns the second element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
367 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
368 * @return A function that returns the second element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
369 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
370 public static <A, B, C, D, E, F$> fj.F<P6<A, B, C, D, E, F$>, B> __2() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
371 return new fj.F<P6<A, B, C, D, E, F$>, B>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
372 public B f(final P6<A, B, C, D, E, F$> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
373 return p._2();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
374 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
375 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
376 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
377
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
378 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
379 * Returns a function that returns the third element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
380 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
381 * @return A function that returns the third element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
382 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
383 public static <A, B, C, D, E, F$> fj.F<P6<A, B, C, D, E, F$>, C> __3() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
384 return new fj.F<P6<A, B, C, D, E, F$>, C>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
385 public C f(final P6<A, B, C, D, E, F$> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
386 return p._3();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
387 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
388 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
389 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
390
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
391 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
392 * Returns a function that returns the fourth element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
393 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
394 * @return A function that returns the fourth element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
395 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
396 public static <A, B, C, D, E, F$> fj.F<P6<A, B, C, D, E, F$>, D> __4() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
397 return new fj.F<P6<A, B, C, D, E, F$>, D>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
398 public D f(final P6<A, B, C, D, E, F$> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
399 return p._4();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
400 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
401 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
402 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
403
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
404 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
405 * Returns a function that returns the fifth element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
406 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
407 * @return A function that returns the fifth element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
408 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
409 public static <A, B, C, D, E, F$> fj.F<P6<A, B, C, D, E, F$>, E> __5() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
410 return new fj.F<P6<A, B, C, D, E, F$>, E>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
411 public E f(final P6<A, B, C, D, E, F$> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
412 return p._5();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
413 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
414 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
415 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
416
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
417 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
418 * Returns a function that returns the sixth element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
419 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
420 * @return A function that returns the sixth element of a product.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
421 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
422 public static <A, B, C, D, E, F$> fj.F<P6<A, B, C, D, E, F$>, F$> __6() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
423 return new fj.F<P6<A, B, C, D, E, F$>, F$>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
424 public F$ f(final P6<A, B, C, D, E, F$> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
425 return p._6();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
426 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
427 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
428 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
429
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
430 public String toString() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
431 return Show.p6Show(Show.<A>anyShow(), Show.<B>anyShow(), Show.<C>anyShow(), Show.<D>anyShow(), Show.<E>anyShow(), Show.<F>anyShow()).showS(this);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
432 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
433
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
434 }