8b64647dd9
The parsing code had a bug that failed to recognize an incomplete line at the end of a fragment, and the fragment application code had a comparison bug to recognize such. Fix them to handle incomplete lines correctly. Add a test script for patches with various combinations of complete and incomplete lines to make sure the fix works. Signed-off-by: Junio C Hamano <junkio@cox.net> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
33 lines
636 B
Bash
Executable File
33 lines
636 B
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# Copyright (c) 2005 Junio C Hamano
|
|
#
|
|
|
|
test_description='git-apply should handle files with incomplete lines.
|
|
|
|
'
|
|
. ./test-lib.sh
|
|
|
|
# setup
|
|
|
|
(echo a; echo b) >frotz.0
|
|
(echo a; echo b; echo c) >frotz.1
|
|
(echo a; echo b | tr -d '\012') >frotz.2
|
|
(echo a; echo c; echo b | tr -d '\012') >frotz.3
|
|
|
|
for i in 0 1 2 3
|
|
do
|
|
for j in 0 1 2 3
|
|
do
|
|
test $i -eq $j && continue
|
|
diff -u frotz.$i frotz.$j |
|
|
sed -e '
|
|
/^---/s|.*|--- a/frotz|
|
|
/^+++/s|.*|+++ b/frotz|' >diff.$i-$j
|
|
cat frotz.$i >frotz
|
|
test_expect_success \
|
|
"apply diff between $i and $j" \
|
|
"git-apply <diff.$i-$j && diff frotz.$j frotz"
|
|
done
|
|
done
|