forked from mirrors/org-mode
Merge branch 'bugfix' into emacs-sync
This commit is contained in:
commit
bd5a04a51c
|
@ -178,21 +178,29 @@ Return a hash table with citation references as keys and fields alist as values.
|
|||
" and ")))
|
||||
('issued
|
||||
;; Date are expressed as an array
|
||||
;; (`date-parts') or a "string (`raw').
|
||||
;; In both cases, extract the year and
|
||||
;; associate it to `year' field, for
|
||||
;; compatibility with BibTeX format.
|
||||
;; (`date-parts') or a "string (`raw'
|
||||
;; or `literal'). In both cases,
|
||||
;; extract the year and associate it
|
||||
;; to `year' field, for compatibility
|
||||
;; with BibTeX format.
|
||||
(let ((date (or (alist-get 'date-parts value)
|
||||
(alist-get 'literal value)
|
||||
(alist-get 'raw value))))
|
||||
(cons 'year
|
||||
(cond
|
||||
((consp date)
|
||||
(caar date))
|
||||
((stringp date)
|
||||
(car (split-string date "-")))
|
||||
(replace-regexp-in-string
|
||||
(rx
|
||||
(minimal-match (zero-or-more anything))
|
||||
(group-n 1 (repeat 4 digit))
|
||||
(zero-or-more anything))
|
||||
(rx (backref 1))
|
||||
date))
|
||||
(t
|
||||
(error "Unknown CSL-JSON date format: %S"
|
||||
date))))))
|
||||
value))))))
|
||||
(_
|
||||
(cons field value))))
|
||||
item)
|
||||
|
|
|
@ -183,7 +183,7 @@ link.
|
|||
(defcustom org-link-descriptive t
|
||||
"Non-nil means Org displays descriptive links.
|
||||
|
||||
E.g. [[https://orgmode.org][Org website]] is be displayed as
|
||||
E.g. [[https://orgmode.org][Org website]] is displayed as
|
||||
\"Org Website\", hiding the link itself and just displaying its
|
||||
description. When set to nil, Org displays the full links
|
||||
literally.
|
||||
|
|
10
lisp/org.el
10
lisp/org.el
|
@ -17522,11 +17522,11 @@ this numeric value."
|
|||
(interactive "r")
|
||||
(let ((result ""))
|
||||
(while (/= beg end)
|
||||
(when (get-char-property beg 'invisible)
|
||||
(setq beg (next-single-char-property-change beg 'invisible nil end)))
|
||||
(let ((next (next-single-char-property-change beg 'invisible nil end)))
|
||||
(setq result (concat result (buffer-substring beg next)))
|
||||
(setq beg next)))
|
||||
(if (invisible-p beg)
|
||||
(setq beg (next-single-char-property-change beg 'invisible nil end))
|
||||
(let ((next (next-single-char-property-change beg 'invisible nil end)))
|
||||
(setq result (concat result (buffer-substring beg next)))
|
||||
(setq beg next))))
|
||||
(setq deactivate-mark t)
|
||||
(kill-new result)
|
||||
(message "Visible strings have been copied to the kill ring.")))
|
||||
|
|
|
@ -8176,52 +8176,75 @@ CLOSED: %s
|
|||
(org-show-set-visibility 'minimal)
|
||||
(org-invisible-p2))))
|
||||
|
||||
(defun test-org/copy-visible ()
|
||||
(ert-deftest test-org/copy-visible ()
|
||||
"Test `org-copy-visible' specifications."
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text "Foo"
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Skip invisible characters by text property.
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text #("F<hidden>oo" 1 7 (invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Skip invisible characters by overlay.
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text "F<hidden>oo"
|
||||
(let ((o (make-overlay 2 10)))
|
||||
(overlay-put o 'invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Handle invisible characters at the beginning and the end of the
|
||||
;; buffer.
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text #("<hidden>Foo" 0 8 (invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text #("Foo<hidden>" 3 11 (invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Handle multiple visible parts.
|
||||
(should
|
||||
(equal "abc"
|
||||
(org-test-with-temp-text
|
||||
#("aXbXc" 1 2 (invisible t) 3 4 (invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t))))))
|
||||
;;`org-unfontify-region', which is wired up to
|
||||
;; `font-lock-unfontify-region-function', removes the invisible text
|
||||
;; property, among other things.
|
||||
(cl-letf (((symbol-function 'org-unfontify-region) #'ignore))
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text "Foo"
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Skip invisible characters by text property.
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text #("F<hidden>oo" 1 9 (invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Skip invisible characters by overlay.
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text "F<hidden>oo"
|
||||
(let ((o (make-overlay 2 10)))
|
||||
(overlay-put o 'invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Handle invisible characters at the beginning and the end of the
|
||||
;; buffer.
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text #("<hidden>Foo" 0 8 (invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
(should
|
||||
(equal "Foo"
|
||||
(org-test-with-temp-text #("Foo<hidden>" 3 11 (invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Handle multiple visible parts.
|
||||
(should
|
||||
(equal "abc"
|
||||
(org-test-with-temp-text
|
||||
#("aXbXc" 1 2 (invisible t) 3 4 (invisible t))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Handle adjacent invisible parts.
|
||||
(should
|
||||
(equal "ab"
|
||||
(org-test-with-temp-text
|
||||
#("aXXb" 1 2 (invisible t) 2 3 (invisible org-link))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))
|
||||
;; Copies text based on what's actually visible, as defined by
|
||||
;; `buffer-invisibility-spec'.
|
||||
(should
|
||||
(equal "aYb"
|
||||
(org-test-with-temp-text
|
||||
#("aXYb"
|
||||
1 2 (invisible t)
|
||||
2 3 (invisible org-test-copy-visible))
|
||||
(let ((kill-ring nil))
|
||||
(org-copy-visible (point-min) (point-max))
|
||||
(current-kill 0 t)))))))
|
||||
|
||||
(ert-deftest test-org/set-visibility-according-to-property ()
|
||||
"Test `org-set-visibility-according-to-property' specifications."
|
||||
|
|
Loading…
Reference in New Issue