diff options
-rwxr-xr-x | doc/tips/automatically_adding_metadata/pre-commit-annex | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/doc/tips/automatically_adding_metadata/pre-commit-annex b/doc/tips/automatically_adding_metadata/pre-commit-annex index f300bd731..fe818d032 100755 --- a/doc/tips/automatically_adding_metadata/pre-commit-annex +++ b/doc/tips/automatically_adding_metadata/pre-commit-annex @@ -1,6 +1,11 @@ #!/bin/sh +# # This script can be used to add git-annex metadata to files when they're -# committed. +# committed. It is typically installed as .git/hooks/pre-commit-annex +# +# You can also run this script by hand, passing it the names of files +# already checked into git-annex, and it will extract/refresh the git-annex +# metadata from the files. # # Copyright 2014 Joey Hess <id@joeyh.name> # License: GPL-3+ @@ -12,8 +17,6 @@ if [ -z "$want" ]; then exit 0 fi -echo "$want" - case "$(git config --bool metadata.overwrite || true)" in true) overwrite=1 @@ -46,7 +49,8 @@ fi IFS=" " -for f in $(git diff-index --name-only --cached $against); do + +process () { if [ -e "$f" ]; then for l in $(extract "$f" | egrep "$want"); do field="${l%% - *}" @@ -54,4 +58,14 @@ for f in $(git diff-index --name-only --cached $against); do addmeta "$f" "$field" "$value" done fi -done +} + +if [ -n "$*" ]; then + for f in $@; do + process "$f" + done +else + for f in $(git diff-index --name-only --cached $against); do + process "$f" + done +fi |