6fa28064b0
(slightly updated from the version posted to the GIT mailing list with small bugfixes). This patch changes the git-apply-patch-script to exit non-zero when the patch cannot be applied. Previously, the external diff driver deliberately ignored the exit status of GIT_EXTERNAL_DIFF command, which was a design mistake. It now stops the processing when GIT_EXTERNAL_DIFF exits non-zero, so the damages from running git-diff-* with git-apply-patch-script between two wrong trees can be contained. The "diff" command line generated by the built-in driver is changed to always exit 0 in order to match this new behaviour. I know Pasky does not use GIT_EXTERNAL_DIFF yet, so this change should not break Cogito, either. Signed-off-by: Junio C Hamano <junkio@cox.net>
70 lines
1.6 KiB
Bash
Executable File
70 lines
1.6 KiB
Bash
Executable File
#!/bin/sh
|
|
# Copyright (C) 2005 Junio C Hamano
|
|
#
|
|
# Applying diff between two trees to the work tree can be
|
|
# done with the following single command:
|
|
#
|
|
# GIT_EXTERNAL_DIFF=git-apply-patch-script git-diff-tree -p $tree1 $tree2
|
|
#
|
|
|
|
case "$#" in
|
|
2) exit 1 ;; # do not feed unmerged diff to me!
|
|
esac
|
|
name="$1" tmp1="$2" hex1="$3" mode1="$4" tmp2="$5" hex2="$6" mode2="$7"
|
|
case "$mode1" in *7??) mode1=+x ;; *6??) mode1=-x ;; esac
|
|
case "$mode2" in *7??) mode2=+x ;; *6??) mode2=-x ;; esac
|
|
|
|
if test -f "$name.orig" || test -f "$name.rej"
|
|
then
|
|
echo >&2 "Unresolved patch conflicts in the previous run found."
|
|
exit 1
|
|
fi
|
|
|
|
case "$mode1,$mode2" in
|
|
.,?x)
|
|
# newly created
|
|
dir=$(dirname "$name")
|
|
case "$dir" in '' | .) ;; *) mkdir -p "$dir" esac || {
|
|
echo >&2 "cannot create leading path for $name."
|
|
exit 1
|
|
}
|
|
case "$mode2" in
|
|
+x)
|
|
echo >&2 "created $name with mode +x."
|
|
chmod "$mode2" "$name"
|
|
;;
|
|
-x)
|
|
echo >&2 "created $name."
|
|
;;
|
|
esac
|
|
git-update-cache --add -- "$name"
|
|
;;
|
|
?x,.)
|
|
# deleted
|
|
echo >&2 "deleted $name."
|
|
rm -f "$name" || {
|
|
echo >&2 "cannot remove $name";
|
|
exit 1
|
|
}
|
|
git-update-cache --remove -- "$name"
|
|
;;
|
|
*)
|
|
# changed
|
|
dir=$(dirname "$name")
|
|
case "$dir" in '' | .) ;; *) mkdir -p "$dir" esac || {
|
|
echo >&2 "cannot create leading path for $name."
|
|
exit 1
|
|
}
|
|
# This will say "patching ..." so we do not say anything outselves.
|
|
diff -u -L "a/$name" -L "b/$name" "$tmp1" "$tmp2" | patch -p1 || exit
|
|
|
|
case "$mode1,$mode2" in
|
|
"$mode2,$mode1") ;;
|
|
*)
|
|
echo >&2 "changing mode from $mode1 to $mode2."
|
|
chmod "$mode2" "$name"
|
|
;;
|
|
esac
|
|
git-update-cache -- "$name"
|
|
esac
|