💾 Archived View for gem.hexandcounter.org › gemlog › posts › md2gmi.gmi captured on 2021-12-17 at 13:26:06. Gemini links have been rewritten to link to archived content
⬅️ Previous capture (2021-11-30)
-=-=-=-=-=-=-
I was looking for a way to convert a single Markdown document to one Gemini document per chapter, turning links to chapters into links to other files. There was no obvious way to do so using Pandoc as it only supports a single output document file, but an answer on Stackoverflow mentioned a trick.
So the steps goes something like this (and you probably should put this in a Makefile or something):
1. Use Pandoc to convert your document to EPUB.
2. Unzip the EPUB somewhere to get a pile of XHTML files.
3. Convert each individual file from XHTML to GMI.
4. Replace ".xhtml" in all files with ".gmi" to make the inter-chapter links correct.
Or something like the following, more or less. Except that I am not sure how to do step 3 in the best way. Possibly using Pandoc or possibly using some other script someone wrote, or a combination.
pandoc -o document.epub document.md unzip document.epub for c in EPUB/text/*.xhtml; do pandoc -o $(basename $c .xhtml).md $c; done (handwaves converting *.md to *.gmi) for f in *.gmi; do sed -i s/.xhtml/.gmi/ $f; done
With this you can, for instance, write your own gamebooks in Markdown and turn into a collection of static Gemini text files on your capsule.
If there is ever support in Pandoc for creating multiple output documents all this should be possible in a single command-line, including the Pangamebook filtering to number and shuffle chapters, if you want that.