DSSG - A static site generator with a different approach
Unlike other static site generators, DSSG doesn't differentiate between front matter and a content section in its content files. This makes it very easy to create web pages based on templates with multiple content sections.
For maximum flexibility, each project can be based on multiple templates.
Content may be written in both Markdown or pure HTML.
How does it work?
DSSG creates HTML pages out of TOML files. Each TOML file represents one HTML page and consists of as many key-value pairs as you want.
The key-value pairs contain both metadata and the actual page content. There can be multiple key-value pairs with page content. If a key in your TOML file ends with
_md, DSSG expects Markdown as value. DSSG will turn the Markdown into HTML.
Templates are written in the Mustache template language. DSSG substitues each variable in the template with its equivalent from the TOML file.
Why is it called DSSG?
DSSG is written in the D programming language. DSSG stands for D Static Site Generator.
The latest binaries are available on https://github.com/kambrium/dssg/releases. Currently, there are Ubuntu 16.04 and Windows 10 binaries.
After you have downloaded the software (see above), open a terminal and unzip the archive.
$ unzip dssg_X.Y.Z_ubuntu0000_x64.zip -d /this/is/your/dssg/path/
Change to the directory that contains the DSSG binary and set the permissions so that you can execute the program.
$ cd /this/is/your/dssg/path/ $ chmod u+x dssg
Add the directory that contains the DSSG binary to your PATH. Please refer to the documentation of your distribution for further details. Here is an example of how it works on Ubuntu with Bash.
$ echo 'export PATH=$PATH:/this/is/your/dssg/path/' >> ~/.bashrc $ source ~/.bashrc
After you have downloaded the software (see above), open the PowerShell and unzip the archive.
PS> Expand-Archive -Path dssg_X.Y.Z_win_x64.zip -DestinationPath C:\this\is\your\dssg\path
Add the directory that contains the DSSG binary to your Path.
PS> [System.Environment]::SetEnvironmentVariable("Path", [System.Environment]::GetEnvironmentVariable("Path", [EnvironmentVariableTarget]::User) + ";C:\this\is\your\dssg\path", [EnvironmentVariableTarget]::User)
Restart the PowerShell.
Try the example
$ git clone https://github.com/kambrium/dssg-example.git $ cd dssg-example $ dssg build $ dssg serve
Begin from scratch
Made with DSSG