aboutsummaryrefslogtreecommitdiff
path: root/emacs/.emacs.d/lisp/my/my-markup.el
blob: 2b1c7f6dd300274dc7a49e92b007dde838f3f4f9 (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
;;; my-markup.el -- Markup related extensions for emacs core -*- 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:

;; Markup related extensions for emacs core.

;;; Code:


;;; shr
(defun my-shr-add-id (dom start end)
  (let ((id (dom-attr dom 'id)))
    (when id
      (put-text-property start end 'shr-frag-id id))))

(defun my-shr-add-id-advice (orig-fun &rest args)
  (let ((start (point)))
    (apply orig-fun args)
    (my-shr-add-id (car args) start (point))))

;;; dom
(defun my-dom-remove-style (node)
  (dolist (to-remove (dom-by-tag node 'style))
    (dom-remove-node node to-remove))
  node)
(defun my-dom-next-p-sibling (dom node)
  "Return the next para sibling of NODE in DOM."
  (when-let* ((parent (dom-parent dom node)))
    (let ((siblings (dom-children parent))
	        (next))
      (while (and siblings (not next))
	      (when (eq (pop siblings) node)
	        (setq next (car siblings))))
      (while (and siblings (not (and (listp next) (eq (dom-tag next) 'p))))
	      (setq next (pop siblings)))
      next)))
(defun my-dom-first-tag-text (dom tag)
  (car (dom-by-tag dom tag)))

;; xml
(defun my-xml-get-first-child (node tag)
  (car (xml-get-children node tag)))
(defun my-xml-get-first-child-text (node tag)
  (when-let ((text (dom-text (my-xml-get-first-child node tag))))
    (replace-regexp-in-string "\n" " " (string-trim text))))

(provide 'my-markup)
;;; my-markup.el ends here