2019-02-26 10:32:19 +01:00
|
|
|
|
;;; oni-ediff.el --- Ediff configuration -*- lexical-binding: t; -*-
|
|
|
|
|
|
|
|
|
|
;; Copyright (C) 2019 Tom Willemse
|
|
|
|
|
|
|
|
|
|
;; Author: Tom Willemse <tom@ryuslash.org>
|
|
|
|
|
;; Keywords: local
|
2020-11-13 18:40:43 +01:00
|
|
|
|
;; Version: 2020.1113.093948
|
2019-02-26 10:32:19 +01:00
|
|
|
|
|
|
|
|
|
;; This program is free software; you can redistribute it and/or modify
|
|
|
|
|
;; it under the terms of the GNU General Public License as published by
|
|
|
|
|
;; the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
;; (at your option) any later version.
|
|
|
|
|
|
|
|
|
|
;; This program is distributed in the hope that it will be useful,
|
|
|
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
;; GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
;; You should have received a copy of the GNU General Public License
|
|
|
|
|
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
|
|
;;; Commentary:
|
|
|
|
|
|
|
|
|
|
;; Ediff configuration.
|
|
|
|
|
|
|
|
|
|
;;; Code:
|
|
|
|
|
|
|
|
|
|
(require 'ediff)
|
|
|
|
|
|
|
|
|
|
(defun oni-ediff--turn-on-fullscreen ()
|
|
|
|
|
"Turn on fullscreen for the current frame."
|
|
|
|
|
(unless (memq (frame-parameter nil 'fullscreen)
|
|
|
|
|
'(fullscreen fullboth))
|
|
|
|
|
(set-frame-parameter nil 'fullscreen 'fullboth)))
|
|
|
|
|
|
|
|
|
|
(defun oni-ediff--turn-off-fullscreen ()
|
|
|
|
|
"Turn off fullscreen for the current frame."
|
|
|
|
|
(when (memq (frame-parameter nil 'fullscreen)
|
|
|
|
|
'(fullscreen fullboth))
|
|
|
|
|
(set-frame-parameter nil 'fullscreen nil)))
|
|
|
|
|
|
2019-10-11 02:02:34 +02:00
|
|
|
|
;;;###autoload
|
|
|
|
|
(defun oni-ediff-from-command-line ()
|
|
|
|
|
"Call ‘ediff’ with arguments from the command line."
|
|
|
|
|
(pcase command-line-args-left
|
|
|
|
|
(`(,fileA ,fileB) (ediff-files fileA fileB))
|
|
|
|
|
(`(,fileA ,fileB ,fileC) (ediff-files3 fileA fileB fileC))
|
|
|
|
|
(_ (error "Invalid number of arguments, need either 2 or 3 files"))))
|
|
|
|
|
|
2020-11-07 01:42:58 +01:00
|
|
|
|
;;;###autoload
|
|
|
|
|
(defun oni-ediff-server (fun files proc &optional nowait)
|
|
|
|
|
(pcase files
|
|
|
|
|
((and `((,fileB) (,fileA) (,command))
|
|
|
|
|
(guard (string= (file-name-nondirectory command) "diff")))
|
2020-11-13 18:40:43 +01:00
|
|
|
|
(let* ((file-a-path (expand-file-name fileA))
|
|
|
|
|
(file-b-path (expand-file-name fileB))
|
|
|
|
|
(file-a-opened-p (find-buffer-visiting fileA))
|
|
|
|
|
(file-b-opened-p (find-buffer-visiting fileB))
|
|
|
|
|
cleanup-function)
|
|
|
|
|
(setq cleanup-function
|
|
|
|
|
(lambda ()
|
|
|
|
|
(remove-hook 'ediff-cleanup-hook cleanup-function)
|
|
|
|
|
(when (not file-a-opened-p)
|
|
|
|
|
(kill-buffer (find-buffer-visiting file-a-path)))
|
|
|
|
|
(when (not file-b-opened-p)
|
|
|
|
|
(kill-buffer (find-buffer-visiting file-b-path)))
|
|
|
|
|
(delete-process proc)))
|
|
|
|
|
(select-frame-set-input-focus (selected-frame))
|
|
|
|
|
(ediff-files (expand-file-name fileA)
|
|
|
|
|
(expand-file-name fileB))
|
|
|
|
|
(add-hook 'ediff-cleanup-hook cleanup-function))
|
2020-11-07 01:42:58 +01:00
|
|
|
|
nil)
|
|
|
|
|
(_
|
|
|
|
|
(message "Got args: \"%s\"" (list files proc nowait))
|
|
|
|
|
(funcall fun files proc nowait))))
|
|
|
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
|
(advice-add 'server-visit-files :around #'oni-ediff-server)
|
|
|
|
|
|
2019-02-26 10:32:19 +01:00
|
|
|
|
(setq ediff-window-setup-function 'ediff-setup-windows-plain)
|
|
|
|
|
(setq ediff-split-window-function 'split-window-horizontally)
|
|
|
|
|
|
|
|
|
|
(setq ediff-diff-options "-w")
|
|
|
|
|
|
2020-11-07 01:49:16 +01:00
|
|
|
|
(setq-default ediff-auto-refine 'on)
|
|
|
|
|
|
2019-02-26 10:32:19 +01:00
|
|
|
|
(add-hook 'ediff-mode-hook #'oni-ediff--turn-on-fullscreen)
|
|
|
|
|
(add-hook 'ediff-cleanup-hook #'oni-ediff--turn-off-fullscreen)
|
2020-11-07 01:49:34 +01:00
|
|
|
|
(add-hook 'ediff-cleanup-hook 'winner-undo)
|
2019-02-26 10:32:19 +01:00
|
|
|
|
|
|
|
|
|
;;;###autoload(with-eval-after-load 'ediff (require 'oni-ediff))
|
|
|
|
|
|
|
|
|
|
(provide 'oni-ediff)
|
|
|
|
|
;;; oni-ediff.el ends here
|