aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVasilij Schneidermann <mail@vasilij.de>2017-08-31 08:01:27 +0200
committerVasilij Schneidermann <mail@vasilij.de>2017-08-31 08:01:27 +0200
commitf103fc17513e48fe66966a93696ac732b47acd81 (patch)
treea180e4394a7bcde2f693abebbe06217bcf55bcfb
parent9bcd646a5db595b44b096c2b3dfa5bfbceea3c0a (diff)
Display missing metadata and be more lenient
-rw-r--r--nov.el30
1 files changed, 18 insertions, 12 deletions
diff --git a/nov.el b/nov.el
index dcf4349..06d56a9 100644
--- a/nov.el
+++ b/nov.el
@@ -174,14 +174,15 @@ Required keys are 'identifier and everything in
(car (esxml-node-children node))))
(esxml-query-all "package>metadata>*" content)))
(required (mapcar (lambda (tag)
- (let ((candidate (assq tag candidates)))
- (when (or (not candidate) (not (cdr candidate)))
- (error "Required metadatum %s not found" tag))
- candidate))
+ (let ((candidate (cdr (assq tag candidates))))
+ (when (not candidate)
+ ;; NOTE: this should ideally be a
+ ;; warning, but `warn' is too obtrusive
+ (message "Required metadatum %s not found" tag))
+ (cons tag candidate)))
nov-required-metadata-tags))
- (optional (->> nov-optional-metadata-tags
- (mapcar (lambda (tag) (assq tag candidates)))
- (--remove (or (not it) (not (cdr it)))))))
+ (optional (mapcar (lambda (tag) (cons tag (cdr (assq tag candidates))))
+ nov-optional-metadata-tags)))
(append `((identifier . ,identifier)) required optional)))
(defun nov-content-manifest (directory content)
@@ -373,6 +374,9 @@ chapter title."
(chapter-title (car (esxml-node-children dom))))
(when (not chapter-title)
(setq chapter-title '(:propertize "No title" face italic)))
+ ;; this shouldn't happen for properly authored EPUBs
+ (when (not title)
+ (setq title '(:propertize "No title" face italic)))
(setq header-line-format (list title ": " chapter-title))))
(defvar nov-rendering-functions
@@ -460,11 +464,13 @@ the HTML is rendered with `shr-render-region'."
(dolist (item metadata)
(-let [(key . value) item]
(insert (format "%s: " (capitalize (symbol-name key))))
- (if (eq key 'description)
- (let ((beg (point)))
- (insert value)
- (shr-render-region beg (point)))
- (insert value))
+ (if value
+ (if (eq key 'description)
+ (let ((beg (point)))
+ (insert value)
+ (shr-render-region beg (point)))
+ (insert value))
+ (insert (propertize "None" 'face 'italic)))
(insert "\n")))
(goto-char (point-min))))
(display-buffer buffer)))