DEV Community

Victor Dorneanu
Victor Dorneanu

Posted on • Originally published at blog.dornea.nu on

Migrate Tiddlywiki to org-roam - Part 1: Export Tiddlers

In the first part of this series I’ll outline the main factors why I’ve decided to move my digital garden / braindump / Zettelkasten to org-roam and which factors have facilitated this decision. In the 2nd part (still work in progress) I will expand more how I’ve built the new brainfck.org using hugo, ox-hugo and org-roam.

Motivation

I’ve been using Tiddlywiki for almost 10 years now and setup different instances for work, personal stuff and lately as my own personal knowledge management system. I’ve used it to save highlights, notes, quotes from different sources and organized them in an useful way. I used daily journaling to handle the daily input of ideas and (web) articles I’m constantly exposed to. I talked at work about the importance of PKMS and how Tiddlywiki can increase productivity and contribute to better (mental) health by using it as a second brain1.

Basically it’s all about giving your a brain a rest and offload information to a medium so your brain doesn’t have to remember everything:

Your brain is for having ideas, not for holding them – Getting Things Done

While I initially started using just one single HTML file for my tiddlers, I soon switched over to the nodeJS installation. This still has better benefits like:

  • you can run the instance in Docker
    • install tiddlywiki and its dependencies without messing around with your system
  • you’ll get multiple “flat” files (.tid files are in plain text)
    • you can apply sed, awk, bash foo to extract/modify data
    • even if Tiddlywiki will be discontinued some day, you’ll still be able to import your notes in whatever note-taking syntax

Tiddlywiki old
old brainfck - Now available at https://tw5.brainfck.org

Among the many packages I’ve used, stroll has definitely changed the way I interacted with Tiddlywiki. It allowed me to focus more on the note-taking process by dividing the screen into 2 columns. This allowed me to work on different tiddlers simultaneously. Still it took me hours to process my notes and digitize them into Tiddlywiki. I guess the UI kind of slowed me down, mostly because I’m a keyboard-centric_user and don’t use the mouse that often. Switching between tiddlers, closing them, creating new ones always involved _mouse interaction.

Tiddlywiki stroll
Tiddlywiki using stroll

For the same reason I’ve been using VIM for more than a decade and since more than 2 years I’m happy to consider myself an evil Emacs user. It became not only my primary editor, but also my RSS feeds reader, mail client, YouTube video player, IDE, API client… I basically live in Emacs2 and try to avoid as many context switches as possible.

Personal preferences

ORG mode as lingua franca

After going down the Emacs rabbit hole, I’ve adopted ORG mode as my main file format for writing documents, exporting these to other formats (PDF, markdown, Confluence, Jira and many others), creating diagrams (mainly plantuml), presentations, writing technical documentation and hopefully some day for publishing a whole book. For the note-taking phase I write my notes in ORG mode and create a rudimentary outline sorted by chapters/sections. Usually I use the same structure to create my blog posts from (like I did in the book summaries). Extracting pieces of information for individual tiddlers, however, tends to be a time-intensive process. I’ve managed to use the Tiddlywiki API within Emacs but my Elisp skills are still not good for doing more advanced stuff like:

  • fetch existing tiddlers, modify body in a new buffer, save new tiddler
  • when linking text to new/existing tiddler, show list (in the minibuffer) of Tiddlers and if not create new one(s)
  • show cross-references (e. g. Backlinks) for a specific tiddler
  • refile specific (ORG) headline to a new tiddler

All these features are some however doable within Tiddlywiki using stroll and streams. But I don’t want to use the web UI anymore since I’m already inside Emacs for the majority of the day 😅

Editing on steroids

At some point I began adopting ORG style syntax for the new tiddlers too:

Tiddlywiki Syntax
Tiddlywiki Syntax

If you pay attention, there are lots of similarities. That’s why I could easily copy and paste most of the ORG content into the tiddlers. As for the rest (source blocks, quotes, examples, sidenotes etc.) manual conversion (or using ox-tiddly ) was necessary.

It was especially this part that slowed me down in my post-reading process mainly because:

  • I’m writing my notes in Emacs (using ORG)
    • converting to full tiddlywiki syntax takes time
  • in some of blog posts (written in ORG) I wanted to include some content from different tiddlers
    • I had to convert Tiddlywiki content back to ORG syntax again

This back and forth between ORG/Emacs and Tiddlywiki combined with the fact I was maintaining multiples sources of information (my raw notes in ORG, my own thoughts / processed notes in Tiddlywiki) brought me to org-roam. Not only this, but it also forced me to rethink my note-taking workflow and make adjustments to the whole system.

I’ll explicitly cover org-roam, hugo and ox-hugo in the next part.

Exporting from Tiddlywiki

As I’ve started exporting my notes from Tiddlywiki I soon realized there are 2 options to do so:

Export tiddlers

David Alfonso has done a great job and put together a repository that helps you with the export of tiddlers. All you need is to export all your tiddlers bundled as one single HTML and then follow the instructions in the README.

In my Tiddlywiki root directory I had a tiddlywiki.info with a build step to export all tiddlers:

ls -l
cat tiddlywiki.info
Enter fullscreen mode Exit fullscreen mode
total 168
drwxr-xr-x 3 victor users   4096 Aug 30 06:09 output
drwxr-xr-x 2 victor users 163840 Aug 29 21:14 tiddlers
-rw-r--r-- 1 victor users   1316 Aug 16 06:00 tiddlywiki.info
{
    "description": "Basic client-server edition",
    "plugins": [
        "tiddlywiki/tiddlyweb",
        "tiddlywiki/filesystem",
        "tiddlywiki/highlight"
    ],
    "themes": [
        "tiddlywiki/vanilla",
        "tiddlywiki/snowwhite"
    ],
    "build": {
        "index": [
            "--rendertiddler",
            "$:/plugins/tiddlywiki/tiddlyweb/save/offline",
            "index.html",
            "text/plain"
        ],
        "static": [
            "--rendertiddler",
            "$:/core/templates/static.template.html",
            "static.html",
            "text/plain",
            "--rendertiddler",
            "$:/core/templates/alltiddlers.template.html",
            "alltiddlers.html",
            "text/plain",
            "--rendertiddlers",
            "[!is[system]]",
            "$:/core/templates/static.tiddler.html",
            "static",
            "text/plain",
            "--rendertiddler",
            "$:/core/templates/static.template.css",
            "static/static.css",
            "text/plain"
        ],
        "books": [
            "--render",
            "[!is[system]prefix[Cashkurs]tag[Book]]",
            "[encodeuricomponent[]addprefix[books/]addsuffix[.org]]",
            "text/plain",
            "$:/vd/templates/render-book"
        ]
    }
}
Enter fullscreen mode Exit fullscreen mode

Now let's generate the single HTML file:

tiddlywiki . --build index
ls -lh ./output/index.html
Enter fullscreen mode Exit fullscreen mode
: -rw-r--r-- 1 victor users 6.0M Aug 30 06:09 ./output/index.html
Enter fullscreen mode Exit fullscreen mode

Generate HTML and meta files

Once you have generated your single HTML Tiddlywiki file, clone the repository and copy your file to wiki.html inside the repository’s root folder. Then you can run make to export your tiddlers.

Afterwards, for each tiddler, you will get:

  • a HTML file (with the tiddler’s content)
  • a meta file (containing header information)

Original tiddler gets exported into one HTML and one meta file
The original tiddler gets exported into one HTML and one meta file

As an example (for the “zucker” tiddler):

cat ./tmp_wiki/output/zucker.html
Enter fullscreen mode Exit fullscreen mode
<ul>
  <li>Auch Saccharose</li>
  <li>Gehört zur Familie der Saccharide</li>
  <li>
    Formen
    <ul>
      <li>
        Einfachzucker
        <ul>
          <li>
            <a class="tc-tiddlylink tc-tiddlylink-resolves" href="#Glukose"
              >Glukose</a
            >
          </li>
          <li>
            <a class="tc-tiddlylink tc-tiddlylink-resolves" href="#Fruktose"
              >Fruktose</a
            >
          </li>
        </ul>
      </li>
      <li>
        Mehrfachzucker
        <ul>
          <li>Stärke</li>
        </ul>
      </li>
    </ul>
  </li>
  <li>
    Haushaltszucker
    <ul>
      <li>Dissacharid</li>
      <li>
        Besteht aus 2 Monosacchariden
        <ul>
          <li>Glukose (Traubenzucker)</li>
          <li>Fruktose (Fruchtzucker)</li>
        </ul>
      </li>
    </ul>
  </li>
  <li>
    <a class="tc-tiddlylink tc-tiddlylink-resolves" href="#S%C3%BC%C3%9Fstoffe"
      >Süßstoffe</a
    >
  </li>
</ul>
Enter fullscreen mode Exit fullscreen mode

And now the ~meta~ data:

cat ./tmp_wiki/output/zucker.meta
Enter fullscreen mode Exit fullscreen mode
created: 20200727100215598
lang: de
modified: 20210518184433986
origin: [[<<. bibliography "Der Ernährungskompass" "Der Ernährungskompass">>]]
revision: 0
tags:
title: Zucker
tmap.id: c268554d-9122-4728-88e0-0549ec026010
type: text/vnd.tiddlywiki
Enter fullscreen mode Exit fullscreen mode

Convert to ORG mode

The original repository will export by default all tiddlers to markdown. Since pandoc is used we can also export to ORG mode directly by changing the Makefile 3.

Instead of exporting to commonmark we export to markdown first:

...
$(MARKDOWN_DIR)/%.md : $(TW_OUTPUT_DIR)/%.html
    @echo "Generating markdown file '$(@F)'..."
    @$(PANDOC) -f html-native_divs-native_spans -t markdown \
        --wrap=none -o - "$^" >> "$@"
...
Enter fullscreen mode Exit fullscreen mode

Then for every generated markdown file we

  • add #+ to every header line (in the corresponding .meta file)
  • insert a newline after header lines
  • convert the markdown file to ORG format
...

$(ORG_DIR)/%.org : $(MARKDOWN_DIR)/%.md
    @echo "Generating ORG file '$(@F)'..."

    # Add #+ to every header line
 @cat "$(TW_OUTPUT_DIR)/`basename $^ .md`.meta" | sed -s 's/^/#+/' >> "$@"

    # Insert newline after header lines
 @echo "" >> "$@"

    # Convert from markdown to org
 @$(PANDOC) -f markdown -t org --wrap=none -o - "$^" >> "$@"

...
Enter fullscreen mode Exit fullscreen mode

Combined files
The ORG file consists of the meta file (where every line is prepended by #+) and the corresponding markdown file.

This is how the final ORG file looks like:

cat org_tiddlers/zucker.org
Enter fullscreen mode Exit fullscreen mode
#+caption: Generated ORG file
#+RESULTS:
#+begin_src org
,#+created: 20200727100215598
,#+lang: de
,#+modified: 20210518184433986
,#+origin: [[<<. bibliography "Der Ernährungskompass" "Der Ernährungskompass">>]]
,#+revision: 0
,#+tags:
,#+title: Zucker
,#+tmap.id: c268554d-9122-4728-88e0-0549ec026010
,#+type: text/vnd.tiddlywiki

-   Auch Saccharose
-   Gehört zur Familie der Saccharide
-   Formen
    -   Einfachzucker
        -   [Glukose](#Glukose){.tc-tiddlylink .tc-tiddlylink-resolves}
        -   [Fruktose](#Fruktose){.tc-tiddlylink
            .tc-tiddlylink-resolves}
    -   Mehrfachzucker
        -   Stärke
-   Haushaltszucker
    -   Dissacharid
    -   Besteht aus 2 Monosacchariden
        -   Glukose (Traubenzucker)
        -   Fruktose (Fruchtzucker)
-   [Süßstoffe](#S%C3%BC%C3%9Fstoffe){.tc-tiddlylink
    .tc-tiddlylink-resolves}
Enter fullscreen mode Exit fullscreen mode

Extract bookmarks

I have lots of bookmarks (each one is mapped to one tiddler) tagged in this way:

cat org_tiddlers/bookmarks/writing_a_technical_book_in_emacs_and_org_mode_.org
Enter fullscreen mode Exit fullscreen mode
#+created: 20220201125456750
#+modified: 20220203071728094
#+name: Writing a Technical Book in Emacs and Org Mode
#+note: Author writes about the workflow itself, importance of pomodoro
#+revision: 0
#+tags: Bookmark [[ORG Mode]] Writing
#+title: Writing a Technical Book in Emacs and Org Mode
#+type: text/vnd.tiddlywiki
#+url: https://www.kpkaiser.com/programming/writing-a-technical-book-in-emacs-and-org-mode/
Enter fullscreen mode Exit fullscreen mode

So each bookmarks consists of:

  • a name
  • a note
  • an url
  • a title (usually the same as name)

Now we can easily parse these files and create the desired structure. For this purpose I’ve used this tinny Python snippet:

import sys
import re

note = ""
url = ""
title = ""
tags = ""
created = ""

for line in sys.stdin:

    # Extract created
    result = re.match("^#\+created: (.*)$", line, re.IGNORECASE)
    if result:
        created = result.group(1)

    # Extract note
    result = re.match("^#\+title: (.*)$", line, re.IGNORECASE)
    if result:
        title = result.group(1)

    # Extract note
    result = re.match("^#\+note: (.*)$", line, re.IGNORECASE)
    if result:
        note = result.group(1)

    # Extract URL
    result = re.match("^#\+url: (.*)$", line, re.IGNORECASE)
    if result:
        url = result.group(1)

    # Extract tags
    result = re.match("^#\+tags: (.*)$", line, re.IGNORECASE)
    if result:
        _tags = result.group(1)
        split = _tags.split(" ")
        tags = ":".join(split)
        if tags:
            tags = f":{tags}:"


# Print
print(f"* [[{url}][{title}]]\t\t{tags}\n  :PROPERTIES:\n  :CREATED: {created}\n  :NOTE: {note}\n  :END:\n ")
Enter fullscreen mode Exit fullscreen mode

Used against our bookmark file it will yield:

cat org_tiddlers/bookmarks/writing_a_technical_book_in_emacs_and_org_mode_.org | python3 /tmp/extract-bookmark.py
Enter fullscreen mode Exit fullscreen mode
,* [[https://www.kpkaiser.com/programming/writing-a-technical-book-in-emacs-and-org-mode/][Writing a Technical Book in Emacs and Org Mode ]]        :Bookmark:[[ORG:Mode]]:Writing:
  :PROPERTIES:
  :CREATED: 20220201125456750
  :NOTE: Author writes about the workflow itself, importance of pomodoro
  :END:
Enter fullscreen mode Exit fullscreen mode

This way we get a nice ORG mode headline with some properties. Now let’s convert all available bookmarks and save into one big file:

cd org_tiddlers
rm /tmp/bookmarks.org
grep * -e "#+tags:.*Bookmark*" -l | xargs -I "{}" sh -c "grep -e '^#.*$' {} | python3 /tmp/extract-bookmark.py; mv {} bookmarks/" >> /tmp/bookmarks.org
Enter fullscreen mode Exit fullscreen mode

Let’s check how many entries we got:

cat /tmp/bookmarks.org | grep "\* \[\[" | wc -l -
Enter fullscreen mode Exit fullscreen mode
425 -
Enter fullscreen mode Exit fullscreen mode

Extract journal entries

Collect all journal tiddlers and merge them into one big file.

cd org_tiddlers
rm /tmp/journals.org
grep * -e "#+tags: Journal" -l | xargs -I % sh -c \
   "echo -e '* %' | tr -d '.org' >> /tmp/journals.org; \
    cat % | sed '/^#+tmap.id/d;/^#+title:/d;/^#+tags:/d;/^#+created:/d;/^#+modified/d;/^#+revision/d;/^#+type/d' \
    >> /tmp/journals.org"
head -n 10 /tmp/journals.org
Enter fullscreen mode Exit fullscreen mode
,* 2020-09-14

- [[https://www.swr.de/swr2/programm/broadcastcontrib-swr-13438.html][Wie funktioniert Selbstregulierung?]]
  - auch in der [[https://www.ardaudiothek.de/wissen/wie-funktioniert-selbstregulierung/80172244][ARD audiothek]]
- Un podcast interesant despre [[https://www.stareanatiei.ro/podcasts/][starea natiei]]
  - este si [[https://www.youtube.com/channel/UCtK5Oe8sHjp6WPcwWuHUVpQ][canal youtube]]
- [[https://stackoverflow.com/questions/42531643/amazon-s3-static-web-hosting-caching][how to use caching with S3 static site hosting]]
,* 2020-09-15

- this site supports now [[https://brainfck.org][TLS/SSL]]
Enter fullscreen mode Exit fullscreen mode

Extract books

This was the most difficult part and I’ll try to explain why. This is how a book tiddler usually looks like (1984):

1984 tiddler
1984 book

Usually I have some content inside the tiddler but also some additional tiddlers related to the book:

  • notes/quotes
    • most of the time these are quotes
    • Examples: 1984 - Note 1, 1984 - Note 2 etc.
  • subtopics

Basically I wanted to merge every tiddler into one ORG file.

Book tiddlers
Merge every single tiddler related to 1984 into one big ORG file

Instead of applying some sed & awk magic, I decided to use Tiddlywikis internal templating system. The $:/core/templates/static.tiddler.html template for examples defines how a single tiddler should be exported to its corresponding HTML file:

\define tv-wikilink-template() $uri_doubleencoded$.html \define
tv-config-toolbar-icons() no \define tv-config-toolbar-text() no \define
tv-config-toolbar-class() tc-btn-invisible \import [[$:/core/ui/PageMacros]]
[all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]] `<!DOCTYPE html>
<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
    <meta name="generator" content="TiddlyWiki" />
    <meta name="tiddlywiki-version" content="`{{$:/core/templates/version}}`" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta name="apple-mobile-web-app-capable" content="yes" />
    <meta
      name="apple-mobile-web-app-status-bar-style"
      content="black-translucent"
    />
    <meta name="mobile-web-app-capable" content="yes" />
    <meta name="format-detection" content="telephone=no" />
    <link id="faviconLink" rel="shortcut icon" href="favicon.ico" />
    <link rel="stylesheet" href="static.css" />
    <title>
      `<$view field="caption"><$view field="title"/></$view>:
      {{$:/core/wiki/title}}`
    </title>
  </head>
  <body class="tc-body">
    `{{$:/StaticBanner||$:/core/templates/html-tiddler}}`
    <section class="tc-story-river tc-static-story-river">
      `<$view tiddler="$:/core/ui/ViewTemplate" format="htmlwikified"/>`
    </section>
  </body>
</html>
Enter fullscreen mode Exit fullscreen mode

We can use the same mechanism to define a template for a book tiddler whenever this has to be
exported. But first of all let's see how a template is used when exporting:

This is what happens:

export-books : deps pre
    @echo "Exporting all book tiddlers from $(ORIGINAL_TIDDLYWIKI) to ORG with custom render template"
    $(NODEJS) $(TIDDLYWIKI_JS) $(WIKI_NAME) --load $(ORIGINAL_TIDDLYWIKI) \
        --render [!is[system]tag[Book]] [encodeuricomponent[]addprefix[books/]addsuffix[.org]] \
        text/plain $$:/vd/templates/render-book
    $(NODEJS) $(SAFE_RENAME_JS) $(TW_OUTPUT_DIR)
Enter fullscreen mode Exit fullscreen mode
  • we load the single HTML Tiddlywiki file via --load
  • we use --render[^render_command] to export a list of tiddlers
  • as a filter we use [!is[system]tag[Book]] which means:
    • give me all non-system tiddlers and from this selection
    • give me all tiddlers tagged with Book
  • [encodeuricomponent[]addprefix[books/]addsuffix[.org]] handles the file path of tiddler to be exported
  • $$:/vd/templates/render-book is the name of the template to be used

And now $:/vd/templates/render-book :

\define quotesFilter() [prefix<currentTiddler>!title<currentTiddler>tag[quote]sortan[]]
\define childrenFilter() [prefix<currentTiddler>!title<currentTiddler>!tag[quote]sortan[]]

<$list filter=[all[current]]>
* {{!!title}}
  :PROPERTIES:
  :FINISHED: {{!!finished_year}}-{{!!finished_month}}
  :END:
** Description
{{!!text}}
</$list>

** Notes
<$list filter="[subfilter<childrenFilter>]">
*** {{!!title}}                  :note:
      :PROPERTIES:
      :CREATED: {{!!created}}
      :TAGS: {{!!tags}}
      :END:
</$list>

** Quotes
<$list filter="[subfilter<quotesFilter>]">
*** {{!!title}}                  :quote:
{{!!text}}
</$list>
Enter fullscreen mode Exit fullscreen mode

Code Snippet 3: The Tiddlywiki render template I've used to export my books and related tiddlers.

Let’s dissect the snippet fragment by fragment.

Add book content

...
<$list filter=[all[current]]>
* {{!!title}}
  :PROPERTIES:
  :FINISHED: {{!!finished_year}}-{{!!finished_month}}
  :END:
** Description
{{!!text}}
</$list>
...
Enter fullscreen mode Exit fullscreen mode

We create a list of tiddlers with following filter: [all[current]] (another way to express we just want the current tiddler). We then create an ORG mode headline consisting of the field title in the current tiddler ({{!!title}}). Then we add a FINISHED property using the fields finished_year and finished_month

1984 fields
Fields of 1984 tiddler

Then I create a sub-heading called Description where I put the tiddler’s content (field text).

Add notes

...
\define childrenFilter() [prefix<currentTiddler>!title<currentTiddler>!tag[quote]sortan[]]
...
** Notes
<$list filter="[subfilter<childrenFilter>]">
*** {{!!title}}                  :note:
      :PROPERTIES:
      :CREATED: {{!!created}}
      :TAGS: {{!!tags}}
      :END:
</$list>
...
Enter fullscreen mode Exit fullscreen mode

We create a sub-heading called Notes where we add additional sub-nodes. For this to work we create again a list of tiddlers where we apply the filter: [subfilter<childrenFilter>]. childrenFilter is defined at the top:

  • prefix<currentTiddler>
    • We focus only on the tiddlers which have the ~currentTiddler~ as a prefix.
    • if ~currentTiddler~ is 1984, then this will match
    • ~1984 - Note 1~
    • ~1984/Wohlstand~
  • !title<currentTiddler>
    • This makes sure we don't match ourself (the ~currentTiddler~)
  • !tag[quote]
    • Match only tiddlers which don't have tag ~quote~
  • sortan[]
    • Sort list of tiddlers by text field

For the sub-heading we then add some properties: CREATED (field created) and TAGS (field tags).

Add quotes

\define quotesFilter() [prefix<currentTiddler>!title<currentTiddler>tag[quote]sortan[]]
...
** Quotes
<$list filter="[subfilter<quotesFilter>]">
*** {{!!title}}                  :quote:
{{!!text}}
</$list>
Enter fullscreen mode Exit fullscreen mode

Also here we create a sub-heading called Quotes and underneath we create additional sub-nodes for the quotes. As for Notes we have a subfilter (quotesFilter):

  • it matches all tiddlers which have the currentTiddler’s title as a prefix
  • AND are tagged by quote.

Put everything together

Now that we have a template let’s have a look at the output:

$ tiddlywiki . --load ./output/index.html \
               --render "[!is[system]prefix[1984]tag[Book]]" \
               "[encodeuricomponent[]addprefix[books/]addsuffix[.org]]" \
               "text/plain"\
               "$:/vd/templates/render-book"
Enter fullscreen mode Exit fullscreen mode

Code Snippet 4: Export everything related to '1984' by applying the $:/vd/templates/render-book template.

And this is what we get:

cat ./output/books/1984.org
Enter fullscreen mode Exit fullscreen mode
* 1984
:PROPERTIES:
:FINISHED: 2021-05
 :END:
** Description
* Theorie und Praxis des oligarchischen Kollektivismus
** von Emmanuel Goldstein
** Kapitel 1: Unwissenheit ist Stärke
** Kapitel 3: 1984/Krieg ist Frieden

** Notes
*** 1984/3 Arten von Menschen                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS: Definition
     :END:

*** 1984/Aufteilung der Welt                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS: Stub
     :END:

*** 1984/Der Große Bruder                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS:
     :END:

*** 1984/Doppeldenk                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS:
     :END:

*** 1984/Krieg                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS:
     :END:

*** 1984/Krieg ist Frieden                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS:
     :END:

*** 1984/Kulturelle Integrität                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS:
     :END:

*** 1984/Rolle der Partei                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS:
     :END:

*** 1984/Versklavung                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS:
     :END:

*** 1984/Wohlstand                  :note:
     :PROPERTIES:
     :CREATED:
     :TAGS:
     :END:
** Quotes
*** 1984 - Note 1                  :quote:
Krieg ist Frieden, Freiheit ist Sklaverei, Unwissenheit ist Stärke - Ministerium für Wahrheit


*** 1984 - Note 2                  :quote:
Gedankendelikt hat nicht den Tod zur Folge: Gedankendelikt IST der Tod.


*** 1984 - Note 3                  :quote:
"Begreifst du denn nicht, dass Neusprech zur ein Ziel hat, nämlich den Gedankenspielraum einzuengen? Zu guter Letzt werden wir
Gedankendelikte buchstäblich unmöglich machen, weil es keine Wörter mehr geben wird, um sie auszudrücken. Jeder
Begriff, der jemals benötigt werden könnte, wird durch exakt ein Wort ausgedrückt sein, dessen Bedeutung streng definiert ist und dessen
sämtliche Nebendeutungen eliminiert und vergessen sind."


*** 1984 - Note 4                  :quote:
Freiheit bedeutet die Freiheit, zu sagen, dass zwei und zwei vier ist. Gilt dies, ergibt sich alles übrige von selbst.


*** 1984 - Note 5                  :quote:
Die Massen revoltieren nie aus eigenem Antrieb, und sie revoltieren nie, nur weil sie unterdrückt werden. Solange man ihnen die Vergleichsmaßstäbe entzieht, werden sie nicht einmal merken, dass man sie unterdrückt.
Enter fullscreen mode Exit fullscreen mode

I think that’s pretty good4.

new brainfck.org
New brainfck.org

I intentionally didn’t add content in the Notes section to the sub-nodes. In the next post I’ll explain how I managed to quickly review my notes using Emacs and some Elisp and add content on the go.


  1. Other popular terms: Zettelkasten (slip box in German), memex, braindump or digital garden. 

  2. Here is my config.org 

  3. I’ve created a fork with my own customizations. 

  4. And this is the final result

Oldest comments (0)