From 1f90d43c57a6e5638a534cf1d0dfad188ce0d123 Mon Sep 17 00:00:00 2001 From: Lucas De Marchi Date: Sat, 15 Aug 2015 20:13:55 -0300 Subject: [PATCH] Tools: allow script to fixup a single file Instead of always trying to fix the entire tree, accept paths in the command line so it only fixes that paths. This allows to easily rebase a branch after the header changes, without touching the rest of the tree. --- Tools/scripts/fix_libraries_includes.sh | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/Tools/scripts/fix_libraries_includes.sh b/Tools/scripts/fix_libraries_includes.sh index d78638778b..8e3ac17f53 100755 --- a/Tools/scripts/fix_libraries_includes.sh +++ b/Tools/scripts/fix_libraries_includes.sh @@ -9,7 +9,7 @@ arg_create_commits=false usage(){ cat <...] Fix includes of libraries headers in source files to be as the following: @@ -20,9 +20,14 @@ Fix includes of libraries headers in source files to be as the following: - If the header is outside the directory containing the source, then we use the notation #include <> with the path relative to libraries folder. +If pathspec is given then it's an argument passed directly to git-grep. See +git-grep(1) for more information on its format. In this case the changes will +apply only to files that match the pathspec. Otherwise changes will be made to +the entire repository. + The output is a log of the process. -Options: +OPTIONS: -h,--help Display this help message. @@ -174,10 +179,18 @@ while [[ -n $1 ]]; do create_commits exit $? ;; - *) + --) + # remaining args are pathspecs + shift + break + ;; + -*) usage >&2 exit 1 ;; + *) + # this and the remaining args are pathspecs + break esac shift done @@ -215,7 +228,7 @@ for header in "${!header_dirs[@]}"; do printf "\r($((++i))/$total) Fixing includes for header %-${header_max_len}s" $header >&2 # for each file that includes $header - git grep -l $regex | while read f; do + git grep -l $regex -- "$@" | while read f; do fix_includes $f $header done done