From 61403d0707ccd101a5635e1ef3d97296ba318bc1 Mon Sep 17 00:00:00 2001 From: "bazel.build machine account" <15028808+bazel-io@users.noreply.github.com> Date: Mon, 25 Sep 2023 17:48:44 -0400 Subject: [PATCH] [6.4.0] Use case-insensitive comparison for Windows paths in `runfiles.bash` (#19626) When matching paths or path segments in the Bash runfiles library, use a case-insensitive comparison when running in MSYS2 as Bazel emits paths that can be capitalized differently. In particular, this fixes failures when the output base path contains uppercase letters. Closes #19602. Commit https://github.com/bazelbuild/bazel/commit/ea4ab7d8e696f48253fd172fcfbd37661e4710d5 PiperOrigin-RevId: 568323218 Change-Id: Ic4655b82b1acbaa9ed50118913d713fba3d7f5de Co-authored-by: Fabian Meumertzheim --- tools/bash/runfiles/runfiles.bash | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/tools/bash/runfiles/runfiles.bash b/tools/bash/runfiles/runfiles.bash index d6e142b8d4690e..a1406816c4564d 100644 --- a/tools/bash/runfiles/runfiles.bash +++ b/tools/bash/runfiles/runfiles.bash @@ -98,16 +98,21 @@ case "$(uname -s | tr [:upper:] [:lower:])" in msys*|mingw*|cygwin*) # matches an absolute Windows path export _RLOCATION_ISABS_PATTERN="^[a-zA-Z]:[/\\]" + # Windows paths are case insensitive and Bazel and MSYS2 capitalize differently, so we can't + # assume that all paths are in the same native case. + export _RLOCATION_GREP_CASE_INSENSITIVE_ARGS=-i ;; *) # matches an absolute Unix path export _RLOCATION_ISABS_PATTERN="^/[^/].*" + export _RLOCATION_GREP_CASE_INSENSITIVE_ARGS= ;; esac -# Does not exit with a non-zero exit code if no match is found. +# Does not exit with a non-zero exit code if no match is found and performs a case-insensitive +# search on Windows. function __runfiles_maybe_grep() { - grep "$@" || test $? = 1; + grep $_RLOCATION_GREP_CASE_INSENSITIVE_ARGS "$@" || test $? = 1; } export -f __runfiles_maybe_grep @@ -251,8 +256,13 @@ function runfiles_current_repository() { # If the runfiles directory exists, check if the caller's path is of the form # $RUNFILES_DIR/rlocation_path and if so, set $rlocation_path. if [[ -z "$rlocation_path" && -d "${RUNFILES_DIR:-/dev/null}" ]]; then - local -r normalized_caller_path="$(echo "$caller_path" | sed 's|\\\\*|/|g')" - local -r normalized_dir="$(echo "${RUNFILES_DIR%[\/]}" | sed 's|\\\\*|/|g')" + normalized_caller_path="$(echo "$caller_path" | sed 's|\\\\*|/|g')" + normalized_dir="$(echo "${RUNFILES_DIR%[\/]}" | sed 's|\\\\*|/|g')" + if [[ -n "${_RLOCATION_GREP_CASE_INSENSITIVE_ARGS}" ]]; then + # When comparing file paths insensitively, also normalize the case of the prefixes. + normalized_caller_path=$(echo "$normalized_caller_path" | tr '[:upper:]' '[:lower:]') + normalized_dir=$(echo "$normalized_dir" | tr '[:upper:]' '[:lower:]') + fi if [[ "$normalized_caller_path" == "$normalized_dir"/* ]]; then rlocation_path=${normalized_caller_path:${#normalized_dir}} rlocation_path=${rlocation_path:1}