10

给定使用 git format-patch(统一补丁格式)创建的差异文件,我如何在 emacs 中加载相同的文件,以便我可以使用 Cc Cc 转到文件中的相应位置,即使文件或目录名称包含一个空间,在窗户上。

我的项目包含很多包含空格的文件和目录名称。

4

1 回答 1

3

这似乎是 Emacs 中的一个错误。这是一个似乎可以为我修复它的补丁:

=== modified file 'lisp/vc/diff-mode.el'
--- lisp/vc/diff-mode.el    2013-01-02 16:13:04 +0000
+++ lisp/vc/diff-mode.el    2013-02-26 05:08:48 +0000
@@ -821,9 +821,11 @@ If the OLD prefix arg is passed, tell th
               (progn (diff-hunk-prev) (point))
             (error (point-min)))))
      (header-files
-      (if (looking-at "[-*][-*][-*] \\(\\S-+\\)\\(\\s-.*\\)?\n[-+][-+][-+] \\(\\S-+\\)")
-          (list (if old (match-string 1) (match-string 3))
-            (if old (match-string 3) (match-string 1)))
+           ;; handle filenames with spaces;
+           ;; cf. diff-font-lock-keywords / diff-file-header-face
+      (if (looking-at "[-*][-*][-*] \\([^\t]+\\)\t.*\n[-+][-+][-+] \\([^\t]+\\)")
+          (list (if old (match-string 1) (match-string 2))
+            (if old (match-string 2) (match-string 1)))
         (forward-line 1) nil)))
       (delq nil
        (append

如果没有异议,我会将其提交到 Emacs bzr 源代码树。

于 2013-02-26T05:14:11.920 回答