Почему wdiff не работает с именованными каналами - PullRequest
4 голосов
/ 30 марта 2009

Почему я могу сделать это в bash:

$ diff -u <(echo -e "line1\nline2") <(echo -e "line1\nline3")
--- /dev/fd/63  2009-03-30 09:49:07.527272646 +0100
+++ /dev/fd/62  2009-03-30 09:49:07.527272646 +0100
@@ -1,2 +1,2 @@
 line1
-line2
+line3

т.е. Я могу использовать именованные каналы / процесс подстановки, чтобы получить различие небольшого куска текста. Однако, когда я пытаюсь сделать это с помощью wdiff, различий для слов, а не просто строк, я не получаю полезного вывода

wdiff <(echo -e "line1\nline2") <(echo -e "line1\nline3")
[--]{++}

ОБНОВЛЕНИЕ: похоже, что для этого существует отчет об ошибке в Ubuntu: https://bugs.launchpad.net/ubuntu/+source/wdiff/+bug/160912

Ответы [ 2 ]

9 голосов
/ 30 марта 2009

strace показывает, что wdiff stat s файлы (возможно, чтобы узнать их размер). Поскольку именованные каналы сообщают о размере 0, вероятно, предполагается, что оба файла пусты и поэтому равны:

$ strace -efile wdiff -1 <(echo -e "line1\nline2") <(echo -e "line1\nline3")
execve("/usr/bin/wdiff", ["wdiff", "-1", "/dev/fd/63", "/dev/fd/62"], [/* 44 vars */]) = 0
[snip uninteresting stuff]
stat64("/dev/fd/63", {st_mode=S_IFIFO|0600, st_size=0, ...}) = 0
open("/dev/fd/63", O_RDONLY)            = 3
open("/tmp/wdiff.MzPXmH", O_RDWR|O_CREAT|O_EXCL, 0600) = 4
stat64("/dev/fd/62", {st_mode=S_IFIFO|0600, st_size=0, ...}) = 0
open("/dev/fd/62", O_RDONLY)            = 4
open("/tmp/wdiff.5nma9j", O_RDWR|O_CREAT|O_EXCL, 0600) = 5
--- SIGCHLD (Child exited) @ 0 (0) ---
unlink("/tmp/wdiff.MzPXmH")             = 0
unlink("/tmp/wdiff.5nma9j")             = 0
{++}Process 27699 detached

Редактировать: также обратите внимание, что bash может использовать имена файлов в стиле /dev/fd вместо именованных каналов, если ядро ​​его поддерживает (последние делают, пример выше показывает это), но эффект в значительной степени тот же.

0 голосов
/ 30 марта 2009

Я думаю, что wdiff не работает.

...