blob: d89301781175d408fd2a5757c0c5c649a7b1d73f (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
;;; my-nov.el -- Extensions for nov.el -*- lexical-binding: t -*-
;; Copyright (C) 2023 Free Software Foundation.
;; Author: Yuchen Pei <id@ypei.org>
;; Package-Requires: ((emacs "28.2"))
;; This file is part of dotfiles.
;; dotfiles is free software: you can redistribute it and/or modify it under
;; the terms of the GNU Affero General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; dotfiles 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 Affero General
;; Public License for more details.
;; You should have received a copy of the GNU Affero General Public
;; License along with dotfiles. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;; Extensions for nov.el.
;;; Code:
(require 'nov)
;; override nov-render-title
;; this is because header line does not work with follow mode
(defun my-nov-render-title (dom)
"Custom <title> rendering function for DOM.
Sets `header-line-format' to a combination of the EPUB title and
chapter title."
(let ((title (cdr (assq 'title nov-metadata)))
(chapter-title (car (esxml-node-children dom))))
(when (not chapter-title)
(setq chapter-title "No title"))
;; this shouldn't happen for properly authored EPUBs
(when (not title)
(setq title "No title"))
(setq mode-line-buffer-identification
(concat title ": " chapter-title))
))
(defun my-nov-scroll-up (arg)
"Scroll with `scroll-up' or visit next chapter if at bottom."
(interactive "P")
(if (>= (follow-window-end) (point-max))
(nov-next-document)
(follow-scroll-up arg)))
(defun my-nov-copy-buffer-file-with-staging ()
(interactive)
(unless (derived-mode-p 'nov-mode) (error "Not in nov mode"))
(pcase-let* ((name
(completing-read (format "Copy %s to: " nov-file-name)
my-copy-file-targets
nil t))
(`(,dest ,staging) (alist-get name my-copy-file-targets
nil nil #'equal)))
(my-copy-file-with-staging
nov-file-name dest staging)))
(defun my-nov-set-left-margin ()
(set-left-margin (point-min) (point-max) 2))
(provide 'my-nov)
;;; my-nov.el ends here
|