aboutsummaryrefslogtreecommitdiff
path: root/nov.el
diff options
context:
space:
mode:
authorDarkSun <lujun9972@gmail.com>2020-02-20 17:39:50 +0800
committerGitHub <noreply@github.com>2020-02-20 10:39:50 +0100
commitcd1b264b3f978a9285fa9297e40ad29d1434adf5 (patch)
tree0727ae7728df9a39076149ca68c25b3c279f01f1 /nov.el
parent41e6a9cf142465633b7128a3b0e284ff6cb582d7 (diff)
Bookmark Integration (#61)
Bookmark Integration
Diffstat (limited to 'nov.el')
-rw-r--r--nov.el46
1 files changed, 37 insertions, 9 deletions
diff --git a/nov.el b/nov.el
index 09916c7..7be29e9 100644
--- a/nov.el
+++ b/nov.el
@@ -48,6 +48,9 @@
(require 'esxml-query)
(require 'shr)
(require 'url-parse)
+(require 'recentf)
+(require 'bookmark)
+(require 'org)
(when (not (fboundp 'libxml-parse-xml-region))
(message "Your Emacs wasn't compiled with libxml support"))
@@ -772,6 +775,8 @@ Saving is only done if `nov-save-place-file' is set."
(setq nov-documents-index 0))
(setq buffer-undo-list t)
(setq nov-file-name (buffer-file-name))
+ (setq-local bookmark-make-record-function
+ 'nov-bookmark-make-record)
(set-visited-file-name nil t) ; disable autosaves and save questions
(let ((place (nov-saved-place (cdr (assq 'identifier nov-metadata)))))
(if place
@@ -789,7 +794,6 @@ Saving is only done if `nov-save-place-file' is set."
;;; recentf interop
-(require 'recentf)
(defun nov-add-to-recentf ()
(when nov-file-name
(recentf-add-file nov-file-name)))
@@ -798,21 +802,45 @@ Saving is only done if `nov-save-place-file' is set."
(add-hook 'nov-mode-hook 'hack-dir-local-variables-non-file-buffer)
-;;; org interop
+(defun nov--find-file (file index point)
+ "Open FILE(nil means current buffer) in nov-mode and go to the specified INDEX and POSITION."
+ (when file
+ (find-file file))
+ (unless (eq major-mode 'nov-mode)
+ (nov-mode))
+ (when (not (nov--index-valid-p nov-documents index))
+ (error "Invalid documents index"))
+ (setq nov-documents-index index)
+ (nov-render-document)
+ (goto-char point))
+
+;; Bookmark Integration
+(defun nov-bookmark-make-record ()
+ "Create a bookmark epub record."
+ (cons (buffer-name)
+ `((filename . ,nov-file-name)
+ (index . ,nov-documents-index)
+ (position . ,(point))
+ (handler . nov-bookmark-jump-handler))))
+
+(defun nov-bookmark-jump-handler (bmk)
+ "The bookmark handler-function interface for bookmark BMK.
+
+See also `nov-bookmark-make-record'."
+ (let ((file (bookmark-prop-get bmk 'filename))
+ (index (bookmark-prop-get bmk 'index))
+ (position (bookmark-prop-get bmk 'position)))
+ (nov--find-file file index position)))
-(require 'org)
+
+;;; org interop
(defun nov-org-link-follow (path)
(if (string-match "^\\(.*\\)::\\([0-9]+\\):\\([0-9]+\\)$" path)
(let ((file (match-string 1 path))
(index (string-to-number (match-string 2 path)))
(point (string-to-number (match-string 3 path))))
- (find-file file)
- (when (not (nov--index-valid-p nov-documents index))
- (error "Invalid documents index"))
- (setq nov-documents-index index)
- (nov-render-document)
- (goto-char point))
+ (nov--find-file file index point))
(error "Invalid nov.el link")))
(defun nov-org-link-store ()