1

我在 Emacs 配置中启用了 flymake。在本地它可以正常工作,但是当我尝试使用 tramp 打开远程 html 文件时,Emacs 挂起,我必须杀死它。

我尝试用gdb查看,栈顶如下:

#0  0x00007fcee786c83c in __pselect (nfds=<optimized out>, readfds=<optimized out>, writefds=<optimized out>, exceptfds=<optimized out>, timeout=<optimized out>, sigmask=<optimized out>)
at ../sysdeps/unix/sysv/linux/pselect.c:79
#1  0x00000000004d02f7 in xg_select (fds_lim=13, rfds=0x7fff4d830210, wfds=0x0, efds=0x0, timeout=0x7fff4d830460, sigmask=0x0) at xgselect.c:48
#2  0x00000000005947f3 in wait_reading_process_output (time_limit=<optimized out>, nsecs=0, read_kbd=0, do_display=false, wait_for_cell=12096626, wait_proc=<optimized out>, just_wait_proc=1) at process.c:4633
#3  0x0000000000597429 in Faccept_process_output (process=56383997, seconds=<optimized out>, millisec=<optimized out>, just_this_one=<optimized out>) at process.c:4026

所以似乎出于某种原因远程机器上的 xmlstarlet 进程,但我不知道为什么。

flymake 使用的命令应该是xmlstarlet val filename.html,从命令行执行没有问题。将 flymake 配置为使用 tidy 或 xmllint 等其他程序不会改变任何内容。

关于我可以做些什么来调试问题的任何建议?

编辑

事实上,在一段时间(至少 1 分钟)之后,命令完成。启动后不再等待相同的缓冲区,flymake 按预期工作。

系统详情

我正在从 Ubuntu 12.04 机器连接。我尝试连接到 FreeBSD 9.3 机器,但在 DragonflyBSD 机器上遇到了同样的问题。远程 shell 在两个系统上都是 zsh,但将其更改为 bash 并没有帮助。

堆栈跟踪

这是我得到的完整的 lisp 堆栈跟踪。

https://gist.github.com/mrighele/8371399

flymake-html-initemacs wiki中介绍的那个

有趣的是,当我发送信号时,文件缓冲区的内容被以下内容覆盖,不确定是否有任何兴趣。

tramp_perl_file_truename () {
function> \perl5 -e '
function quote> use File::Spec;
function quote> use Cwd "realpath";
function quote> sub recursive {
function quote>     my ($volume, @dirs) = @_;
function quote>     my $real = realpath(File::Spec->catpath(
function quote>                    $volume, File::Spec->catdir(@dirs), ""));
function quote>     if ($real) {
function quote>         my ($vol, $dir) = File::Spec->splitpath($real, 1);
function quote>         return ($vol, File::Spec->splitdir($dir));
function quote>     }
function quote>     else {
function quote>         my $last = pop(@dirs);
function quote>         ($volume, @dirs) = recursive($volume, @dirs);
function quote>         push(@dirs, $last);
function quote>         return ($volume, @dirs);
function quote>     }
function quote> }
function quote> $result = realpath($ARGV[0]);
function quote> if (!$result) {
function quote>     my ($vol, $dir) = File::Spec->splitpath($ARGV[0], 1);
function quote>     ($vol, @dirs) = recursive($vol, File::Spec->splitdir($dir)<sive($vol, File::Spec->splitdir($dir))                                       <sive($vol, File::Spec->splitdir($dir));
function quote>     $result = File::Spec->catpath($vol, File::Spec->catdir(@di<>catpath($vol, File::Spec->catdir(@dir                                       <>catpath($vol, File::Spec->catdir(@dirs), "");
function quote> }
function quote> if ($ARGV[0] =~ /\/$/) {
function quote>     $result = $result . "/";
function quote> }
function quote> print "\"$result\"\n";
function quote> ' "$1" 2>/dev/null
function> } 2>/dev/null; echo tramp_exit_status $?
tramp_exit_status 0
4

1 回答 1

1

尝试以下操作:

(setq debug-on-event 'sigusr2)

然后当 Emacs 被冻结时,kill -USR2 <emacspid>从 shell 执行。这应该有希望给你一个 lisp 级别的回溯,这将有助于追踪问题。

于 2013-11-10T20:08:03.690 回答