;; Add some manual entries.
(dolist (it '((?\" """ "“" "”" "”" "„" "⹂" "〞" "‟" "‟" "❞" "❝" "❠" "“" "„" "〝" "〟" "🙷" "🙶" "🙸" "«" "»")
(?' "❟" "❛" "❜" "‘" "’" "‚" "‛" "‚" "" "❮" "❯" "‹" "›")
- (?` "❛" "‘" "‛" "" "❮" "‹")
- (?\s "\t" "\r" "\n")))
+ (?` "❛" "‘" "‛" "" "❮" "‹")))
(let ((idx (car it))
(chars (cdr it)))
(aset equiv idx (append chars (aref equiv idx)))))
match any number of times."
(if character-fold-search
(apply #'concat
- (mapcar (lambda (c) (let ((out (or (aref character-fold-table c)
- (regexp-quote (string c)))))
- (if (and lax (memq c '(?\s ?\t ?\r ?\n )))
- (concat out "+")
- out)))
- string))
+ (mapcar (lambda (c) (if (and lax (memq c '(?\s ?\t ?\r ?\n)))
+ "[ \t\n\r\xa0\x2002\x2d\x200a\x202f\x205f\x3000]+"
+ (or (aref character-fold-table c)
+ (regexp-quote (string c)))))
+ string))
(regexp-quote string)))
;;; character-fold.el ends here