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.
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.
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.
$ git clone https://github.com/kambrium/dssg-example.git
$ cd dssg-example
$ dssg build
$ dssg serve
$ dssg new myproject
$ cd myproject
// Create Mustache templates in 'contents/_templates'
// Create TOML files, CSS, JavaScript, images etc. in 'contents'
$ dssg build
$ dssg serve
MIT