Tangling Examples in Emacs

Tried literate programming with Org and Emacs, but want to know the details of what files goes where and how to specify it? Let’s look at each approach with some examples.

First, the default value for the tangle property is no, but we could change this per file (not globally that I’ve found), with the following setting somewhere in your org file:

#+PROPERTY: header-args :tangle yes

However, to get this to actually work, you need to enter C-c C-c on that line. If you read the file into Emacs, those lines are automatically operated, so the C-c C-c trick is only needed when added or changed.

Emacs bases the filename for the source code on the original org file. For instance, here is example-1.org:

#+PROPERTY:    header-args :tangle yes

Just an example.

#+begin_src sh
echo "Hello"
#+end_src

And another language:

#+begin_src python
print("Hello")
#+end_src

Creates two files, example-1.sh:

echo "Hello"

And example-1.python:

print("Hello")

Wait? By example-1.python? Shouldn’t the extension be .py? Well, it should. Normally, if I don’t use the yes parameter, and instead specify what filenames (and its location) I want to store all of those files. Let’s try example-2.org that has more control:

#+PROPERTY:    header-args:shell :tangle no
#+PROPERTY:    header-args:python  :tangle /tmp/tangling-examples/example-2.py

Just an example.

#+begin_src shell
echo "Hello"
#+end_src

And another language:

#+begin_src python
print("Hello")
#+end_src

Hitting C-c C-c on both of those two lines sets the configuration so that when we tangle, C-c C-v t, we get a single file, example-2.py with the correct extension.

Tangled Results per Section

The previous example shows my typical use case, however, you can get create