# HG changeset patch # User Eli Zaretskii # Date 1279275433 -10800 # Node ID 0c54c271bb98b083f506edd90ff840d5abf6112b # Parent d03ee75f7be2946cff05063566a8636650ce929c Fix bug #4451. vc.el (vc-coding-system-inherit-eol): New defvar. (vc-coding-system-for-diff): Use it to decide whether to inherit from the file the EOL format for reading the diffs of that file. diff -r d03ee75f7be2 -r 0c54c271bb98 lisp/ChangeLog --- a/lisp/ChangeLog Fri Jul 16 12:59:37 2010 +0300 +++ b/lisp/ChangeLog Fri Jul 16 13:17:13 2010 +0300 @@ -1,3 +1,10 @@ +2010-07-16 Reiner Steib + + * vc.el (vc-coding-system-inherit-eol): New defvar. + (vc-coding-system-for-diff): Use it to decide whether to inherit + from the file the EOL format for reading the diffs of that file. + (Bug#4451) + 2010-07-16 Eli Zaretskii * mail/rmailmm.el (rmail-mime-save): Make the temp buffer diff -r d03ee75f7be2 -r 0c54c271bb98 lisp/vc.el --- a/lisp/vc.el Fri Jul 16 12:59:37 2010 +0300 +++ b/lisp/vc.el Fri Jul 16 13:17:13 2010 +0300 @@ -1398,6 +1398,16 @@ ;; (vc-call-backend ',(vc-backend f) ;; 'diff (list ',f) ',rev1 ',rev2)))))) +(defvar vc-coding-system-inherit-eol t + "When non-nil, inherit the EOL format for reading Diff output from the file. + +Used in `vc-coding-system-for-diff' to determine the EOL format to use +for reading Diff output for a file. If non-nil, the EOL format is +inherited from the file itself. +Set this variable to nil if your Diff tool might use a different +EOL. Then Emacs will auto-detect the EOL format in Diff output, which +gives better results.") ;; Cf. bug#4451. + (defun vc-coding-system-for-diff (file) "Return the coding system for reading diff output for FILE." (or coding-system-for-read @@ -1405,7 +1415,12 @@ ;; use the buffer's coding system (let ((buf (find-buffer-visiting file))) (when buf (with-current-buffer buf - buffer-file-coding-system))) + (if vc-coding-system-inherit-eol + buffer-file-coding-system + ;; Don't inherit the EOL part of the coding-system, + ;; because some Diff tools may choose to use + ;; a different one. bug#4451. + (coding-system-base buffer-file-coding-system))))) ;; otherwise, try to find one based on the file name (car (find-operation-coding-system 'insert-file-contents file)) ;; and a final fallback