forked from jooby-project/jooby
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathArrayValue.java
More file actions
125 lines (101 loc) · 3.09 KB
/
ArrayValue.java
File metadata and controls
125 lines (101 loc) · 3.09 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
/**
* Jooby https://jooby.io
* Apache License Version 2.0 https://jooby.io/LICENSE.txt
* Copyright 2014 Edgar Espina
*/
package io.jooby.internal;
import io.jooby.Context;
import io.jooby.exception.MissingValueException;
import io.jooby.exception.TypeMismatchException;
import io.jooby.ValueNode;
import javax.annotation.Nonnull;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Iterator;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
public class ArrayValue implements ValueNode {
private final Context ctx;
private final String name;
private final List<ValueNode> list = new ArrayList<>(5);
public ArrayValue(Context ctx, String name) {
this.ctx = ctx;
this.name = name;
}
@Override public String name() {
return name;
}
public ArrayValue add(ValueNode value) {
this.list.add(value);
return this;
}
public ArrayValue add(List<String> values) {
for (String value : values) {
add(value);
}
return this;
}
public ArrayValue add(String value) {
return this.add(new SingleValue(ctx, name, value));
}
@Override public ValueNode get(@Nonnull int index) {
try {
return list.get(index);
} catch (IndexOutOfBoundsException x) {
return new MissingValue(name + "[" + index + "]");
}
}
@Override public ValueNode get(@Nonnull String name) {
return new MissingValue(this.name + "." + name);
}
@Override public int size() {
return list.size();
}
@Override public String value() {
String name = name();
throw new TypeMismatchException(name == null ? getClass().getSimpleName() : name, String.class);
}
@Override public String toString() {
return list.toString();
}
@Override public Iterator<ValueNode> iterator() {
return list.iterator();
}
@Nonnull @Override public <T> T to(@Nonnull Class<T> type) {
return ctx.convert(list.get(0), type);
}
@Nonnull @Override public <T> List<T> toList(@Nonnull Class<T> type) {
return collect(new ArrayList<>(this.list.size()), type);
}
@Nonnull @Override public <T> Optional<T> toOptional(@Nonnull Class<T> type) {
try {
return Optional.ofNullable(to(type));
} catch (MissingValueException x) {
return Optional.empty();
}
}
@Nonnull @Override public <T> Set<T> toSet(@Nonnull Class<T> type) {
return collect(new LinkedHashSet<>(this.list.size()), type);
}
@Override public Map<String, List<String>> toMultimap() {
List<String> values = new ArrayList<>();
list.stream().forEach(it -> it.toMultimap().values().forEach(values::addAll));
return Collections.singletonMap(name, values);
}
@Override public List<String> toList() {
return collect(new ArrayList<>(), String.class);
}
@Override public Set<String> toSet() {
return collect(new LinkedHashSet<>(), String.class);
}
private <T, C extends Collection<T>> C collect(C collection, Class<T> type) {
for (ValueNode node : list) {
collection.add(node.to(type));
}
return collection;
}
}