Notes on Soupault

On Pranab’s site

Nov 20, 2024 (IST)

Show/Hide Contents
  1. Understand­ing HTML
  2. Widget = function
  3. HTML and markup languages

An SSG (static site generator) that understands HTML.

Soupault

This is what “An introduction to Soupault” was going to be. For some reason I turned that into a full beginner’s guide. Maybe because these notes might only make sense in context. Anyway, if you have the terminal open and want to start making a website, that’s what you’re looking for.

An introduction to Soupault

If you just want a brief introduction, this is what you’re looking for.

Understand­ing HTML🔗

Here’s what I mean when I say Soupault understands HTML: it uses CSS selectors to extract and add information.

This means that it turns the HTML into a series of nodes with attributes and children — it’s not just arbitrary text being put together.

The way Soupault works is by configuring everything in a TOML file. This is where you specify “widgets”, which are steps in a pipeline that work on a page. Widgets that interact with the HTML use CSS selectors.

[widgets.add-author]
	widget = "insert_html"
	html = "<p>by Pranab</p>"
	selector = "h1"
	action = "insert_after"

This is a widget that adds “by Pranab” under the title of every page in the site. Here’s how it works:

Widget = function🔗

It helps to think of a widget as a function call.

The widget key specifies the name of the function, and the rest of the keys are arguments to it.

The widget title is simply a description of what the widget does:

[widget.<description>]
	widget = "<type>"
	<arg1> = "<val1>"
	<arg2> = "<val2>"
	...

This, specifically, was the revelation that made Soupault finally click for me, and what prompted me to write the first “introduction”, before it turned into a full beginner’s guide.

HTML and markup languages🔗

If Soupault works with HTML, what about all the Markdown?

Well, Soupault first converts your markup to HTML.

You tell it which file extensions should be converted to HTML, and which shell command to use for conversion.

For example, Cmark is a widely available tool that converts Markdown to HTML.

Here’s how you’d use it:

[settings]
	page_file_extensions = [ "md" ]

[preprocessors]
	md = "cmark --unsafe"

As long as you can convert it to HTML, you can use any markup language you want.

If you really wanted, you could author your pages in JSON, and write a custom CLI tool to convert it to HTML. Just tell Soupault to use your program.

[settings]
	page_file_extensions = [ "md", "json" ]

[preprocessors]
	md = "cmark --unsafe"
	json = "my-cli"

If all this didn’t make sense, maybe the full introduction might be for you:

An introduction to Soupault


References to this page: