Грамотное программирование с использованием org-babel

Я нахожусь на грамотной программе, используя org-babel. Мой источник структурирован так,

-imports
-utility fns
-game structure
 - detailed explanations

Это нормальная структура кода, я хотел бы переместить объяснения утилиты fns в конец, чтобы она не отображалась первой в сгенерированном файле pdf. Теперь это можно сделать с расширением noweb, но проблема в том, что когда у вас много маленьких функций для каждой, мне нужно добавить src_block с уникальным именем, прокрутить файл вниз и добавить ссылку на него в файле, который действительно раздражает., Есть ли способ назвать все src_blocks в разделе? скажем, весь код в этом разделе переходит в блок А.

1 ответ

Решение

Вы можете дать несколько кусков с тем же именем. Например, я создаю свой файл.emacs с помощью org-tangle, и в верхней части файла org у меня есть главный шаблон, который выглядит примерно так:

#+begin_src emacs-lisp :tangle "/path/to/.emacs" :comments both :noweb tangle
<<generated-file-warning>
<<includes>>
<<definitions>>
<<settings>>
<<generated-file-warning>
#+end_src

Под этим у меня есть схема с исходными блоками, вот так:

* extensions
** yasnippet

#+name: early-includes
#+begin_src emacs-lisp
(require 'yasnippet)
(yas/initialize)
#+end_src

#+name: settings
#+begin_src emacs-lisp
(yas/load/directory "/path/to/my/snippets")
#+end_src

Примечание: для более старых версий режима org вам может понадобиться #+srcname: вместо #+name:

Вы также можете создать свойство под названиемnoweb-ref, который применяет одно и то же имя ко всем исходным блокам в поддереве.

Другие вопросы по тегам