aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/main
diff options
context:
space:
mode:
authorGravatar John Cater <jcater@google.com>2017-08-01 01:17:02 +0200
committerGravatar Dmitry Lomov <dslomov@google.com>2017-08-01 12:22:00 +0200
commitaacc305ba5a2035155cdc9afc9a300c739282829 (patch)
treef4cfad7ae2743cb28e2c085f152be17d459a07d7 /src/main
parent53a87b9b9888092f28ce65c29a4beaef2e3cca7d (diff)
Update LocationExpander to properly handle spaces in filenames.
Also added basic tests. Change-Id: I5861816bf116486e0ee365debd3dfbda131047f7 PiperOrigin-RevId: 163764257
Diffstat (limited to 'src/main')
-rw-r--r--src/main/java/com/google/devtools/build/lib/analysis/LocationExpander.java30
1 files changed, 24 insertions, 6 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/analysis/LocationExpander.java b/src/main/java/com/google/devtools/build/lib/analysis/LocationExpander.java
index 1d068e03bf..689094a5a2 100644
--- a/src/main/java/com/google/devtools/build/lib/analysis/LocationExpander.java
+++ b/src/main/java/com/google/devtools/build/lib/analysis/LocationExpander.java
@@ -14,7 +14,8 @@
package com.google.devtools.build.lib.analysis;
-import com.google.common.base.Joiner;
+import static java.util.stream.Collectors.joining;
+
import com.google.common.collect.ImmutableCollection;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
@@ -35,6 +36,7 @@ import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.TreeSet;
+import java.util.stream.Stream;
/**
* Expands $(location) tags inside target attributes.
@@ -61,6 +63,7 @@ public class LocationExpander {
private static final int MAX_PATHS_SHOWN = 5;
private static final String LOCATION = "$(location";
+
private final RuleContext ruleContext;
private final ImmutableSet<Options> options;
@@ -194,11 +197,7 @@ public class LocationExpander {
Collection<String> paths = resolveLabel(label, message, multiple);
result.append(value, restart, start);
- if (multiple) {
- Joiner.on(' ').appendTo(result, paths);
- } else {
- result.append(Iterables.getOnlyElement(paths));
- }
+ appendPaths(result, paths, multiple);
} catch (IllegalStateException ise) {
reporter.report(ruleContext, ise.getMessage());
return value;
@@ -257,6 +256,25 @@ public class LocationExpander {
return paths;
}
+ private void appendPaths(StringBuilder result, Collection<String> paths, boolean multiple) {
+ Stream<String> stream = paths.stream();
+ if (!multiple) {
+ stream = stream.limit(1);
+ }
+
+ String pathString = stream.map(LocationExpander::quotePath).collect(joining(" "));
+
+ result.append(pathString);
+ }
+
+ private static String quotePath(String path) {
+ // TODO(jcater): Handle more cases where escaping is needed.
+ if (path.contains(" ")) {
+ path = "'" + path + "'";
+ }
+ return path;
+ }
+
/**
* Extracts all possible target locations from target specification.
*