aboutsummaryrefslogtreecommitdiff
path: root/nov.el
diff options
context:
space:
mode:
authorVasilij Schneidermann <mail@vasilij.de>2024-04-07 13:44:01 +0200
committerVasilij Schneidermann <mail@vasilij.de>2024-04-07 13:44:01 +0200
commit6508a10afcf6a2c330c76319641a2c64f653b02c (patch)
treeff3e1a9d8e28ca8c1e429f967034fbb4875857f0 /nov.el
parent08118ee9a6b15a287e766bd2e3cd025848136d60 (diff)
Use custom line filling when `nov-text-width` is t
Previously, setting `nov-text-width` to t did just stub out `shr-fill-line`, but that disabled insertion of indentation, which made the TOC items left-aligned. Now a custom replacement is used which only performs the indentation and skips on the filling.
Diffstat (limited to 'nov.el')
-rw-r--r--nov.el15
1 files changed, 14 insertions, 1 deletions
diff --git a/nov.el b/nov.el
index 91dc585..f2b6385 100644
--- a/nov.el
+++ b/nov.el
@@ -571,6 +571,19 @@ Sets `header-line-format' according to `nov-header-line-format'."
(title . nov-render-title))
"Alist of rendering functions used with `shr-render-region'.")
+(defun nov-fill-line ()
+ "Like `shr-fill-line', but only performing indentation.
+To be used when `nov-text-width' is set to t."
+ (let ((shr-indentation (or (get-text-property (point) 'shr-indentation)
+ shr-indentation)))
+ (put-text-property (point) (1+ (point)) 'shr-indentation nil)
+ (let ((face (get-text-property (point) 'face))
+ (background-start (point)))
+ (shr-indent)
+ (when face
+ (put-text-property background-start (point) 'face
+ `,(shr-face-background face))))))
+
(defun nov-render-html ()
"Render HTML in current buffer with shr."
(run-hooks 'nov-pre-html-render-hook)
@@ -582,7 +595,7 @@ Sets `header-line-format' according to `nov-header-line-format'."
;; every usage of `shr-tag-img'
(cl-letf (((symbol-function 'shr-tag-img) 'nov-render-img))
(if (eq nov-text-width t)
- (cl-letf (((symbol-function 'shr-fill-line) 'ignore))
+ (cl-letf (((symbol-function 'shr-fill-line) #'nov-fill-line))
(shr-render-region (point-min) (point-max)))
(let ((shr-width nov-text-width))
(shr-render-region (point-min) (point-max))))))