Replace all uses of the old `defadvice` with the new `advice-add`

* lisp/org.el (org-run-like-in-org-mode): Strength reduce `eval`
to `cl-progv`.
(org--check-org-structure-template-alist): Strength reduce `eval`
to `symbol-value`.
(org-map-entries, org-eval-in-calendar, org-diary-sexp-entry):
Make sure we use the new lexically scoped dialect.
(org--math-always-on): New function, extracted from advice.
(org-cdlatex-mode): Use it with `advice-add`.
(org-self-insert-command): Simplify `and`+`listp` into `consp`.
(org-submit-bug-report):
Make sure we use the new lexically scoped dialect.

* lisp/org-protocol.el (org-protocol-convert-query-to-plist):
Use `cl-mapcan`.
(org--protocol-detect-protocol-server): New function, extracted
from advice.
(server-visit-files): Use it with `advice-add`.

* lisp/org-mouse.el (org--mouse-dnd-insert-text): New function, extracted
from advice.
(dnd-insert-text): Use it with `advice-add`.
(org--mouse-dnd-open-file): New function, extracted from advice.
(dnd-open-file): Use it with `advice-add`.
(org--mouse-open-at-point): New function, extracted from advice.
(org-mode-hook): Advise `org-open-at-point` with `advice-add`.

* lisp/org-ctags.el (org--ctags-load-tag-list): New function, extracted
from advice.
(visit-tags-table): Use it with `advice-add`.
(org--ctags-set-org-mark-before-finding-tag): New function, extracted
from advice.
(xref-find-definitions): Use it with `advice-add`.

* lisp/org-compat.el (org-bookmark-jump-unhide): Accept (unused) args.
(save-place-find-file-hook): Use `advice-add`.
(org--ecb-show-context): New function, extracted from advice.
(ecb-method-clicked): Use it with `advice-add`.
(org-mark-jump-unhide): Accept (unused) args.
(pop-to-mark-command, exchange-point-and-mark, pop-global-mark):
Use `advice-add`.

Along the way, remove some redundant `:group` args
(redundant because they specify the same group as would be used by
default anyway) and make a few other simplifications.
Also don't bother putting `advice-add` within an eval-after-load
since the advice machinery already takes care of handling it.
This commit is contained in:
Stefan Monnier 2022-04-01 07:50:01 +02:00 committed by Bastien
parent d7cae14953
commit 6d73cd34a0
8 changed files with 98 additions and 122 deletions

View File

@ -901,7 +901,6 @@ attention to case differences."
(defcustom org-imenu-depth 2 (defcustom org-imenu-depth 2
"The maximum level for Imenu access to Org headlines. "The maximum level for Imenu access to Org headlines.
This also applied for speedbar access." This also applied for speedbar access."
:group 'org-imenu-and-speedbar
:type 'integer) :type 'integer)
;;;; Imenu ;;;; Imenu
@ -1114,7 +1113,7 @@ ELEMENT is the element at point."
;;;; Bookmark ;;;; Bookmark
(defun org-bookmark-jump-unhide () (defun org-bookmark-jump-unhide (&rest _)
"Unhide the current position, to show the bookmark location." "Unhide the current position, to show the bookmark location."
(and (derived-mode-p 'org-mode) (and (derived-mode-p 'org-mode)
(or (org-invisible-p) (or (org-invisible-p)
@ -1123,7 +1122,7 @@ ELEMENT is the element at point."
(org-show-context 'bookmark-jump))) (org-show-context 'bookmark-jump)))
;; Make `bookmark-jump' shows the jump location if it was hidden. ;; Make `bookmark-jump' shows the jump location if it was hidden.
(add-hook 'bookmark-after-jump-hook 'org-bookmark-jump-unhide) (add-hook 'bookmark-after-jump-hook #'org-bookmark-jump-unhide)
;;;; Calendar ;;;; Calendar
@ -1176,42 +1175,29 @@ key."
;;;; Saveplace ;;;; Saveplace
;; Make sure saveplace shows the location if it was hidden ;; Make sure saveplace shows the location if it was hidden
(eval-after-load 'saveplace (advice-add 'save-place-find-file-hook :after #'org-bookmark-jump-unhide)
'(defadvice save-place-find-file-hook (after org-make-visible activate)
"Make the position visible."
(org-bookmark-jump-unhide)))
;;;; Ecb ;;;; Ecb
;; Make sure ecb shows the location if it was hidden ;; Make sure ecb shows the location if it was hidden
(eval-after-load 'ecb (advice-add 'ecb-method-clicked :after #'org--ecb-show-context)
'(defadvice ecb-method-clicked (after esf/org-show-context activate) (defun org--ecb-show-context (&rest _)
"Make hierarchy visible when jumping into location from ECB tree buffer." "Make hierarchy visible when jumping into location from ECB tree buffer."
(when (derived-mode-p 'org-mode) (when (derived-mode-p 'org-mode)
(org-show-context)))) (org-show-context)))
;;;; Simple ;;;; Simple
(defun org-mark-jump-unhide () (defun org-mark-jump-unhide (&rest _)
"Make the point visible with `org-show-context' after jumping to the mark." "Make the point visible with `org-show-context' after jumping to the mark."
(when (and (derived-mode-p 'org-mode) (when (and (derived-mode-p 'org-mode)
(org-invisible-p)) (org-invisible-p))
(org-show-context 'mark-goto))) (org-show-context 'mark-goto)))
(eval-after-load 'simple (advice-add 'pop-to-mark-command :after #'org-mark-jump-unhide)
'(defadvice pop-to-mark-command (after org-make-visible activate)
"Make the point visible with `org-show-context'."
(org-mark-jump-unhide)))
(eval-after-load 'simple (advice-add 'exchange-point-and-mark :after #'org-mark-jump-unhide)
'(defadvice exchange-point-and-mark (after org-make-visible activate) (advice-add 'pop-global-mark :after #'org-mark-jump-unhide)
"Make the point visible with `org-show-context'."
(org-mark-jump-unhide)))
(eval-after-load 'simple
'(defadvice pop-global-mark (after org-make-visible activate)
"Make the point visible with `org-show-context'."
(org-mark-jump-unhide)))
;;;; Session ;;;; Session

View File

@ -157,7 +157,6 @@ See the ctags documentation for more information.")
(defcustom org-ctags-path-to-ctags (defcustom org-ctags-path-to-ctags
(if (executable-find "ctags-exuberant") "ctags-exuberant" "ctags") (if (executable-find "ctags-exuberant") "ctags-exuberant" "ctags")
"Name of the ctags executable file." "Name of the ctags executable file."
:group 'org-ctags
:version "24.1" :version "24.1"
:type 'file) :type 'file)
@ -166,7 +165,6 @@ See the ctags documentation for more information.")
org-ctags-ask-rebuild-tags-file-then-find-tag org-ctags-ask-rebuild-tags-file-then-find-tag
org-ctags-ask-append-topic) org-ctags-ask-append-topic)
"List of functions to be prepended to ORG-OPEN-LINK-FUNCTIONS by ORG-CTAGS." "List of functions to be prepended to ORG-OPEN-LINK-FUNCTIONS by ORG-CTAGS."
:group 'org-ctags
:version "24.1" :version "24.1"
:type 'hook :type 'hook
:options '(org-ctags-find-tag :options '(org-ctags-find-tag
@ -188,7 +186,6 @@ Created as a local variable in each buffer.")
"Text to insert when creating a new org file via opening a hyperlink. "Text to insert when creating a new org file via opening a hyperlink.
The following patterns are replaced in the string: The following patterns are replaced in the string:
`%t' - replaced with the capitalized title of the hyperlink" `%t' - replaced with the capitalized title of the hyperlink"
:group 'org-ctags
:version "24.1" :version "24.1"
:type 'string) :type 'string)
@ -207,7 +204,8 @@ The following patterns are replaced in the string:
(visit-tags-table tags-filename)))))) (visit-tags-table tags-filename))))))
(defadvice visit-tags-table (after org-ctags-load-tag-list activate compile) (advice-add 'visit-tags-table :after #'org--ctags-load-tag-list)
(defun org--ctags-load-tag-list (&rest _)
(when (and org-ctags-enabled-p tags-file-name) (when (and org-ctags-enabled-p tags-file-name)
(setq-local org-ctags-tag-list (setq-local org-ctags-tag-list
(org-ctags-all-tags-in-current-tags-table)))) (org-ctags-all-tags-in-current-tags-table))))
@ -295,8 +293,9 @@ The new topic will be titled NAME (or TITLE if supplied)."
;;;; Misc interoperability with etags system ================================= ;;;; Misc interoperability with etags system =================================
(defadvice xref-find-definitions (advice-add 'xref-find-definitions :before
(before org-ctags-set-org-mark-before-finding-tag activate compile) #'org--ctags-set-org-mark-before-finding-tag)
(defun org--ctags-set-org-mark-before-finding-tag (&rest _)
"Before trying to find a tag, save our current position on org mark ring." "Before trying to find a tag, save our current position on org mark ring."
(save-excursion (save-excursion
(when (and (derived-mode-p 'org-mode) org-ctags-enabled-p) (when (and (derived-mode-p 'org-mode) org-ctags-enabled-p)

View File

@ -580,15 +580,17 @@ This means, between the beginning of line and the point."
(insert text) (insert text)
(beginning-of-line)) (beginning-of-line))
(defadvice dnd-insert-text (around org-mouse-dnd-insert-text activate) (advice-add 'dnd-insert-text :around #'org--mouse-dnd-insert-text)
(defun org--mouse-dnd-insert-text (orig-fun window action text &rest args)
(if (derived-mode-p 'org-mode) (if (derived-mode-p 'org-mode)
(org-mouse-insert-item text) (org-mouse-insert-item text)
ad-do-it)) (apply orig-fun window action text args)))
(defadvice dnd-open-file (around org-mouse-dnd-open-file activate) (advice-add 'dnd-open-file :around #'org--mouse-dnd-open-file)
(defun org--mouse-dnd-open-file (orig-fun uri &rest args)
(if (derived-mode-p 'org-mode) (if (derived-mode-p 'org-mode)
(org-mouse-insert-item uri) (org-mouse-insert-item uri)
ad-do-it)) (apply orig-fun uri args)))
(defun org-mouse-match-closure (function) (defun org-mouse-match-closure (function)
(let ((match (match-data t))) (let ((match (match-data t)))
@ -894,15 +896,17 @@ This means, between the beginning of line and the point."
(1 `(face nil keymap ,org-mouse-map mouse-face highlight) prepend))) (1 `(face nil keymap ,org-mouse-map mouse-face highlight) prepend)))
t)) t))
(defadvice org-open-at-point (around org-mouse-open-at-point activate) (advice-add 'org-open-at-point :around #'org--mouse-open-at-point)))
(let ((context (org-context)))
(cond (defun org--mouse-open-at-point (orig-fun &rest args)
((assq :headline-stars context) (org-cycle)) (let ((context (org-context)))
((assq :checkbox context) (org-toggle-checkbox)) (cond
((assq :item-bullet context) ((assq :headline-stars context) (org-cycle))
(let ((org-cycle-include-plain-lists t)) (org-cycle))) ((assq :checkbox context) (org-toggle-checkbox))
((org-footnote-at-reference-p) nil) ((assq :item-bullet context)
(t ad-do-it)))))) (let ((org-cycle-include-plain-lists t)) (org-cycle)))
((org-footnote-at-reference-p) nil)
(t (apply orig-fun args)))))
(defun org-mouse-move-tree-start (_event) (defun org-mouse-move-tree-start (_event)
(interactive "e") (interactive "e")

View File

@ -179,7 +179,6 @@
cache-dir)) cache-dir))
"org-persist/")) "org-persist/"))
"Directory where the data is stored." "Directory where the data is stored."
:group 'org-persist
:type 'directory) :type 'directory)
(defcustom org-persist-remote-files 100 (defcustom org-persist-remote-files 100
@ -931,8 +930,8 @@ Also, remove containers associated with non-existing files."
(message "Missing write access rights to org-persist-directory: %S" (message "Missing write access rights to org-persist-directory: %S"
org-persist-directory) org-persist-directory)
(add-hook 'kill-emacs-hook #'org-persist-write-all) (add-hook 'kill-emacs-hook #'org-persist-write-all)
;; `org-persist-gc' should run before `org-persist-write-all'. So we are adding the ;; `org-persist-gc' should run before `org-persist-write-all'.
;; hook after `org-persist-write-all'. ;; So we are adding the hook after `org-persist-write-all'.
(add-hook 'kill-emacs-hook #'org-persist-gc))) (add-hook 'kill-emacs-hook #'org-persist-gc)))
(add-hook 'after-init-hook #'org-persist-load-all) (add-hook 'after-init-hook #'org-persist-load-all)

View File

@ -174,7 +174,6 @@ The filenames passed on the command line are passed to the emacs-server in
reverse order. Set to t (default) to re-reverse the list, i.e. use the reverse order. Set to t (default) to re-reverse the list, i.e. use the
sequence on the command line. If nil, the sequence of the filenames is sequence on the command line. If nil, the sequence of the filenames is
unchanged." unchanged."
:group 'org-protocol
:type 'boolean) :type 'boolean)
(defcustom org-protocol-project-alist nil (defcustom org-protocol-project-alist nil
@ -233,7 +232,6 @@ Example:
Consider using the interactive functions `org-protocol-create' Consider using the interactive functions `org-protocol-create'
and `org-protocol-create-for-org' to help you filling this and `org-protocol-create-for-org' to help you filling this
variable with valid contents." variable with valid contents."
:group 'org-protocol
:type 'alist) :type 'alist)
(defcustom org-protocol-protocol-alist nil (defcustom org-protocol-protocol-alist nil
@ -284,20 +282,17 @@ Here is an example:
(\"your-protocol\" (\"your-protocol\"
:protocol \"your-protocol\" :protocol \"your-protocol\"
:function your-protocol-handler-function)))" :function your-protocol-handler-function)))"
:group 'org-protocol
:type '(alist)) :type '(alist))
(defcustom org-protocol-default-template-key nil (defcustom org-protocol-default-template-key nil
"The default template key to use. "The default template key to use.
This is usually a single character string but can also be a This is usually a single character string but can also be a
string with two characters." string with two characters."
:group 'org-protocol
:type '(choice (const nil) (string))) :type '(choice (const nil) (string)))
(defcustom org-protocol-data-separator "/+\\|\\?" (defcustom org-protocol-data-separator "/+\\|\\?"
"The default data separator to use. "The default data separator to use.
This should be a single regexp string." This should be a single regexp string."
:group 'org-protocol
:version "24.4" :version "24.4"
:package-version '(Org . "8.0") :package-version '(Org . "8.0")
:type 'regexp) :type 'regexp)
@ -309,7 +304,8 @@ This should be a single regexp string."
Emacsclient compresses double and triple slashes." Emacsclient compresses double and triple slashes."
(when (string-match "^\\([a-z]+\\):/" uri) (when (string-match "^\\([a-z]+\\):/" uri)
(let* ((splitparts (split-string uri "/+"))) (let* ((splitparts (split-string uri "/+")))
(setq uri (concat (car splitparts) "//" (mapconcat 'identity (cdr splitparts) "/"))))) (setq uri (concat (car splitparts) "//"
(mapconcat #'identity (cdr splitparts) "/")))))
uri) uri)
(defun org-protocol-split-data (data &optional unhexify separator) (defun org-protocol-split-data (data &optional unhexify separator)
@ -549,10 +545,10 @@ Now template ?b will be used."
"Convert QUERY key=value pairs in the URL to a property list." "Convert QUERY key=value pairs in the URL to a property list."
(when query (when query
(let ((plus-decoded (replace-regexp-in-string "\\+" " " query t t))) (let ((plus-decoded (replace-regexp-in-string "\\+" " " query t t)))
(apply 'append (mapcar (lambda (x) (cl-mapcan (lambda (x)
(let ((c (split-string x "="))) (let ((c (split-string x "=")))
(list (intern (concat ":" (car c))) (cadr c)))) (list (intern (concat ":" (car c))) (cadr c))))
(split-string plus-decoded "&")))))) (split-string plus-decoded "&")))))
(defun org-protocol-open-source (fname) (defun org-protocol-open-source (fname)
"Process an org-protocol://open-source?url= style URL with FNAME. "Process an org-protocol://open-source?url= style URL with FNAME.
@ -641,7 +637,7 @@ Old-style links such as \"protocol://sub-protocol://param1/param2\" are
also recognized. also recognized.
If a matching protocol is found, the protocol is stripped from If a matching protocol is found, the protocol is stripped from
fname and the result is passed to the protocol function as the FNAME and the result is passed to the protocol function as the
first parameter. The second parameter will be non-nil if FNAME first parameter. The second parameter will be non-nil if FNAME
uses key=val&key2=val2-type arguments, or nil if FNAME uses uses key=val&key2=val2-type arguments, or nil if FNAME uses
val/val2-type arguments. If the function returns nil, the val/val2-type arguments. If the function returns nil, the
@ -687,12 +683,12 @@ to deal with new-style links.")
(throw 'fname t)))))))) (throw 'fname t))))))))
fname))) fname)))
(defadvice server-visit-files (before org-protocol-detect-protocol-server activate) (advice-add 'server-visit-files :around #'org--protocol-detect-protocol-server)
(defun org--protocol-detect-protocol-server (orig-fun files client &rest args)
"Advice server-visit-flist to call `org-protocol-modify-filename-for-protocol'." "Advice server-visit-flist to call `org-protocol-modify-filename-for-protocol'."
(let ((flist (if org-protocol-reverse-list-of-files (let ((flist (if org-protocol-reverse-list-of-files
(reverse (ad-get-arg 0)) (reverse files)
(ad-get-arg 0))) files)))
(client (ad-get-arg 1)))
(catch 'greedy (catch 'greedy
(dolist (var flist) (dolist (var flist)
;; `\' to `/' on windows. FIXME: could this be done any better? ;; `\' to `/' on windows. FIXME: could this be done any better?
@ -701,11 +697,16 @@ to deal with new-style links.")
fname (member var flist) client)) fname (member var flist) client))
(if (eq fname t) ;; greedy? We need the t return value. (if (eq fname t) ;; greedy? We need the t return value.
(progn (progn
(ad-set-arg 0 nil) ;; FIXME: Doesn't this just ignore all the files before
;; this one (the remaining ones have been passed to
;; `org-protocol-check-filename-for-protocol' but not
;; the ones before).
(setq files nil)
(throw 'greedy t)) (throw 'greedy t))
(if (stringp fname) ;; probably filename (if (stringp fname) ;; probably filename
(setcar var fname) (setcar var fname)
(ad-set-arg 0 (delq var (ad-get-arg 0)))))))))) (setq files (delq var files)))))))
(apply orig-fun files client args)))
;;; Org specific functions: ;;; Org specific functions:

View File

@ -67,7 +67,6 @@ just like `org-structure-template-alist'. The tempo snippet
Do not use \"I\" as a KEY, as it is reserved for expanding Do not use \"I\" as a KEY, as it is reserved for expanding
\"#+include\"." \"#+include\"."
:group 'org-tempo
:type '(repeat (cons (string :tag "Key") :type '(repeat (cons (string :tag "Key")
(string :tag "Keyword"))) (string :tag "Keyword")))
:package-version '(Org . "9.2")) :package-version '(Org . "9.2"))
@ -102,8 +101,8 @@ Tempo templates will be added."
Go through `org-structure-template-alist' and Go through `org-structure-template-alist' and
`org-tempo-keywords-alist' and update tempo templates." `org-tempo-keywords-alist' and update tempo templates."
(mapc 'org--check-org-structure-template-alist '(org-structure-template-alist (mapc #'org--check-org-structure-template-alist '(org-structure-template-alist
org-tempo-keywords-alist)) org-tempo-keywords-alist))
(let ((keys (org-tempo--keys))) (let ((keys (org-tempo--keys)))
;; Check for duplicated snippet keys and warn if any are found. ;; Check for duplicated snippet keys and warn if any are found.
(when (> (length keys) (length (delete-dups keys))) (when (> (length keys) (length (delete-dups keys)))
@ -176,8 +175,8 @@ didn't succeed."
;; Org Tempo is set up with each new Org buffer and potentially in the ;; Org Tempo is set up with each new Org buffer and potentially in the
;; current Org buffer. ;; current Org buffer.
(add-hook 'org-mode-hook 'org-tempo-setup) (add-hook 'org-mode-hook #'org-tempo-setup)
(add-hook 'org-tab-before-tab-emulation-hook 'org-tempo-complete-tag) (add-hook 'org-tab-before-tab-emulation-hook #'org-tempo-complete-tag)
;; Enable Org Tempo in all open Org buffers. ;; Enable Org Tempo in all open Org buffers.
(dolist (b (org-buffer-list 'files)) (dolist (b (org-buffer-list 'files))

View File

@ -8577,14 +8577,15 @@ This will temporarily bind local variables that are typically bound in
Org mode to the values they have in Org mode, and then interactively Org mode to the values they have in Org mode, and then interactively
call CMD." call CMD."
(org-load-modules-maybe) (org-load-modules-maybe)
(let (binds) (let (vars vals)
(dolist (var (org-get-local-variables)) (dolist (var (org-get-local-variables))
(when (or (not (boundp (car var))) (when (or (not (boundp (car var)))
(eq (symbol-value (car var)) (eq (symbol-value (car var))
(default-value (car var)))) (default-value (car var))))
(push (list (car var) `(quote ,(cadr var))) binds))) (push (car var) vars)
(eval `(let ,binds (push (cadr var) vals)))
(call-interactively (quote ,cmd)))))) (cl-progv vars vals
(call-interactively cmd))))
(defun org-get-category (&optional pos force-refresh) (defun org-get-category (&optional pos force-refresh)
"Get the category applying to position POS." "Get the category applying to position POS."
@ -9513,7 +9514,7 @@ block can be inserted by pressing TAB after the string \"<KEY\"."
In particular, check if the Org 9.2 format is used as opposed to In particular, check if the Org 9.2 format is used as opposed to
previous format." previous format."
(let ((elm (cl-remove-if-not (lambda (x) (listp (cdr x))) (let ((elm (cl-remove-if-not (lambda (x) (listp (cdr x)))
(or (eval checklist) (or (symbol-value checklist)
org-structure-template-alist)))) org-structure-template-alist))))
(when elm (when elm
(org-display-warning (org-display-warning
@ -12804,7 +12805,7 @@ a *different* entry, you cannot use these techniques."
;; Get the right scope ;; Get the right scope
(cond (cond
((and scope (listp scope) (symbolp (car scope))) ((and scope (listp scope) (symbolp (car scope)))
(setq scope (eval scope))) (setq scope (eval scope t)))
((eq scope 'agenda) ((eq scope 'agenda)
(setq scope (org-agenda-files t))) (setq scope (org-agenda-files t)))
((eq scope 'agenda-with-archives) ((eq scope 'agenda-with-archives)
@ -14625,7 +14626,7 @@ Unless KEEPDATE is non-nil, update `org-ans2' to the cursor date."
(let ((sf (selected-frame)) (let ((sf (selected-frame))
(sw (selected-window))) (sw (selected-window)))
(select-window (get-buffer-window "*Calendar*" t)) (select-window (get-buffer-window "*Calendar*" t))
(eval form) (eval form t)
(when (and (not keepdate) (calendar-cursor-to-date)) (when (and (not keepdate) (calendar-cursor-to-date))
(let* ((date (calendar-cursor-to-date)) (let* ((date (calendar-cursor-to-date))
(time (encode-time 0 0 0 (nth 1 date) (nth 0 date) (nth 2 date)))) (time (encode-time 0 0 0 (nth 1 date) (nth 0 date) (nth 2 date))))
@ -15039,9 +15040,9 @@ D may be an absolute day number, or a calendar-type list (month day year)."
(let* ((sexp `(let ((entry ,entry) (let* ((sexp `(let ((entry ,entry)
(date ',d)) (date ',d))
,(car (read-from-string sexp)))) ,(car (read-from-string sexp))))
(result (if calendar-debug-sexp (eval sexp) (result (if calendar-debug-sexp (eval sexp t)
(condition-case nil (condition-case nil
(eval sexp) (eval sexp t)
(error (error
(beep) (beep)
(message "Bad sexp at line %d in %s: %s" (message "Bad sexp at line %d in %s: %s"
@ -15974,25 +15975,29 @@ in Org mode.
(cdlatex-compute-tables)) (cdlatex-compute-tables))
(unless org-cdlatex-texmathp-advice-is-done (unless org-cdlatex-texmathp-advice-is-done
(setq org-cdlatex-texmathp-advice-is-done t) (setq org-cdlatex-texmathp-advice-is-done t)
(defadvice texmathp (around org-math-always-on activate) (advice-add 'texmathp :around #'org--math-always-on)))
"Always return t in Org buffers.
(defun org--math-always-on (orig-fun &rest args)
"Always return t in Org buffers.
This is because we want to insert math symbols without dollars even outside This is because we want to insert math symbols without dollars even outside
the LaTeX math segments. If Org mode thinks that point is actually inside the LaTeX math segments. If Org mode thinks that point is actually inside
an embedded LaTeX fragment, let `texmathp' do its job. an embedded LaTeX fragment, let `texmathp' do its job.
`\\[org-cdlatex-mode-map]'" `\\[org-cdlatex-mode-map]'"
(interactive) (interactive)
(let (p) (cond
(cond ((not (derived-mode-p 'org-mode)) (apply orig-fun args))
((not (derived-mode-p 'org-mode)) ad-do-it) ((eq this-command 'cdlatex-math-symbol)
((eq this-command 'cdlatex-math-symbol) (setq texmathp-why '("cdlatex-math-symbol in org-mode" . 0))
(setq ad-return-value t t)
texmathp-why '("cdlatex-math-symbol in org-mode" . 0))) (t
(t (let ((p (org-inside-LaTeX-fragment-p)))
(let ((p (org-inside-LaTeX-fragment-p))) (when p ;; FIXME: Shouldn't we return t when `p' is nil?
(if (and p (member (car p) (plist-get org-format-latex-options :matchers))) (if (member (car p)
(setq ad-return-value t (plist-get org-format-latex-options :matchers))
texmathp-why '("Org mode embedded math" . 0)) (progn
(when p ad-do-it))))))))) (setq texmathp-why '("Org mode embedded math" . 0))
t)
(apply orig-fun args)))))))
(defun turn-on-org-cdlatex () (defun turn-on-org-cdlatex ()
"Unconditionally turn on `org-cdlatex-mode'." "Unconditionally turn on `org-cdlatex-mode'."
@ -16952,8 +16957,8 @@ overwritten, and the table is not marked as requiring realignment."
(call-interactively org-speed-command)) (call-interactively org-speed-command))
((functionp org-speed-command) ((functionp org-speed-command)
(funcall org-speed-command)) (funcall org-speed-command))
((and org-speed-command (listp org-speed-command)) ((consp org-speed-command)
(eval org-speed-command)) (eval org-speed-command t))
(t (let (org-use-speed-commands) (t (let (org-use-speed-commands)
(call-interactively 'org-self-insert-command))))) (call-interactively 'org-self-insert-command)))))
((and ((and
@ -18781,7 +18786,8 @@ such private information before sending the email.")
(string-match "\\(-hook\\|-function\\)\\'" (symbol-name v))) (string-match "\\(-hook\\|-function\\)\\'" (symbol-name v)))
(and (and
(get v 'custom-type) (get v 'standard-value) (get v 'custom-type) (get v 'standard-value)
(not (equal (symbol-value v) (eval (car (get v 'standard-value))))))) (not (equal (symbol-value v)
(eval (car (get v 'standard-value)) t)))))
(push v list))))) (push v list)))))
(kill-buffer (get-buffer "*Warn about privacy*")) (kill-buffer (get-buffer "*Warn about privacy*"))
list)) list))

View File

@ -362,7 +362,6 @@ When this option is turned on, `indent-region' is run on all
component xml buffers before they are saved. Turn this off for component xml buffers before they are saved. Turn this off for
regular use. Turn this on if you need to examine the xml regular use. Turn this on if you need to examine the xml
visually." visually."
:group 'org-export-odt
:version "24.1" :version "24.1"
:type 'boolean) :type 'boolean)
@ -399,7 +398,6 @@ with GNU ELPA tar or standard Emacs distribution."
:type '(choice :type '(choice
(const :tag "Not set" nil) (const :tag "Not set" nil)
(directory :tag "Schema directory")) (directory :tag "Schema directory"))
:group 'org-export-odt
:version "24.1" :version "24.1"
:set :set
(lambda (var value) (lambda (var value)
@ -437,7 +435,6 @@ If unspecified, the file named \"OrgOdtContentTemplate.xml\"
under `org-odt-styles-dir' is used." under `org-odt-styles-dir' is used."
:type '(choice (const nil) :type '(choice (const nil)
(file)) (file))
:group 'org-export-odt
:version "24.3") :version "24.3")
(defcustom org-odt-styles-file nil (defcustom org-odt-styles-file nil
@ -471,7 +468,6 @@ a per-file basis. For example,
#+ODT_STYLES_FILE: \"/path/to/styles.xml\" or #+ODT_STYLES_FILE: \"/path/to/styles.xml\" or
#+ODT_STYLES_FILE: (\"/path/to/file.ott\" (\"styles.xml\" \"image/hdr.png\"))." #+ODT_STYLES_FILE: (\"/path/to/file.ott\" (\"styles.xml\" \"image/hdr.png\"))."
:group 'org-export-odt
:version "24.1" :version "24.1"
:type :type
'(choice '(choice
@ -486,7 +482,6 @@ a per-file basis. For example,
(defcustom org-odt-display-outline-level 2 (defcustom org-odt-display-outline-level 2
"Outline levels considered for enumerating captioned entities." "Outline levels considered for enumerating captioned entities."
:group 'org-export-odt
:version "24.4" :version "24.4"
:package-version '(Org . "8.0") :package-version '(Org . "8.0")
:type 'integer) :type 'integer)
@ -516,7 +511,6 @@ specifiers are interpreted as below:
%d output dir in full %d output dir in full
%D output dir as a URL. %D output dir as a URL.
%x extra options as set in `org-odt-convert-capabilities'." %x extra options as set in `org-odt-convert-capabilities'."
:group 'org-export-odt
:version "24.1" :version "24.1"
:type :type
'(choice '(choice
@ -529,7 +523,6 @@ specifiers are interpreted as below:
"Use this converter to convert from \"odt\" format to other formats. "Use this converter to convert from \"odt\" format to other formats.
During customization, the list of converter names are populated During customization, the list of converter names are populated
from `org-odt-convert-processes'." from `org-odt-convert-processes'."
:group 'org-export-odt
:version "24.1" :version "24.1"
:type '(choice :convert-widget :type '(choice :convert-widget
(lambda (w) (lambda (w)
@ -591,7 +584,6 @@ format) to be converted to any of the export formats associated
with that class. with that class.
See default setting of this variable for a typical configuration." See default setting of this variable for a typical configuration."
:group 'org-export-odt
:version "24.1" :version "24.1"
:type :type
'(choice '(choice
@ -618,7 +610,6 @@ variable, the list of valid values are populated based on
You can set this option on per-file basis using file local You can set this option on per-file basis using file local
values. See Info node `(emacs) File Variables'." values. See Info node `(emacs) File Variables'."
:group 'org-export-odt
:version "24.1" :version "24.1"
:type '(choice :convert-widget :type '(choice :convert-widget
(lambda (w) (lambda (w)
@ -644,7 +635,6 @@ The function must accept two parameters:
The function should return the string to be exported. The function should return the string to be exported.
The default value simply returns the value of CONTENTS." The default value simply returns the value of CONTENTS."
:group 'org-export-odt
:version "26.1" :version "26.1"
:package-version '(Org . "8.3") :package-version '(Org . "8.3")
:type 'function) :type 'function)
@ -664,7 +654,6 @@ TEXT the main headline text (string).
TAGS the tags string, separated with colons (string or nil). TAGS the tags string, separated with colons (string or nil).
The function result will be used as headline text." The function result will be used as headline text."
:group 'org-export-odt
:version "26.1" :version "26.1"
:package-version '(Org . "8.3") :package-version '(Org . "8.3")
:type 'function) :type 'function)
@ -685,7 +674,6 @@ The function must accept six parameters:
CONTENTS the contents of the inlinetask, as a string. CONTENTS the contents of the inlinetask, as a string.
The function should return the string to be exported." The function should return the string to be exported."
:group 'org-export-odt
:version "26.1" :version "26.1"
:package-version '(Org . "8.3") :package-version '(Org . "8.3")
:type 'function) :type 'function)
@ -712,7 +700,6 @@ nil Ignore math snippets.
be loaded. be loaded.
Any other symbol is a synonym for `mathjax'." Any other symbol is a synonym for `mathjax'."
:group 'org-export-odt
:version "24.4" :version "24.4"
:package-version '(Org . "8.0") :package-version '(Org . "8.0")
:type '(choice :type '(choice
@ -732,7 +719,6 @@ Any other symbol is a synonym for `mathjax'."
A rule consists in an association whose key is the type of link A rule consists in an association whose key is the type of link
to consider, and value is a regexp that will be matched against to consider, and value is a regexp that will be matched against
link's path." link's path."
:group 'org-export-odt
:version "24.4" :version "24.4"
:package-version '(Org . "8.0") :package-version '(Org . "8.0")
:type '(alist :key-type (string :tag "Type") :type '(alist :key-type (string :tag "Type")
@ -745,7 +731,6 @@ link's path."
A rule consists in an association whose key is the type of link A rule consists in an association whose key is the type of link
to consider, and value is a regexp that will be matched against to consider, and value is a regexp that will be matched against
link's path." link's path."
:group 'org-export-odt
:version "26.1" :version "26.1"
:package-version '(Org . "8.3") :package-version '(Org . "8.3")
:type '(alist :key-type (string :tag "Type") :type '(alist :key-type (string :tag "Type")
@ -756,7 +741,6 @@ link's path."
Use this for sizing of embedded images. See Info node `(org) Use this for sizing of embedded images. See Info node `(org)
Images in ODT export' for more information." Images in ODT export' for more information."
:type 'float :type 'float
:group 'org-export-odt
:version "24.4" :version "24.4"
:package-version '(Org . "8.1")) :package-version '(Org . "8.1"))
@ -778,7 +762,6 @@ styles.xml already contains needed styles for colorizing to work.
This variable is effective only if `org-odt-fontify-srcblocks' is This variable is effective only if `org-odt-fontify-srcblocks' is
turned on." turned on."
:group 'org-export-odt
:version "24.1" :version "24.1"
:type 'boolean) :type 'boolean)
@ -788,7 +771,6 @@ Turn this option on if you want to colorize the source code
blocks in the exported file. For colorization to work, you need blocks in the exported file. For colorization to work, you need
to make available an enhanced version of `htmlfontify' library." to make available an enhanced version of `htmlfontify' library."
:type 'boolean :type 'boolean
:group 'org-export-odt
:version "24.1") :version "24.1")
@ -873,7 +855,6 @@ implementation filed under `org-odt-get-table-cell-styles'.
The TABLE-STYLE-NAME \"OrgEquation\" is used internally for The TABLE-STYLE-NAME \"OrgEquation\" is used internally for
formatting of numbered display equations. Do not delete this formatting of numbered display equations. Do not delete this
style from the list." style from the list."
:group 'org-export-odt
:version "24.1" :version "24.1"
:type '(choice :type '(choice
(const :tag "None" nil) (const :tag "None" nil)
@ -918,7 +899,6 @@ document by setting the default language and country either using
the application UI or through a custom styles file. the application UI or through a custom styles file.
See `org-odt--build-date-styles' for implementation details." See `org-odt--build-date-styles' for implementation details."
:group 'org-export-odt
:version "24.4" :version "24.4"
:package-version '(Org . "8.0") :package-version '(Org . "8.0")
:type 'boolean) :type 'boolean)
@ -2005,14 +1985,16 @@ information."
;;;; Latex Environment ;;;; Latex Environment
;; (eval-after-load 'ox-odt '(ad-deactivate 'org-format-latex-as-mathml)) ;; (eval-after-load 'ox-odt '(ad-deactivate 'org-format-latex-as-mathml))
;; (defadvice org-format-latex-as-mathml ; FIXME ;; (advice-add 'org-format-latex-as-mathml ; FIXME
;; (after org-odt-protect-latex-fragment activate) ;; :around #'org--odt-protect-latex-fragment)
;; (defun org--odt-protect-latex-fragment (orig-fun latex-frag &rest args)
;; "Encode LaTeX fragment as XML. ;; "Encode LaTeX fragment as XML.
;; Do this when translation to MathML fails." ;; Do this when translation to MathML fails."
;; (unless (> (length ad-return-value) 0) ;; (let ((retval (apply orig-fun latex-frag args)))
;; (setq ad-return-value (org-odt--encode-plain-text (ad-get-arg 0))))) ;; (if (> (length retval) 0)
;; retval
;; (org-odt--encode-plain-text latex-frag))))
(defun org-odt-latex-environment (latex-environment _contents info) (defun org-odt-latex-environment (latex-environment _contents info)
"Transcode a LATEX-ENVIRONMENT element from Org to ODT. "Transcode a LATEX-ENVIRONMENT element from Org to ODT.