如何将diff3
与ed
一起使用?我下面的尝试与diff3 --merge
输出不匹配,所以我一定做错了什么。
上下文:我已经移植了OpenBSD的diff3prog.c实用程序,以便在具有diff
和ed
的BusyBox中使用。
cat <<- EOF > parent.txt
1
2
3
EOF
cat <<- EOF > ours.txt
1
2
3
EOF
cat <<- EOF > theirs.txt
1
2
3
4
EOF
f1=ours.txt
f2=parent.txt
f3=theirs.txt
diff3 --merge $f1 $f2 $f3 > merged_good.txt
diff3 -E $f1 $f2 $f3 | ed $f1
#prints:
#6
#?
mv $f1 merged_bad.txt
cat merged_good.txt
#prints:
#1
#2
#3
#4
cat merged_bad.txt
#prints:
#1
#2
#3
(最初我在上面的评论中发布了这个。没有人添加任何进一步的上下文,但问题已经解决,所以我也将其作为答案添加(
似乎diff3
输出未命中w
ed
命令。因此,要获得预期的输出,应该使用(diff3 -E $f1 $f2 $f3; echo w) | ed $f1
。