Add a function to execute a named source block interactively
This commit is contained in:
parent
6b38f282a5
commit
d1f7e96f51
62
README.org
62
README.org
@ -2274,27 +2274,29 @@ list detailing and motivating each listing:
|
|||||||
1. Listing [[lst:set-org-options]] handles basic [[https://orgmode.org/][Org-mode]] options.
|
1. Listing [[lst:set-org-options]] handles basic [[https://orgmode.org/][Org-mode]] options.
|
||||||
2. Listing [[lst:setup-org-babel]] handles basic [[https://orgmode.org/][Org-mode]] options specific to
|
2. Listing [[lst:setup-org-babel]] handles basic [[https://orgmode.org/][Org-mode]] options specific to
|
||||||
[[info:org#Working with Source Code][work with source code (info)]].
|
[[info:org#Working with Source Code][work with source code (info)]].
|
||||||
3. Listing [[lst:ob-tangle-plus]] extends [[info:org#Noweb Reference Syntax][source code export (info)]] with the
|
3. Listing [[lst:org-babel-execute-named-block]] adds a function to execute a named
|
||||||
|
source block interactively.
|
||||||
|
4. Listing [[lst:ob-tangle-plus]] extends [[info:org#Noweb Reference Syntax][source code export (info)]] with the
|
||||||
possibility to tangle of for instance Emacs Lisp files (or other programming
|
possibility to tangle of for instance Emacs Lisp files (or other programming
|
||||||
mode files) into a directory specified by ~org-babel-post-tangle-dir~ which
|
mode files) into a directory specified by ~org-babel-post-tangle-dir~ which
|
||||||
can be changed using =org-get-entry= to read lines like ~#+property:
|
can be changed using =org-get-entry= to read lines like ~#+property:
|
||||||
tangle-dir: ANY-PLACE~ near the beginning an Org file.
|
tangle-dir: ANY-PLACE~ near the beginning an Org file.
|
||||||
4. Listing [[lst:set-org-link-options]] handles [[https://orgmode.org/][Org-mode]] options specific to
|
5. Listing [[lst:set-org-link-options]] handles [[https://orgmode.org/][Org-mode]] options specific to
|
||||||
[[info:org#Hyperlinks][hyperlinks (info)]].
|
[[info:org#Hyperlinks][hyperlinks (info)]].
|
||||||
5. Listing [[lst:setup-org-mode-map-1]] and [[lst:setup-org-mode-map-2]] extend the
|
6. Listing [[lst:setup-org-mode-map-1]] and [[lst:setup-org-mode-map-2]] extend the
|
||||||
=org-mode-map= with useful key-bindings.
|
=org-mode-map= with useful key-bindings.
|
||||||
6. Listing [[lst:setup-org-src]] facilitates [[info:org#Editing Source Code][editing source code blocks]], and it
|
7. Listing [[lst:setup-org-src]] facilitates [[info:org#Editing Source Code][editing source code blocks]], and it
|
||||||
provides functions to change the indentation of all =org-src-mode= blocks.
|
provides functions to change the indentation of all =org-src-mode= blocks.
|
||||||
7. Listing [[lst:setup-ob-python]] allows to pretty-print Python session source
|
8. Listing [[lst:setup-ob-python]] allows to pretty-print Python session source
|
||||||
block values with [[https://github.com/psf/black#readme][black]] instead of [[https://docs.python.org/3/library/pprint.html][pprint]]. This snippet may break in the
|
block values with [[https://github.com/psf/black#readme][black]] instead of [[https://docs.python.org/3/library/pprint.html][pprint]]. This snippet may break in the
|
||||||
future, because it sets =org-babel-python--def-format-value= which is a
|
future, because it sets =org-babel-python--def-format-value= which is a
|
||||||
constant declared "private" by two dashes in its name!
|
constant declared "private" by two dashes in its name!
|
||||||
8. Listing [[lst:set-org-export-options]] selects the =non-intrusive= expert user
|
9. Listing [[lst:set-org-export-options]] selects the =non-intrusive= expert user
|
||||||
interface for export dispatching.
|
interface for export dispatching.
|
||||||
9. Listing [[lst:setup-org-for-lualatex-export]] and
|
10. Listing [[lst:setup-org-for-lualatex-export]] and
|
||||||
[[lst:set-ox-latex-options-for-lualatex-export]] configure [[https://orgmode.org/][Org-mode]] to generate
|
[[lst:set-ox-latex-options-for-lualatex-export]] configure [[https://orgmode.org/][Org-mode]] to generate
|
||||||
output for the LuaLaTeX compiler.
|
output for the LuaLaTeX compiler.
|
||||||
10. Listing [[lst:setup-org-latex-classes]] defines [[info:org#LaTeXspecificexportsettings][org-latex-classes (info)]] for
|
11. Listing [[lst:setup-org-latex-classes]] defines [[info:org#LaTeXspecificexportsettings][org-latex-classes (info)]] for
|
||||||
backward compatibility. See table [[tab:org-latex-class-tag-placeholder]] and
|
backward compatibility. See table [[tab:org-latex-class-tag-placeholder]] and
|
||||||
type {{{kbd(C-h v org-latex-classes)}}} for an explanation of the code in
|
type {{{kbd(C-h v org-latex-classes)}}} for an explanation of the code in
|
||||||
listing [[lst:setup-org-latex-classes]].
|
listing [[lst:setup-org-latex-classes]].
|
||||||
@ -2365,6 +2367,50 @@ list detailing and motivating each listing:
|
|||||||
(setopt org-babel-lisp-eval-fn #'sly-eval)))
|
(setopt org-babel-lisp-eval-fn #'sly-eval)))
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
#+caption[Add function to execute a named source block interactively]:
|
||||||
|
#+caption: Add function to execute a named source block interactively.
|
||||||
|
#+name: lst:org-babel-execute-named-block
|
||||||
|
#+begin_src emacs-lisp -n :results silent
|
||||||
|
(with-eval-after-load 'ob-core
|
||||||
|
(defun org-babel--source-block-names (&optional language)
|
||||||
|
"Return an alist of source block name strings and language symbols.
|
||||||
|
When LANGUAGE is non-nil, restrict the alist to named LANGUAGE blocks."
|
||||||
|
(when (stringp language)
|
||||||
|
(if (string= language "elisp")
|
||||||
|
(setq language nil)
|
||||||
|
(setq language (intern-soft language)))
|
||||||
|
(unless language
|
||||||
|
(user-error "Correct the LANGUAGE string or use a LANGUAGE symbol")))
|
||||||
|
(let (result)
|
||||||
|
(save-excursion
|
||||||
|
(goto-char (point-min))
|
||||||
|
(while (re-search-forward org-babel-src-block-regexp nil t)
|
||||||
|
(when (org-babel-active-location-p)
|
||||||
|
(when-let ((lang (intern-soft (match-string 2)))
|
||||||
|
(name (org-element-property :name (org-element-at-point))))
|
||||||
|
(when (or (not language) (eq lang language))
|
||||||
|
(push (cons name lang)
|
||||||
|
result))))))
|
||||||
|
(reverse result)))
|
||||||
|
|
||||||
|
(defun org-babel-execute-named-block (&optional arg)
|
||||||
|
"Execute a named source block after prompting for a source block name.
|
||||||
|
When prefix ARG is non-nil, prompt first for a language."
|
||||||
|
(interactive "P")
|
||||||
|
(let (language)
|
||||||
|
(when arg
|
||||||
|
(setq language (completing-read "language: " org-babel-load-languages)))
|
||||||
|
(if-let* ((names (org-babel--source-block-names language))
|
||||||
|
(name (completing-read "name: " names)))
|
||||||
|
(if (cl-remove-if-not (lambda (pair) (string= name (car pair))) names)
|
||||||
|
(save-excursion
|
||||||
|
(org-babel-goto-named-src-block name)
|
||||||
|
(org-babel-execute-maybe))
|
||||||
|
(user-error "There is no named %S of language %S block"
|
||||||
|
name (or language "any-org-babel-load-language")))
|
||||||
|
(user-error "There are no named language %S blocks" language)))))
|
||||||
|
#+end_src
|
||||||
|
|
||||||
#+caption[Change the =org-babel-tangle= destination to a specific directory]:
|
#+caption[Change the =org-babel-tangle= destination to a specific directory]:
|
||||||
#+caption: Change the =org-babel-tangle= destination to a specific directory.
|
#+caption: Change the =org-babel-tangle= destination to a specific directory.
|
||||||
#+name: lst:ob-tangle-plus
|
#+name: lst:ob-tangle-plus
|
||||||
|
Loading…
Reference in New Issue
Block a user