From aacc305ba5a2035155cdc9afc9a300c739282829 Mon Sep 17 00:00:00 2001 From: John Cater Date: Tue, 1 Aug 2017 01:17:02 +0200 Subject: Update LocationExpander to properly handle spaces in filenames. Also added basic tests. Change-Id: I5861816bf116486e0ee365debd3dfbda131047f7 PiperOrigin-RevId: 163764257 --- .../build/lib/analysis/LocationExpander.java | 30 +++++++++++++++++----- 1 file changed, 24 insertions(+), 6 deletions(-) (limited to 'src/main') 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; @@ -194,11 +197,7 @@ public class LocationExpander { Collection 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 paths, boolean multiple) { + Stream 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. * -- cgit v1.2.3