Refactor lang/web/autoload/html

This commit is contained in:
Henrik Lissner 2017-07-04 13:09:25 +02:00
parent ed1a79040e
commit 59c5a78940
No known key found for this signature in database
GPG key ID: 5F6C0EA160557395

View file

@ -4,11 +4,57 @@
(defvar +web-entities-list
[[" " " "] [" " ""] [" " ""] [" " ""]
["‏" ""] ["‎" ""] ["‍" ""] ["‌" ""]
["¡" "¡"] ["¢" "¢"] ["£" "£"] ["¤" "¤"] ["¥" "¥"] ["¦" "¦"] ["§" "§"] ["¨" "¨"] ["©" "©"] ["ª" "ª"] ["«" "«"] ["¬" "¬"] ["­" "­"] ["®" "®"] ["¯" "¯"] ["°" "°"] ["±" "±"] ["²" "²"] ["³" "³"] ["´" "´"] ["µ" "µ"] ["¶" ""] ["·" "·"] ["¸" "¸"] ["¹" "¹"] ["º" "º"] ["»" "»"] ["¼" "¼"] ["½" "½"] ["¾" "¾"] ["¿" "¿"]
["À" "À"] ["Á" "Á"] ["Â" "Â"] ["Ã" "Ã"] ["Ä" "Ä"] ["Å" "Å"] ["Æ" "Æ"] ["Ç" "Ç"] ["È" "È"] ["É" "É"] ["Ê" "Ê"] ["Ë" "Ë"] ["Ì" "Ì"] ["Í" "Í"] ["Î" "Î"] ["Ï" "Ï"] ["Ð" "Ð"] ["Ñ" "Ñ"] ["Ò" "Ò"] ["Ó" "Ó"] ["Ô" "Ô"] ["Õ" "Õ"] ["Ö" "Ö"] ["×" "×"] ["Ø" "Ø"] ["Ù" "Ù"] ["Ú" "Ú"] ["Û" "Û"] ["Ü" "Ü"] ["Ý" "Ý"] ["Þ" "Þ"] ["ß" "ß"] ["à" "à"] ["á" "á"] ["â" "â"] ["ã" "ã"] ["ä" "ä"] ["å" "å"] ["æ" "æ"] ["ç" "ç"] ["è" "è"] ["é" "é"] ["ê" "ê"] ["ë" "ë"] ["ì" "ì"] ["í" "í"] ["î" "î"] ["ï" "ï"] ["ð" "ð"] ["ñ" "ñ"] ["ò" "ò"] ["ó" "ó"] ["ô" "ô"] ["õ" "õ"] ["ö" "ö"]
["÷" "÷"] ["ø" "ø"] ["ù" "ù"] ["ú" "ú"] ["û" "û"] ["ü" "ü"] ["ý" "ý"] ["þ" "þ"] ["ÿ" "ÿ"] ["ƒ" "ƒ"]
["Α" "Α"] ["Β" "Β"] ["Γ" "Γ"] ["Δ" "Δ"] ["Ε" "Ε"] ["Ζ" "Ζ"] ["Η" "Η"] ["Θ" "Θ"] ["Ι" "Ι"] ["Κ" "Κ"] ["Λ" "Λ"] ["Μ" "Μ"] ["Ν" "Ν"] ["Ξ" "Ξ"] ["Ο" "Ο"] ["Π" "Π"] ["Ρ" "Ρ"] ["Σ" "Σ"] ["Τ" "Τ"] ["Υ" "Υ"] ["Φ" "Φ"] ["Χ" "Χ"] ["Ψ" "Ψ"] ["Ω" "Ω"] ["α" "α"] ["β" "β"] ["γ" "γ"] ["δ" "δ"] ["ε" "ε"] ["ζ" "ζ"] ["η" "η"] ["θ" "θ"] ["ι" "ι"] ["κ" "κ"] ["λ" "λ"] ["μ" "μ"] ["ν" "ν"] ["ξ" "ξ"] ["ο" "ο"] ["π" "π"] ["ρ" "ρ"] ["ς" "ς"] ["σ" "σ"] ["τ" "τ"] ["υ" "υ"] ["φ" "φ"] ["χ" "χ"] ["ψ" "ψ"] ["ω" "ω"] ["ϑ" "ϑ"] ["ϒ" "ϒ"] ["ϖ" "ϖ"]
["•" ""] ["…" ""] ["′" ""] ["″" ""] ["‾" ""] ["⁄" ""] ["℘" ""] ["ℑ" ""] ["ℜ" ""] ["™" ""] ["ℵ" ""] ["←" ""] ["↑" ""] ["→" ""] ["↓" ""] ["↔" ""] ["↵" ""] ["⇐" ""] ["⇑" ""] ["⇒" ""] ["⇓" ""] ["⇔" ""] ["∀" ""] ["∂" ""] ["∃" ""] ["∅" ""] ["∇" ""] ["∈" ""] ["∉" ""] ["∋" ""] ["∏" ""] ["∑" ""] ["−" ""] ["∗" ""] ["√" ""] ["∝" ""] ["∞" ""] ["∠" ""] ["∧" ""] ["∨" ""] ["∩" ""] ["∪" ""] ["∫" ""] ["∴" ""] ["∼" ""] ["≅" ""] ["≈" ""] ["≠" ""] ["≡" ""] ["≤" ""] ["≥" ""] ["⊂" ""] ["⊃" ""] ["⊄" ""] ["⊆" ""] ["⊇" ""] ["⊕" ""] ["⊗" ""] ["⊥" ""] ["⋅" ""] ["⌈" ""] ["⌉" ""] ["⌊" ""] ["⌋" ""] ["⟨" ""] ["⟩" ""] ["◊" ""] ["♠" ""] ["♣" ""] ["♥" ""] ["♦" ""] [""" "\""] ["Œ" "Œ"] ["œ" "œ"] ["Š" "Š"] ["š" "š"] ["Ÿ" "Ÿ"] ["ˆ" "ˆ"] ["˜" "˜"] ["–" ""] ["—" ""] ["‘" ""] ["’" ""] ["‚" ""] ["“" ""] ["”" ""] ["„" ""] ["†" ""] ["‡" ""] ["‰" ""] ["‹" ""] ["›" ""] ["€" ""]]
["¡" "¡"] ["¢" "¢"] ["£" "£"] ["¤" "¤"] ["¥" "¥"]
["¦" "¦"] ["§" "§"] ["¨" "¨"] ["©" "©"] ["ª" "ª"]
["«" "«"] ["¬" "¬"] ["­" "­"] ["®" "®"] ["¯" "¯"]
["°" "°"] ["±" "±"] ["²" "²"] ["³" "³"] ["´" "´"]
["µ" "µ"] ["¶" ""] ["·" "·"] ["¸" "¸"] ["¹" "¹"]
["º" "º"] ["»" "»"] ["¼" "¼"] ["½" "½"]
["¾" "¾"] ["¿" "¿"] ["À" "À"] ["Á" "Á"]
["Â" "Â"] ["Ã" "Ã"] ["Ä" "Ä"] ["Å" "Å"] ["Æ" "Æ"]
["Ç" "Ç"] ["È" "È"] ["É" "É"] ["Ê" "Ê"]
["Ë" "Ë"] ["Ì" "Ì"] ["Í" "Í"] ["Î" "Î"] ["Ï" "Ï"]
["Ð" "Ð"] ["Ñ" "Ñ"] ["Ò" "Ò"] ["Ó" "Ó"]
["Ô" "Ô"] ["Õ" "Õ"] ["Ö" "Ö"] ["×" "×"] ["Ø" "Ø"]
["Ù" "Ù"] ["Ú" "Ú"] ["Û" "Û"] ["Ü" "Ü"]
["Ý" "Ý"] ["Þ" "Þ"] ["ß" "ß"] ["à" "à"] ["á" "á"]
["â" "â"] ["ã" "ã"] ["ä" "ä"] ["å" "å"]
["æ" "æ"] ["ç" "ç"] ["è" "è"] ["é" "é"] ["ê" "ê"]
["ë" "ë"] ["ì" "ì"] ["í" "í"] ["î" "î"]
["ï" "ï"] ["ð" "ð"] ["ñ" "ñ"] ["ò" "ò"] ["ó" "ó"]
["ô" "ô"] ["õ" "õ"] ["ö" "ö"] ["÷" "÷"] ["ø" "ø"]
["ù" "ù"] ["ú" "ú"] ["û" "û"] ["ü" "ü"] ["ý" "ý"]
["þ" "þ"] ["ÿ" "ÿ"] ["ƒ" "ƒ"] ["Α" "Α"] ["Β" "Β"]
["Γ" "Γ"] ["Δ" "Δ"] ["Ε" "Ε"] ["Ζ" "Ζ"] ["Η" "Η"]
["Θ" "Θ"] ["Ι" "Ι"] ["Κ" "Κ"] ["Λ" "Λ"] ["Μ" "Μ"]
["Ν" "Ν"] ["Ξ" "Ξ"] ["Ο" "Ο"] ["Π" "Π"] ["Ρ" "Ρ"]
["Σ" "Σ"] ["Τ" "Τ"] ["Υ" "Υ"] ["Φ" "Φ"] ["Χ" "Χ"]
["Ψ" "Ψ"] ["Ω" "Ω"] ["α" "α"] ["β" "β"] ["γ" "γ"]
["δ" "δ"] ["ε" "ε"] ["ζ" "ζ"] ["η" "η"] ["θ" "θ"]
["ι" "ι"] ["κ" "κ"] ["λ" "λ"] ["μ" "μ"] ["ν" "ν"]
["ξ" "ξ"] ["ο" "ο"] ["π" "π"] ["ρ" "ρ"] ["ς" "ς"]
["σ" "σ"] ["τ" "τ"] ["υ" "υ"] ["φ" "φ"] ["χ" "χ"]
["ψ" "ψ"] ["ω" "ω"] ["ϑ" "ϑ"] ["ϒ" "ϒ"] ["ϖ" "ϖ"]
["•" ""] ["…" ""] ["′" ""] ["″" ""] ["‾" ""]
["⁄" ""] ["℘" ""] ["ℑ" ""] ["ℜ" ""] ["™" ""]
["ℵ" ""] ["←" ""] ["↑" ""] ["→" ""] ["↓" ""]
["↔" ""] ["↵" ""] ["⇐" ""] ["⇑" ""] ["⇒" ""]
["⇓" ""] ["⇔" ""] ["∀" ""] ["∂" ""] ["∃" ""]
["∅" ""] ["∇" ""] ["∈" ""] ["∉" ""] ["∋" ""]
["∏" ""] ["∑" ""] ["−" ""] ["∗" ""] ["√" ""]
["∝" ""] ["∞" ""] ["∠" ""] ["∧" ""] ["∨" ""]
["∩" ""] ["∪" ""] ["∫" ""] ["∴" ""] ["∼" ""]
["≅" ""] ["≈" ""] ["≠" ""] ["≡" ""] ["≤" ""]
["≥" ""] ["⊂" ""] ["⊃" ""] ["⊄" ""] ["⊆" ""]
["⊇" ""] ["⊕" ""] ["⊗" ""] ["⊥" ""] ["⋅" ""]
["⌈" ""] ["⌉" ""] ["⌊" ""] ["⌋" ""] ["⟨" ""]
["⟩" ""] ["◊" ""] ["♠" ""] ["♣" ""]
["♥" ""] ["♦" ""] [""" "\""] ["Œ" "Œ"] ["œ" "œ"]
["Š" "Š"] ["š" "š"] ["Ÿ" "Ÿ"] ["ˆ" "ˆ"]
["˜" "˜"] ["–" ""] ["—" ""] ["‘" ""] ["’" ""]
["‚" ""] ["“" ""] ["”" ""] ["„" ""]
["†" ""] ["‡" ""] ["‰" ""] ["‹" ""] ["›" ""]
["€" ""]]
"A list of sequence string pairs, representing an html entity and its decoded
character.")
@ -22,7 +68,7 @@ character.")
case-fold-search)
(when (and (not (equal from " "))
(string-match-p (regexp-quote from) text))
(setq text (s-replace from to text)))))
(setq text (replace-regexp-in-string (regexp-quote from) to text t t)))))
text)
(defun +web--entities-region (beg end &optional decode-p)
@ -30,14 +76,14 @@ character.")
function @ http://ergoemacs.org/emacs/elisp_replace_html_entities_command.html"
(save-restriction
(narrow-to-region beg end)
(let (case-fold-search)
(seq-doseq (rep +web-entities-list)
(let ((from (elt rep (if decode-p 0 1)))
(to (elt rep (if decode-p 1 0))))
(unless (equal from " ")
(goto-char (point-min))
(while (search-forward from nil t)
(replace-match to 'FIXEDCASE 'LITERAL))))))))
(seq-doseq (rep +web-entities-list)
(let ((from (elt rep (if decode-p 0 1)))
(to (elt rep (if decode-p 1 0)))
case-fold-search)
(unless (equal from " ")
(goto-char (point-min))
(while (search-forward from nil t)
(replace-match to 'FIXEDCASE 'LITERAL)))))))
;;;###autoload
(defun +web-encode-entities (text)