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.
This commit is contained in:
Lucas De Marchi 2015-08-15 20:13:55 -03:00 committed by Andrew Tridgell
parent 29740ccb8a
commit 1f90d43c57

View File

@ -9,7 +9,7 @@ arg_create_commits=false
usage(){ usage(){
cat <<EOF cat <<EOF
Usage: $(basename $BASH_SOURCE) [-h|--help] Usage: $(basename $BASH_SOURCE) [OPTIONS] [--] [<pathspec>...]
Fix includes of libraries headers in source files to be as the following: 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 - If the header is outside the directory containing the source, then we use
the notation #include <> with the path relative to libraries folder. 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. The output is a log of the process.
Options: OPTIONS:
-h,--help -h,--help
Display this help message. Display this help message.
@ -174,10 +179,18 @@ while [[ -n $1 ]]; do
create_commits create_commits
exit $? exit $?
;; ;;
*) --)
# remaining args are pathspecs
shift
break
;;
-*)
usage >&2 usage >&2
exit 1 exit 1
;; ;;
*)
# this and the remaining args are pathspecs
break
esac esac
shift shift
done 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 printf "\r($((++i))/$total) Fixing includes for header %-${header_max_len}s" $header >&2
# for each file that includes $header # 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 fix_includes $f $header
done done
done done