默认情况下,某些文本编辑器可以显示更改的行。但是在Emacs中,怎么样?
答案 0 :(得分:10)
次要模式highlight-changes-mode
显示文字更改。
此外:
我为highlight-changes-mode
编写了一些边缘支持代码。
(eval-after-load "hilit-chg"
'(progn
(defvar highlight-fringe-mark 'filled-square
"The fringe bitmap name marked at changed line.
Should be selected from `fringe-bitmaps'.")
(defadvice hilit-chg-make-ov (after hilit-chg-add-fringe activate)
(mapc (lambda (ov)
(if (overlay-get ov 'hilit-chg)
(let ((fringe-anchor (make-string 1 ?x)))
(put-text-property 0 1 'display
(list 'left-fringe highlight-fringe-mark)
fringe-anchor)
(overlay-put ov 'before-string fringe-anchor))
))
(overlays-at (ad-get-arg 1))))))
fringed http://gyazo.com/997008bd7f400c4c01f12288ad991b24.png
此外: 要删除节省时间的亮点,请尝试:
(add-hook 'after-save-hook
(lambda ()
(when highlight-changes-mode
(save-restriction
(widen)
(highlight-changes-remove-highlight (point-min) (point-max))))))
答案 1 :(得分:3)
我假设您对缓冲区和保存文件之间的更改感兴趣。我通常会使用diff-buffer-with-file
,因为我不太经常需要它。
我还使用diff-hl
模式,该模式显示已保存文件的更改行与版本控制系统中的最后一次提交。它可以在Melpa中找到。
这是我的配置,它将指标更改为“+”,“ - ”和“!”:
(setq diff-hl-fringe-bmp-function 'diff-hl-fringe-bmp-from-type)
(global-diff-hl-mode 1)
虽然你没有问过这个问题,但我还是会提到vc
可以轻松区分受版本控制的文件C-x v =
(当前文件)或C-x v D
(整个项目)。