summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLars Magne Ingebrigtsen <larsi@gnus.org>2014-11-26 22:08:44 +0100
committerLars Magne Ingebrigtsen <larsi@gnus.org>2014-11-26 22:08:52 +0100
commit7520f8919ae4030b5b2c3fbcc4141c85bb65aad1 (patch)
tree0e672a0fe7097a140e4960e962713be79e144043
parentc9cb3d535b2daf19b53dcaeedc2f2ae923bca2a1 (diff)
Further eww dom.el cleanups
* net/eww.el (eww-tag-title): Use `dom-text'. * dom.el (dom-by-tag): Use `equal' for comparisons so that tags can be strings. (dom-elements): Protect against non-text nodes. (dom-non-text-children): New function.
-rw-r--r--lisp/ChangeLog9
-rw-r--r--lisp/dom.el12
-rw-r--r--lisp/net/eww.el27
3 files changed, 30 insertions, 18 deletions
diff --git a/lisp/ChangeLog b/lisp/ChangeLog
index 1698eb7631..4884d5ca9c 100644
--- a/lisp/ChangeLog
+++ b/lisp/ChangeLog
@@ -1,3 +1,12 @@
+2014-11-26 Lars Magne Ingebrigtsen <larsi@gnus.org>
+
+ * dom.el (dom-by-tag): Use `equal' for comparisons so that tags
+ can be strings.
+ (dom-elements): Protect against non-text nodes.
+ (dom-non-text-children): New function.
+
+ * net/eww.el (eww-tag-title): Use `dom-text'.
+
2014-11-26 Sam Steingold <sds@gnu.org>
* textmodes/sgml-mode.el (sgml-validate-command): Pass -utf8 to tidy.
diff --git a/lisp/dom.el b/lisp/dom.el
index 3157e0b2f2..04d6c219ec 100644
--- a/lisp/dom.el
+++ b/lisp/dom.el
@@ -47,6 +47,12 @@
(cddr (car node))
(cddr node)))
+(defun dom-non-text-children (node)
+ "Return all non-text-node children of NODE."
+ (cl-loop for child in (dom-children node)
+ unless (stringp child)
+ collect child))
+
(defun dom-set-attributes (node attributes)
"Set the attributes of NODE to ATTRIBUTES."
(setq node (dom-ensure-node node))
@@ -93,7 +99,7 @@ A name is a symbol like `td'."
(dom-by-tag child tag))
when matches
append matches)))
- (if (eq (dom-tag dom) tag)
+ (if (equal (dom-tag dom) tag)
(cons dom matches)
matches)))
@@ -113,7 +119,9 @@ A name is a symbol like `td'."
"Find elements matching MATCH (a regexp) in ATTRIBUTE.
ATTRIBUTE would typically be `class', `id' or the like."
(let ((matches (cl-loop for child in (dom-children dom)
- for matches = (dom-elements child attribute match)
+ for matches = (and (not (stringp child))
+ (dom-elements child attribute
+ match))
when matches
append matches))
(attr (dom-attr dom attribute)))
diff --git a/lisp/net/eww.el b/lisp/net/eww.el
index a1460a8f55..10298b109d 100644
--- a/lisp/net/eww.el
+++ b/lisp/net/eww.el
@@ -453,14 +453,10 @@ See the `eww-search-prefix' variable for the search engine used."
(setq header-line-format nil)))
(defun eww-tag-title (dom)
- (let ((title ""))
- (dolist (sub (dom-children dom))
- (when (stringp sub)
- (setq title (concat title sub))))
- (plist-put eww-data :title
- (replace-regexp-in-string
- "^ \\| $" ""
- (replace-regexp-in-string "[ \t\r\n]+" " " title))))
+ (plist-put eww-data :title
+ (replace-regexp-in-string
+ "^ \\| $" ""
+ (replace-regexp-in-string "[ \t\r\n]+" " " (dom-text dom))))
(eww-update-header-line-format))
(defun eww-tag-body (dom)
@@ -589,14 +585,13 @@ the like."
(defun eww-highest-readability (node)
(let ((result node)
highest)
- (dolist (elem (dom-children node))
- (when (and (not (stringp elem))
- (> (or (dom-attr
- (setq highest (eww-highest-readability elem))
- :eww-readability-score)
- most-negative-fixnum)
- (or (dom-attr result :eww-readability-score)
- most-negative-fixnum)))
+ (dolist (elem (dom-non-text-children node))
+ (when (> (or (dom-attr
+ (setq highest (eww-highest-readability elem))
+ :eww-readability-score)
+ most-negative-fixnum)
+ (or (dom-attr result :eww-readability-score)
+ most-negative-fixnum))
(setq result highest)))
result))