如何在 ed 中使用 diff3
How to use diff3 with ed
如何将diff3
与ed
一起使用?我下面的尝试与 diff3 --merge
输出不匹配,所以我一定是做错了什么。
上下文:我已经将 OpenBSD 的 diff3prog.c 实用程序移植到 BusyBox 中使用,它有 diff
和 ed
.
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
.
如何将diff3
与ed
一起使用?我下面的尝试与 diff3 --merge
输出不匹配,所以我一定是做错了什么。
上下文:我已经将 OpenBSD 的 diff3prog.c 实用程序移植到 BusyBox 中使用,它有 diff
和 ed
.
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
.