annotate src/main/java/fj/Show.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 import fj.data.Array;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
4 import fj.data.Either;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
5 import fj.data.LazyString;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
6 import fj.data.List;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
7 import fj.data.Natural;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
8 import fj.data.NonEmptyList;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
9 import fj.data.Option;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
10 import fj.data.Stream;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
11 import fj.data.Tree;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
12 import fj.data.Validation;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
13 import fj.data.hlist.HList;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
14 import fj.data.vector.V2;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
15 import fj.data.vector.V3;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
16 import fj.data.vector.V4;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
17 import fj.data.vector.V5;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
18 import fj.data.vector.V6;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
19 import fj.data.vector.V7;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
20 import fj.data.vector.V8;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
21
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
22 import java.math.BigDecimal;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
23 import java.math.BigInteger;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
24
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
25 import static fj.Function.compose;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
26 import static fj.P.p;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
27 import static fj.Unit.unit;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
28 import static fj.data.Stream.cons;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
29 import static fj.data.Stream.fromString;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
30 import static fj.data.Stream.join;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
31 import static fj.data.Stream.nil;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
32 import static fj.data.Stream.single;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
33
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
34 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
35 * Renders an object for display.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
36 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
37 * @version %build.number%
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
38 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
39 public final class Show<A> {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
40 private final F<A, Stream<Character>> f;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
41
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
42 private Show(final F<A, Stream<Character>> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
43 this.f = f;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
44 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
45
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
46 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
47 * Maps the given function across this show as a contra-variant functor.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
48 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
49 * @param f The function to map.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
50 * @return A new show.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
51 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
52 public <B> Show<B> comap(final F<B, A> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
53 return show(compose(this.f, f));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
54 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
55
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
56 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
57 * Returns the display rendering of the given argument.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
58 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
59 * @param a The argument to display.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
60 * @return The display rendering of the given argument.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
61 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
62 public Stream<Character> show(final A a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
63 return f.f(a);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
64 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
65
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
66 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
67 * Returns the display rendering of the given argument.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
68 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
69 * @param a The argument to display.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
70 * @return The display rendering of the given argument.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
71 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
72 public List<Character> showl(final A a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
73 return show(a).toList();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
74 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
75
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
76 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
77 * Returns the display rendering of the given argument as a <code>String</code>.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
78 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
79 * @param a The argument to display.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
80 * @return The display rendering of the given argument as a <code>String</code>.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
81 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
82 public String showS(final A a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
83 return Stream.asString(show(a));
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 * Returns the transformation equivalent to this show.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
88 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
89 * @return the transformation equivalent to this show.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
90 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
91 public F<A, String> showS_() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
92 return new F<A, String>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
93 public String f(final A a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
94 return showS(a);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
95 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
96 };
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
97 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
98
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
99 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
100 * Returns the transformation equivalent to this show.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
101 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
102 * @return the transformation equivalent to this show.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
103 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
104 public F<A, Stream<Character>> show_() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
105 return f;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
106 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
107
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
108 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
109 * Prints the given argument to the standard output stream with a new line.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
110 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
111 * @param a The argument to print.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
112 * @return The unit value.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
113 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
114 public Unit println(final A a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
115 print(a);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
116 System.out.println();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
117 return unit();
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 * Prints the given argument to the standard output stream.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
122 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
123 * @param a The argument to print.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
124 * @return The unit value.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
125 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
126 public Unit print(final A a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
127 final char[] buffer = new char[8192];
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
128 int c = 0;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
129 for (Stream<Character> cs = show(a); cs.isNotEmpty(); cs = cs.tail()._1()) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
130 buffer[c] = cs.head();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
131 c++;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
132 if (c == 8192) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
133 System.out.print(buffer);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
134 c = 0;
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
135 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
136 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
137 System.out.print(Array.copyOfRange(buffer, 0, c));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
138 return unit();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
139 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
140
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
141 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
142 * Prints the given argument to the standard error stream with a new line.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
143 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
144 * @param a The argument to print.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
145 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
146 public void printlnE(final A a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
147 System.err.println(showS(a));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
148 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
149
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
150 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
151 * Returns a show instance using the given function.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
152 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
153 * @param f The function to use for the returned show instance.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
154 * @return A show instance.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
155 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
156 public static <A> Show<A> show(final F<A, Stream<Character>> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
157 return new Show<A>(f);
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
158 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
159
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
160 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
161 * Returns a show instance using the given function.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
162 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
163 * @param f The function to use for the returned show instance.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
164 * @return A show instance.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
165 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
166 public static <A> Show<A> showS(final F<A, String> f) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
167 return new Show<A>(new F<A, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
168 public Stream<Character> f(final A a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
169 return fromString(f.f(a));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
170 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
171 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
172 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
173
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
174 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
175 * Returns a show instance that uses {@link Object#toString()} to perform the display rendering.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
176 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
177 * @return A show instance that uses {@link Object#toString()} to perform the display rendering.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
178 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
179 public static <A> Show<A> anyShow() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
180 return new Show<A>(new F<A, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
181 public Stream<Character> f(final A a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
182 return Stream.fromString((a == null) ? "null" : a.toString());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
183 }
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 * A show instance for the <code>boolean</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
189 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
190 public static final Show<Boolean> booleanShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
191
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
192 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
193 * A show instance for the <code>byte</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
194 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
195 public static final Show<Byte> byteShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
196
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
197 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
198 * A show instance for the <code>char</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
199 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
200 public static final Show<Character> charShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
201
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
202 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
203 * A show instance for the <code>double</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
204 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
205 public static final Show<Double> doubleShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
206
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
207 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
208 * A show instance for the <code>float</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
209 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
210 public static final Show<Float> floatShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
211
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
212 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
213 * A show instance for the <code>int</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
214 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
215 public static final Show<Integer> intShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
216
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
217 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
218 * A show instance for the <code>BigInteger</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
219 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
220 public static final Show<BigInteger> bigintShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
221
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
222 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
223 * A show instance for the <code>BigDecimal</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
224 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
225 public static final Show<BigDecimal> bigdecimalShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
226
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
227 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
228 * A show instance for the <code>long</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
229 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
230 public static final Show<Long> longShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
231
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
232 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
233 * A show instance for the <code>short</code> type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
234 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
235 public static final Show<Short> shortShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
236
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
237 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
238 * A show instance for the {@link String} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
239 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
240 public static final Show<String> stringShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
241
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
242 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
243 * A show instance for the {@link StringBuffer} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
244 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
245 public static final Show<StringBuffer> stringBufferShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
246
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
247 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
248 * A show instance for the {@link StringBuilder} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
249 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
250 public static final Show<StringBuilder> stringBuilderShow = anyShow();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
251
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
252 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
253 * A show instance for the {@link Option} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
254 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
255 * @param sa Show for the element of the option.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
256 * @return A show instance for the {@link Option} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
257 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
258 public static <A> Show<Option<A>> optionShow(final Show<A> sa) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
259 return new Show<Option<A>>(new F<Option<A>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
260 public Stream<Character> f(final Option<A> o) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
261 return o.isNone() ?
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
262 fromString("None") :
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
263 fromString("Some(").append(sa.f.f(o.some())).append(single(')'));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
264 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
265 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
266 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
267
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
268 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
269 * A show instance for the {@link Either} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
270 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
271 * @param sa Show for the left side of the {@link Either}.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
272 * @param sb Show for the right side of the {@link Either}.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
273 * @return A show instance for the {@link Either} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
274 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
275 public static <A, B> Show<Either<A, B>> eitherShow(final Show<A> sa, final Show<B> sb) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
276 return new Show<Either<A, B>>(new F<Either<A, B>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
277 public Stream<Character> f(final Either<A, B> e) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
278 return e.isLeft() ?
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
279 fromString("Left(").append(sa.f.f(e.left().value())).append(single(')')) :
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
280 fromString("Right(").append(sb.f.f(e.right().value())).append(single(')'));
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
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
285 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
286 * A show instance for the {@link Validation} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
287 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
288 * @param sa Show for the fail side of the {@link Validation}.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
289 * @param sb Show for the success side of the {@link Validation}.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
290 * @return A show instance for the {@link Validation} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
291 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
292 public static <A, B> Show<Validation<A, B>> validationShow(final Show<A> sa, final Show<B> sb) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
293 return new Show<Validation<A, B>>(new F<Validation<A, B>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
294 public Stream<Character> f(final Validation<A, B> v) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
295 return v.isFail() ?
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
296 fromString("Fail(").append(sa.f.f(v.fail())).append(single(')')) :
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
297 fromString("Success(").append(sb.f.f(v.success())).append(single(')'));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
298 }
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 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
303 * A show instance for the {@link Stream} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
304 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
305 * @param sa Show for the elements of the Stream.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
306 * @return A show instance for the {@link Stream} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
307 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
308 public static <A> Show<List<A>> listShow(final Show<A> sa) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
309 return new Show<List<A>>(new F<List<A>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
310 public Stream<Character> f(final List<A> as) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
311 return streamShow(sa).show(as.toStream());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
312 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
313 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
314 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
315
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
316 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
317 * A show instance for the {@link NonEmptyList} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
318 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
319 * @param sa Show for the elements of the non-empty Stream.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
320 * @return A show instance for the {@link NonEmptyList} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
321 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
322 public static <A> Show<NonEmptyList<A>> nonEmptyListShow(final Show<A> sa) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
323 return listShow(sa).comap(NonEmptyList.<A>toList_());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
324 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
325
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
326 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
327 * A show instance for the {@link Tree} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
328 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
329 * @param sa Show for the elements of the tree.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
330 * @return A show instance for the {@link Tree} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
331 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
332 public static <A> Show<Tree<A>> treeShow(final Show<A> sa) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
333 return new Show<Tree<A>>(new F<Tree<A>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
334 public Stream<Character> f(final Tree<A> a) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
335 final Stream<Character> b = sa.f.f(a.root())
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
336 .append(p1Show(streamShow(treeShow(sa))).f.f(a.subForest()))
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
337 .snoc(')');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
338 return cons('(', p(b));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
339 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
340 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
341 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
342
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
343 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
344 * A show instance for the {@link Stream} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
345 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
346 * @param sa Show for the elements of the stream.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
347 * @return A show instance for the {@link Stream} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
348 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
349 public static <A> Show<Stream<A>> streamShow(final Show<A> sa) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
350 return new Show<Stream<A>>(new F<Stream<A>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
351 public Stream<Character> f(final Stream<A> as) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
352 return join(as.map(sa.show_()).intersperse(fromString(",")).cons(fromString("<")).snoc(p(fromString(">"))));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
353 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
354 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
355 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
356
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
357 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
358 * A show instance for the {@link Array} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
359 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
360 * @param sa Show for the elements of the array.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
361 * @return A show instance for the {@link Array} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
362 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
363 public static <A> Show<Array<A>> arrayShow(final Show<A> sa) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
364 return new Show<Array<A>>(new F<Array<A>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
365 public Stream<Character> f(final Array<A> as) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
366 Stream<Character> b = nil();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
367
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
368 for (int i = 0; i < as.length(); i++) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
369 b = b.append(sa.f.f(as.get(i)));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
370
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
371 if (i != as.length() - 1)
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
372 b = b.snoc(',');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
373 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
374
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
375 b = b.snoc('}');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
376
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
377 return cons('{', p(b));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
378 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
379 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
380 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
381
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
382 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
383 * A show instance for the {@link Class} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
384 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
385 * @return A show instance for the {@link Class} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
386 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
387 public static <A> Show<Class<A>> classShow() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
388 return new Show<Class<A>>(new F<fj.Class<A>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
389 public Stream<Character> f(final Class<A> c) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
390 return anyShow().show(c.clas());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
391 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
392 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
393 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
394
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
395 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
396 * A show instance for the {@link P1 tuple-1} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
397 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
398 * @param sa Show for the first element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
399 * @return A show instance for the {@link P1 tuple-1} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
400 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
401 public static <A> Show<P1<A>> p1Show(final Show<A> sa) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
402 return new Show<P1<A>>(new F<P1<A>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
403 public Stream<Character> f(final P1<A> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
404 return cons('(', p(sa.show(p._1()))).snoc(')');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
405 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
406 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
407 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
408
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
409 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
410 * A show instance for the {@link P2 tuple-2} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
411 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
412 * @param sa Show for the first element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
413 * @param sb Show for the second element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
414 * @return A show instance for the {@link P2 tuple-2} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
415 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
416 public static <A, B> Show<P2<A, B>> p2Show(final Show<A> sa, final Show<B> sb) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
417 return new Show<P2<A, B>>(new F<P2<A, B>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
418 public Stream<Character> f(final P2<A, B> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
419 return cons('(', p(sa.show(p._1()))).snoc(',').append(sb.show(p._2())).snoc(')');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
420 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
421 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
422 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
423
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
424 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
425 * A show instance for the {@link P3 tuple-3} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
426 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
427 * @param sa Show for the first element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
428 * @param sb Show for the second element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
429 * @param sc Show for the third element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
430 * @return A show instance for the {@link P3 tuple-3} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
431 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
432 public static <A, B, C> Show<P3<A, B, C>> p3Show(final Show<A> sa, final Show<B> sb, final Show<C> sc) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
433 return new Show<P3<A, B, C>>(new F<P3<A, B, C>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
434 public Stream<Character> f(final P3<A, B, C> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
435 return cons('(', p(sa.show(p._1()))).snoc(',').append(sb.show(p._2())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
436 .append(sc.show(p._3())).snoc(')');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
437 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
438 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
439 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
440
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
441 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
442 * A show instance for the {@link P4 tuple-4} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
443 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
444 * @param sa Show for the first element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
445 * @param sb Show for the second element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
446 * @param sc Show for the third element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
447 * @param sd Show for the fourth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
448 * @return A show instance for the {@link P4 tuple-4} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
449 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
450 public static <A, B, C, D> Show<P4<A, B, C, D>> p4Show(final Show<A> sa, final Show<B> sb,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
451 final Show<C> sc, final Show<D> sd) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
452 return new Show<P4<A, B, C, D>>(new F<P4<A, B, C, D>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
453 public Stream<Character> f(final P4<A, B, C, D> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
454 return cons('(', p(sa.show(p._1()))).snoc(',').append(sb.show(p._2())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
455 .append(sc.show(p._3())).snoc(',').append(sd.show(p._4())).snoc(')');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
456 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
457 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
458 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
459
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
460 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
461 * A show instance for the {@link P5 tuple-5} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
462 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
463 * @param sa Show for the first element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
464 * @param sb Show for the second element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
465 * @param sc Show for the third element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
466 * @param sd Show for the fourth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
467 * @param se Show for the fifth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
468 * @return A show instance for the {@link P5 tuple-5} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
469 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
470 public static <A, B, C, D, E> Show<P5<A, B, C, D, E>> p5Show(final Show<A> sa, final Show<B> sb,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
471 final Show<C> sc, final Show<D> sd, final Show<E> se) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
472 return new Show<P5<A, B, C, D, E>>(new F<P5<A, B, C, D, E>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
473 public Stream<Character> f(final P5<A, B, C, D, E> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
474 return cons('(', p(sa.show(p._1()))).snoc(',').append(sb.show(p._2())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
475 .append(sc.show(p._3())).snoc(',').append(sd.show(p._4())).snoc(',').append(se.show(p._5())).snoc(')');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
476 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
477 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
478 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
479
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
480 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
481 * A show instance for the {@link P6 tuple-6} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
482 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
483 * @param sa Show for the first element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
484 * @param sb Show for the second element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
485 * @param sc Show for the third element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
486 * @param sd Show for the fourth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
487 * @param se Show for the fifth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
488 * @param sf Show for the sixth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
489 * @return A show instance for the {@link P6 tuple-6} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
490 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
491 public static <A, B, C, D, E, F$> Show<P6<A, B, C, D, E, F$>> p6Show(final Show<A> sa, final Show<B> sb,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
492 final Show<C> sc, final Show<D> sd,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
493 final Show<E> se, final Show<F$> sf) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
494 return new Show<P6<A, B, C, D, E, F$>>(new F<P6<A, B, C, D, E, F$>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
495 public Stream<Character> f(final P6<A, B, C, D, E, F$> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
496 return cons('(', p(sa.show(p._1()))).snoc(',').append(sb.show(p._2())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
497 .append(sc.show(p._3())).snoc(',').append(sd.show(p._4())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
498 .append(se.show(p._5())).snoc(',').append(sf.show(p._6())).snoc(')');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
499 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
500 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
501 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
502
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
503 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
504 * A show instance for the {@link P7 tuple-7} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
505 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
506 * @param sa Show for the first element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
507 * @param sb Show for the second element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
508 * @param sc Show for the third element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
509 * @param sd Show for the fourth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
510 * @param se Show for the fifth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
511 * @param sf Show for the sixth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
512 * @param sg Show for the seventh element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
513 * @return A show instance for the {@link P7 tuple-7} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
514 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
515 public static <A, B, C, D, E, F$, G> Show<P7<A, B, C, D, E, F$, G>> p7Show(final Show<A> sa, final Show<B> sb,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
516 final Show<C> sc, final Show<D> sd,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
517 final Show<E> se, final Show<F$> sf,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
518 final Show<G> sg) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
519 return new Show<P7<A, B, C, D, E, F$, G>>(new F<P7<A, B, C, D, E, F$, G>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
520 public Stream<Character> f(final P7<A, B, C, D, E, F$, G> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
521 return cons('(', p(sa.show(p._1()))).snoc(',').append(sb.show(p._2())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
522 .append(sc.show(p._3())).snoc(',').append(sd.show(p._4())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
523 .append(se.show(p._5())).snoc(',').append(sf.show(p._6())).snoc(',').append(sg.show(p._7())).snoc(')');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
524 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
525 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
526 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
527
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
528 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
529 * A show instance for the {@link P8 tuple-8} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
530 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
531 * @param sa Show for the first element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
532 * @param sb Show for the second element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
533 * @param sc Show for the third element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
534 * @param sd Show for the fourth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
535 * @param se Show for the fifth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
536 * @param sf Show for the sixth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
537 * @param sg Show for the seventh element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
538 * @param sh Show for the eighth element of the tuple.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
539 * @return A show instance for the {@link P8 tuple-8} type.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
540 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
541 public static <A, B, C, D, E, F$, G, H> Show<P8<A, B, C, D, E, F$, G, H>> p8Show(final Show<A> sa, final Show<B> sb,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
542 final Show<C> sc, final Show<D> sd,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
543 final Show<E> se, final Show<F$> sf,
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
544 final Show<G> sg, final Show<H> sh) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
545 return new Show<P8<A, B, C, D, E, F$, G, H>>(new F<P8<A, B, C, D, E, F$, G, H>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
546 public Stream<Character> f(final P8<A, B, C, D, E, F$, G, H> p) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
547 return cons('(', p(sa.show(p._1()))).snoc(',').append(sb.show(p._2())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
548 .append(sc.show(p._3())).snoc(',').append(sd.show(p._4())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
549 .append(se.show(p._5())).snoc(',').append(sf.show(p._6())).snoc(',')
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
550 .append(sg.show(p._7())).snoc(',').append(sh.show(p._8())).snoc(')');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
551 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
552 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
553 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
554
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
555 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
556 * A show instance for a vector-2.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
557 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
558 * @param ea A show for the elements of the vector.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
559 * @return A show instance for a vector-2.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
560 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
561 public static <A> Show<V2<A>> v2Show(final Show<A> ea) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
562 return streamShow(ea).comap(V2.<A>toStream_());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
563 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
564
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
565 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
566 * A show instance for a vector-3.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
567 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
568 * @param ea A show for the elements of the vector.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
569 * @return A show instance for a vector-3.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
570 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
571 public static <A> Show<V3<A>> v3Show(final Show<A> ea) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
572 return streamShow(ea).comap(V3.<A>toStream_());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
573 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
574
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
575 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
576 * A show instance for a vector-4.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
577 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
578 * @param ea A show for the elements of the vector.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
579 * @return A show instance for a vector-4.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
580 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
581 public static <A> Show<V4<A>> v4Show(final Show<A> ea) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
582 return streamShow(ea).comap(V4.<A>toStream_());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
583 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
584
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
585 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
586 * A show instance for a vector-5.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
587 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
588 * @param ea A show for the elements of the vector.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
589 * @return A show instance for a vector-5.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
590 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
591 public static <A> Show<V5<A>> v5Show(final Show<A> ea) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
592 return streamShow(ea).comap(V5.<A>toStream_());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
593 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
594
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
595 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
596 * A show instance for a vector-6.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
597 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
598 * @param ea A show for the elements of the vector.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
599 * @return A show instance for a vector-6.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
600 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
601 public static <A> Show<V6<A>> v6Show(final Show<A> ea) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
602 return streamShow(ea).comap(V6.<A>toStream_());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
603 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
604
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
605 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
606 * A show instance for a vector-7.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
607 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
608 * @param ea A show for the elements of the vector.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
609 * @return A show instance for a vector-7.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
610 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
611 public static <A> Show<V7<A>> v7Show(final Show<A> ea) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
612 return streamShow(ea).comap(V7.<A>toStream_());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
613 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
614
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
615 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
616 * A show instance for a vector-8.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
617 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
618 * @param ea A show for the elements of the vector.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
619 * @return A show instance for a vector-8.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
620 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
621 public static <A> Show<V8<A>> v8Show(final Show<A> ea) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
622 return streamShow(ea).comap(V8.<A>toStream_());
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
623 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
624
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
625 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
626 * A show instance for natural numbers.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
627 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
628 public static final Show<Natural> naturalShow = bigintShow.comap(new F<Natural, BigInteger>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
629 public BigInteger f(final Natural natural) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
630 return natural.bigIntegerValue();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
631 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
632 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
633
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
634 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
635 * A show instance for streams that splits into lines.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
636 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
637 * @param sa A show instance for the elements of a stream.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
638 * @return A show instance for streams that splits into lines.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
639 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
640 public static <A> Show<Stream<A>> unlineShow(final Show<A> sa) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
641 return new Show<Stream<A>>(new F<Stream<A>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
642 public Stream<Character> f(final Stream<A> as) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
643 return join(as.map(sa.show_()).intersperse(fromString("\n")));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
644 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
645 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
646 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
647
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
648 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
649 * A show instance for lazy strings.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
650 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
651 public static final Show<LazyString> lazyStringShow = show(new F<LazyString, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
652 public Stream<Character> f(final LazyString string) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
653 return string.toStream();
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
654 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
655 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
656
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
657 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
658 * A show instance for the empty heterogeneous Stream.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
659 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
660 public static final Show<HList.HNil> HListShow = showS(Function.<HList.HNil, String>constant("Nil"));
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
661
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
662 /**
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
663 * A show instance for heterogeneous Streams.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
664 *
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
665 * @param e A show instance for the first element of the Stream.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
666 * @param l A show instance for the rest of the Stream.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
667 * @return a show instance for heterogeneous Streams.
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
668 */
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
669 public static <E, L extends HList<L>> Show<HList.HCons<E, L>> HListShow(final Show<E> e, final Show<L> l) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
670 return show(new F<HList.HCons<E, L>, Stream<Character>>() {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
671 public Stream<Character> f(final HList.HCons<E, L> c) {
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
672 return e.show(c.head()).cons('[').append(l.show(c.tail())).snoc(']');
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
673 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
674 });
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
675 }
fe80c1edf1be add getLoop
tatsuki
parents:
diff changeset
676 }