aboutsummaryrefslogtreecommitdiff
path: root/resources/src/main/java/org
diff options
context:
space:
mode:
authorChristian Williams <christianw@google.com>2017-11-07 13:16:01 -0800
committerChristian Williams <christianw@google.com>2017-11-07 13:16:08 -0800
commitc80e6a6e822ba6ea33f95fdc2fc068a2d9d74451 (patch)
treeb8cb8e45c3033c18330efbf1868614e1e18f9322 /resources/src/main/java/org
parentede3fe4bd1dd8d637cd02e8b7a2086daea5c59d9 (diff)
downloadrobolectric-shadows-c80e6a6e822ba6ea33f95fdc2fc068a2d9d74451.tar.gz
Simplify ResBundle.
Diffstat (limited to 'resources/src/main/java/org')
-rw-r--r--resources/src/main/java/org/robolectric/res/ResBundle.java23
1 files changed, 10 insertions, 13 deletions
diff --git a/resources/src/main/java/org/robolectric/res/ResBundle.java b/resources/src/main/java/org/robolectric/res/ResBundle.java
index 539c64278..a7b516bbc 100644
--- a/resources/src/main/java/org/robolectric/res/ResBundle.java
+++ b/resources/src/main/java/org/robolectric/res/ResBundle.java
@@ -1,7 +1,8 @@
package org.robolectric.res;
-import java.util.Collection;
+import java.util.ArrayList;
import java.util.HashMap;
+import java.util.List;
import java.util.Map;
import org.robolectric.res.android.ConfigDescription;
import org.robolectric.res.android.ResTable_config;
@@ -18,25 +19,23 @@ public class ResBundle {
}
public void receive(ResourceTable.Visitor visitor) {
- for (final Map.Entry<ResName, Map<String, TypedResource>> entry : valuesMap.map.entrySet()) {
- visitor.visit(entry.getKey(), entry.getValue().values());
+ for (final Map.Entry<ResName, List<TypedResource>> entry : valuesMap.map.entrySet()) {
+ visitor.visit(entry.getKey(), entry.getValue());
}
}
static class ResMap {
- private final Map<ResName, Map<String, TypedResource>> map = new HashMap<>();
+ private final Map<ResName, List<TypedResource>> map = new HashMap<>();
public TypedResource pick(ResName resName, String qualifiersStr) {
- Map<String, TypedResource> values = map.get(resName);
+ List<TypedResource> values = map.get(resName);
if (values == null || values.size() == 0) return null;
- Collection<TypedResource> typedResources = values.values();
-
ResTable_config toMatch = new ResTable_config();
new ConfigDescription().parse(qualifiersStr == null ? "" : qualifiersStr, toMatch);
TypedResource bestMatchSoFar = null;
- for (TypedResource candidate : typedResources) {
+ for (TypedResource candidate : values) {
ResTable_config candidateConfig = candidate.getConfig();
if (candidateConfig.match(toMatch)) {
if (bestMatchSoFar == null || candidateConfig.isBetterThan(bestMatchSoFar.getConfig(), toMatch)) {
@@ -49,11 +48,9 @@ public class ResBundle {
}
public void put(ResName resName, TypedResource value) {
- Map<String, TypedResource> values = map.get(resName);
- if (values == null) map.put(resName, values = new HashMap<>());
- if (!values.containsKey(value.getXmlContext().getQualifiers())) {
- values.put(value.getXmlContext().getQualifiers(), value);
- }
+ List<TypedResource> values = map.get(resName);
+ if (values == null) map.put(resName, values = new ArrayList<>());
+ values.add(value);
}
public int size() {