Configuration file
A config file, $basedir/wmk_config.yaml
, can be used to configure many aspects
of how wmk
operates. The name of the file may be changed by setting the
environment variable WMK_CONFIG
which should contain a filename without a
leading directory path.
The configuration file must exist (but may be empty). If it specifies a theme
and a file named wmk_config.yaml
(regardless of the WMK_CONFIG
environment
variable setting) exists in the theme directory, then any settings in that file
will be merged with the main config – unless ignore_theme_conf
is true.
It is also possible to split the configuration file up into several smaller
files. These are placed in the wmk_config.d/
directory (inside the base
directory). The filename of each yaml file in that directory (minus the .yaml
extension) is treated as a key and the contents as its value. Subdirectories can
be used to represent a nested structure. For instance, the file
wmk_config.d/site/colors/darkmode.yaml
would contain the settings that
will be visible to templates as the site.colors.darkmode
variable.
Note that the WMK_CONFIG
environment variable affects the name of the
directory looked for; setting it to myconf.yaml
would e.g. mean that wmk
will inspect myconf.d/
for extra configuration settings instead of
wmk_config.d/
(although this does not apply to themes, whose configuration
file/directory name is fixed).
Currently there is support for the following settings:
-
template_context
: Default values for the context passed to templates. This should be a dict. -
site
: Values for common information relating to the website. These are also added to the template context under the keysite
. They are often used by templates and themes to affect the look and feel of the website. For further discussion, see Site, page and nav variables. -
render_drafts
: Normally, content files withdraft
set to a true value in the metadata section will be skipped during rendering. This can be turned off (so that thedraft
status flag is ignored) by settingrender_drafts
to True in the config file. -
markdown_extensions
: A list of extensions to enable for markdown processing by Python-Markdown. The default is['extra', 'sane_lists']
. If you specify third-party extensions here, you have to install them into the Python virtual environment first. Obviously, this has no effect ifpandoc
is true. May be set or overridden through frontmatter variables. -
markdown_extension_configs
: Settings for your markdown extensions. May be set in the config file or in the frontmatter. For convenience, there are special frontmatter settings for two extensions, namely fortoc
andwikilinks
: - The
toc
boolean setting will turn thetoc
extension off if set to False and on if set to True, regardless of its presence inmarkdown_extensions
. - If
toc
is inmarkdown_extensions
(or has been turned on via thetoc
boolean), then thetoc_depth
frontmatter variable will affect the configuration of the extension regardless of themarkdown_extension_configs
setting. -
If
wikilinks
is inmarkdown_extensions
then the options specified in thewikilinks
frontmatter setting will be passed on to the extension. Example:wikilinks: {'base_url': '/somewhere'}
. -
pandoc
: Normally Python-Markdown is used for markdown processing, but if this boolean setting is true, then Pandoc via Pypandoc is used by default instead. This can be turned off or on through frontmatter variables as well. Another config setting which affects whether Pandoc is used iscontent_extensions
, for which see below. -
pandoc_filters
,pandoc_options
: Lists of filters and options for Pandoc. Has no effect unlesspandoc
is true. May be set or overridden through frontmatter variables. -
pandoc_input_format
: Which input format to assume for Pandoc; has no effect unlesspandoc
is true. The default value ismarkdown
. If set, the value should be a markdown subvariant for markdown-like content, i.e. one ofmarkdown
(pandoc-flavoured),gfm
(github-flavoured),markdown_mmd
(MultiMarkdown),markdown_phpextra
,markdown_strict
,commonmark
, orcommonmark_x
. As for other supported input formats, there is little reason to setpandoc_input_format
explicitly for them, since they have no variants in the relevant sense, and the right format is picked based on the file extension. May be set or overridden through frontmatter variables. -
pandoc_output_format
: Output format for Pandoc; has no effect unlesspandoc
is true. This should be a HTML variant, i.e. eitherhtml
,html5
orhtml4
, or alternatively one of the HTML-based slide formats, i.e.s5
,slideous
,slidy
,dzslides
orreavealjs
. Chunked HTML (new in Pandoc 3) is not supported. May be set or overridden through frontmatter variables. -
pandoc_extra_formats
,pandoc_extra_formats_settings
: Ifpandoc
is True, thenpandoc_extra_formats
in the frontmatter can be used to convert to other formats than HTML, for instance PDF or MS Word (docx).pandoc_extra_formats
is a dict where each key is a format name (e.g.pdf
) and its value is the output filename relative to the web root (e.g.subdir/myfile.pdf
). The special valueauto
indicates that the name of the output file should be based on that of the source file but with the file extension replaced by the name of the format. For instance, a source file namedsubdir/index.md
(relative to the content directory) maps to an output file namedsubdir/index.pdf
(relative to the web root directory) if the output format ispdf
, and so on.pandoc_extra_formats_settings
, if present, contains any special settings for the conversion in the form of a dict where each key is a format name and its value is either a dict with the keysextra_args
and/orfilters
, or a list (which then is interpreted as the value of theextra_args
setting). -
slugify_dirs
: Affects the names of directories created inhtdocs
because of thepretty_path
setting. Iftrue
(which is the default), the name will be identical to theslug
of the source file. If explicitly set tofalse
, then the directory name will be the same as the basename of the source file, almost regardless of the characters in the filename. -
use_cache
: boolean, True by default. If you set this to False, the rendering cache will be disabled. This is useful for small and medium-sized projects where the final HTML output often depends on factors other than the content file alone. Note that caching for a specific file can be turned off by puttingno_cache: true
in the frontmatter. -
cache_mtime_matters
: boolean, False by default. Normally only the body of the markdown file and a few selected processing settings make up the cache key. If, on the other hand, this setting is True (either in the configuration file or in the frontmatter), then the modification time of the markdown file affects the cache key, so touching the file is sufficient for refreshing its cache entry. -
use_sass
: A boolean indicating whether to handle Sass/SCSS files inassets/scss
automatically. True by default. -
use_dart_sass
: By default, Sass/SCSS is handled by libsass. Ifuse_dart_sass
is true, Dart Sass is used instead. This requires it to be installed as an external command. -
dart_sass_bin
: This can be set to point to the location of thesass
executable that will be run whenuse_dart_sass
is true. Normally not needed unlesssass
is not in yourPATH
or you want to add parameters (or use a specific version). -
sass_output_style
: The output style for Sass/SCSS rendering. This should be one ofcompact
,compressed
,expanded
ornested
. The default isexpanded
. Has no effect ifuse_sass
is false. When using Dart Sass,compact
andnested
have the same effect asexpanded
. -
assets_map
: An assets map is a mapping from filenames or aliases to names of files containing a hash identifier (under the webroot). A typical entry might thus map from/css/style.css
to/css/style.1234abcdef56.css
. The value of this setting is either a dict or the name of a JSON or YAML file (inside the data directory) containing the mapping. It will be available to templates asASSETS_MAP
. -
assets_fingerprinting
: A boolean indicating whether to automatically fingerprint assets files (i.e. add hash indicators to their names). If true, any fingerprinted files will be added to theASSETS_MAP
template variable. -
assets_fingerprinting_conf
: A dict where the keys are subdirectories of the webroot, e.g.js
orimg/icons
, and the values are dicts containing the keyspattern
and (optionally)exclude
. These are regular expressions indicating which files to fingerprint under these directories. The filename is fingerprinted if it matchespattern
but does not matchexclude
. (The default value ofexclude
looks for files that appear to have been fingerprinted already and thus does not normally need to be set). The default value of this setting is a simple setup for thejs
andcss
subdirectories of the webroot. -
assets_commands
: A list of arbitrary commands to run at the assets compilation stage (just before Sass/SCSS files inassets/scss
are processed, assuminguse_sass
is not false). The commands are run in order inside the base directory of the site. Example:['bin/fetch_external_assets.sh', 'node esbuild.mjs']
. -
lunr_index
: If this is True, a search index forlunr.js
is written as a file namedidx.json
in the root of thehtdocs/
directory. Basic information about each page (title and summary) is additionally written toidx.summaries.json
. -
lunr_index_fields
: The default fields for generating the lunr search index aretitle
andbody
. Additional fields and their weight can be configured through this variable. For instance{"title": 10, "tags": 5, "body": 1}
. Aside frombody
, the fields are assumed to be attributes ofpage
. -
lunr_languages
: A two-letter language code or a list of such codes, indicating which language(s) to use for stemming when building a Lunr index. The default language isen
. For more on this, see Site search. -
http
: This is is a dict for configuring the address used forwmk serve
. It may contain either or both of two keys:port
(default: 7007) andip
(default: 127.0.0.1). Can also be set directly via command line options. -
output_directory
: Normally the output will be written to the directoryhtdocs
inside the basedir, but this can be overridden by setting this configuration variable. The value should be a relative path that does not start with/
or.
, e.g.site
orpublic
. -
mako_imports
: A list of Python statements to add to the top of each generated Mako template module file. Generally these are import statements. -
theme
: This is the name of a subdirectory to the directory$basedir/themes
(or a symlink placed there) in which to look for extrastatic
,assets
,py
andtemplate
directories. Note that neithercontent
nordata
directories of a theme will be used bywmk
. A theme-provided template may be rendered as stand-alone page, but only if no local template overrides it (i.e. has the same relative path). Mako's internal template lookup will similarly first look for referenced components in the normaltemplate
directory before looking in the theme directory. Configuration settings fromwmk_config.yaml
in the theme directory will be used as long as they do not conflict with those in the main config file. -
ignore_theme_conf
: If set to true in the main configuration file, this tells wmk to ignore any settings inwmk_config.yaml
in the theme directory. -
extra_template_dirs
: A list of directories in which to look for template files. These are placed after both$basedir/templates
and theme-provided templates in the template engine search path. This makes it possible to build up a library of components which can be easily used on multiple sites and across different themes. -
jinja2_templates
: If this boolean setting is true, it indicates that the template files in thetemplate
directory (and supplied by the theme, or otherwise in the template engine search path) are to be interpreted by Jinja2 rather than Mako. Note that Jinja2 templates used standalone or as layout templates for Markdown content should have the extension.html
rather than.mhtml
. -
redirects
: If this is True or a string pointing to a YAML file in thedata/
directory (whose default name isredirects.yaml
), then wmk will write HTML stubs containing<meta http-equiv="refresh" ...>
in the indicated locations. The contents of the YAML file is a list of entries with the keysfrom
andto
. The former is a path underhtdocs/
or a list of such paths, whileto
is an absolute or relative URL which you are to be redirected to. -
content_extensions
: Customize which file extensions are handled inside thecontent/
directory. May be a list (e.g.['.md', '.html']
) or a dict. The value for each key in the dict should itself be a dict where the following keys have an effect:pandoc
(boolean),pandoc_input_format
(string),is_binary
(boolean),raw
(boolean),pandoc_binary_format
(string). See the value ofDEFAULT_CONTENT_EXTENSIONS
inwmk.py
for details. -
mdcontent_json
: This option may specify the name of a JSON file to which to write the entireMDCONTENT
object in serialized form, along with the environment variables for each page. The destination file may be either inhtdocs/
,data/
ortmp/
. If the file path does not start with one of these,data
is assumed. The specified (or implied) directory must exist. -
init_commands
: A list of arbitrary commands to run at the very beginning of processing, just after theme settings have been loaded and the Python search path configured. They are run in order inside the base directory of the site. -
cleanup_commands
: A list of arbitrary commands to run at the very end of wmk processing. The commands are run in order inside the base directory of the site.