Gomarkwiki is a command-line program that converts Markdown to HTML, to create static websites from Markdown. I use it for note taking and personal wikis. I was using ikiwiki, but wanted something faster, and that supported more modern syntax and formatting. Gomarkwiki is developed in Go using the Goldmark parser, which makes it very fast, and gives it support for CommonMark as well as GitHub Flavored Markdown (GFM), such as tables.
NAME
gomarkwiki - Generates HTML from Markdown.
SYNOPSIS
gomarkwiki [options] source_dir dest_dir
gomarkwiki [options] -wikis wikis_file
DESCRIPTION
gomarkwiki generates HTML from Markdown. Each Markdown file found in
source_dir/content results in a corresponding HTML page generated in
dest_dir.
The source_dir is processed recursively. The directory structure found
in source_dir is mirrored in dest_dir.
Markdown files are identified by the file extensions .md, .mdwn, and
.markdown.
Other files found in source_dir, that are not Markdown, are copied to
dest_dir.
Multiple source_dir and dest_dir pairs can be specified using the -wikis
option, giving it the path to a CSV file that has one wiki defined per
line, formatted as source_dir,dest_dir.
A default CSS style sheet called style.css is placed in dest_dir.
Styles can be overridden by creating a local.css file in
source_dir/content. The local.css file will be copied to dest_dir, and
override any default styles found in styles.css.
A second CSS style sheet called github-style.css is placed in dest_dir
as well, to format pages using GitHub-like styles. To use this CSS file
for a given Markdown file, start the file with the directive
#[style(github)]. These styles can be overridden too, by creating
a github-local.css file in source_dir/content.
A favicon can be placed in source_dir/content to give HTML pages
a default icon. The filename should be favicon.ico.
String substitutions can be made using string pairs in the file
source_dir/substitution-strings.csv. Each line of substitution-strings.csv
is a comma separated pair of strings, with the string placeholder first,
followed by a comma, and then the string substitution. Then anywhere
{{placeholder}} is found in a Markdown file, the corresponding HTML file
have the substitution instead. For example if substitution-strings.csv has
the line "FOOBAR,www.foobar.com" then any instance of {{FOOBAR}} in
a Markdown file will result in www.foobar.com in the HTML file.
Files can be ignored with the file source_dir/ignore.txt. Each line
should be one regular expression that specifies file names to ignore.
For example, an ignore.txt with the line \.tmp$ will ignore all files
with that end in .tmp
OPTIONS
-clean
Delete any files in dest_dir that do not have a corresponding
file in source_dir. By default no files are deleted from dest_dir.
-help
Show help and exit.
-regen
Regenerate all HTML regardless of timestamps. By default an HTML
file is only regenerated when the timestamp on its Markdown file
is newer that the timestamp on the HTML file.
-verbose
Print all status messages.
-version
Print version information and exit.
-watch
Remain running and watch for changes to regenerate files on the fly.
-wikis wikis_file
Generate wikis specified in CSV file, with one wiki defined per
line formatted as source_dir,dest_dir.
Generate the HTML for an example site with markdown in ~/example-site
and
save generated HTML to ~/wikis-html/example-site
:
gomarkwiki ~/example-site ~/wikis-html/example-site
Or to generate multiple wikis using the CSV file /etc/gomarkwiki/wikis.csv
that has:
/path/to/src/wiki1,/path/to/dest/wiki1
/path/to/src/wiki2,/path/to/dest/wiki2
/path/to/src/wiki3,/path/to/dest/wiki3
To generate all three wikis in one pass, clean any files from the dest directories that don't have corresponding files in their source directory, and remain running to watch for changes and regenerate destination files with:
gomarkwiki -clean -watch -wikis /etc/gomarkwiki/wikis.csv
Gomarkwiki can be installed by either building from source, or downloading a pre-built binary.
Gomarkwiki is written in the Go programming language and you need at least Go version 1.20. To build gomarkwiki from source, execute the following steps:
$ git clone https://github.com/stalexan/gomarkwiki
$ cd gomarkwiki
$ make build
This builds gomarkwiki and places the executable in the ./build
directory.
You can download the latest stable release versions of gomarkwiki from the gomarkwiki releases page. These builds are considered stable and releases are made regularly in a controlled manner.
There’s both pre-compiled binaries for different platforms as well as the source code available for download. Just download and run the one matching your system.
If you like, you can verify the integrity of your downloads by testing the SHA-256 checksums listed in SHA256SUMS, and verifying the integrity of the file SHA256SUMS with the PGP signature in SHA256SUMS.asc. The PGP signature was created using the key (0x26565B27732B7C75):
pub rsa3072 2023-04-29 [SC] [expires: 2025-04-28]
A6951D3EEB4DDAF71434364E26565B27732B7C75
uid Sean Alexandre <sean@alexan.org>
sub rsa3072 2023-04-29 [S] [expires: 2024-04-28]
AAAB32D28EB8110409B4B33CD856897AA7E38BD1
The binaries released with each gomarkwiki version are reproducible, which means you can reproduce a byte identical version from the source code for that release.
Reproducible builds can be done with either Docker using the release build scripts found in the release-builder directory, or without Docker by manually doing what the scripts do.
In either case, the first step is to determine which version of Go was used to
build gomarkwiki, and which version of gomarkwiki to build. This can be done
with the --version
option:
$ gomarkwiki --version
gomarkwiki v0.2.0 compiled with go1.20.5 on linux/amd64
To do a reproducible build with Docker, we first create a Docker image by
running build-image.sh
in the
release-builder
directory, giving it the version of Go that will be used to do the build. Here
we create an image that will have Go version 1.20.5:
./build-image.sh 1.20.5
Then to create the release build run build-release.sh
, in the same directory,
giving it the location of source to build, where to place the binaries that are
created, and which commit of gomarkwiki to build. Here we build gomarkwiki
version v0.2.0
using the source that's in ~/gomarkwiki
, and place the
binaries that are created in ~/tmp/build-output
:
./build-release.sh ~/gomarkwiki ~/tmp/build-output v0.2.0
A reproducible build can also be done manually, without Docker. Here we perform the same steps as done in the build scripts, but for just one executable.
First install the version of Go that was used to build Gomarkwiki. For example, to install Go 1.20.5:
$ GO_URL="https://dl.google.com/go/go1.20.5.linux-amd64.tar.gz"
$ wget -O go.tar.gz.asc "${GO_URL}.asc"
$ wget -O go.tar.gz "$GO_URL" --progress=dot:giga
$ gpg --verify go.tar.gz.asc go.tar.gz
$ tar -C /usr/local -xzf go.tar.gz; \
The signing key can be installed with, if needed:
gpg --keyserver keyserver.ubuntu.com --recv-keys 'EB4C 1BFD 4F04 2F6D DDCC EC91 7721 F63B D38B 4796'
More on this signing key can be found here: google.com Linux Software Repositories.
Add Go to PATH
and set GOPATH
:
$ export PATH=$PATH:/usr/local/go/bin
$ export GOPATH=$HOME/go
Extract the source to build. Here we extract to /tmp/build
, but any directory will do:
$ mkdir /tmp/build
$ cd /tmp/build
$ curl -L https://github.com/stalexan/gomarkwiki/releases/download/v0.2.0/gomarkwiki-v0.2.0.tar.gz | tar xz --strip-components=1
Build Gomarkwiki:
$ GOOS=linux GOARCH=amd64 CGO_ENABLED=0 go build -trimpath -ldflags "-s -w -X 'main.version=v0.2.0'" -o gomarkwiki_v0.2.0_linux_amd64 ./cmd/main.go
Create the zipped version:
$ bzip2 gomarkwiki_v0.2.0_linux_amd64
Compare the SHA256 sums. Here we've downloaded the release's SHA256SUMS file to the current directory:
$ sha256sum --ignore-missing --check SHA256SUMS
gomarkwiki_v0.2.0_linux_amd64.bz2: OK
The SHA256 sums are the same, and we've done a reproducible build.
Gomarkwiki is licensed under the MIT License. You can find the complete text in LICENSE.txt.