--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo"
 +slug: hugo
 +url: /commands/hugo/
 +---
 +## hugo
 +
 +hugo builds your site
 +
 +### Synopsis
 +
 +hugo is the main command, used to build your Hugo site.
 +
 +Hugo is a Fast and Flexible Static Site Generator
 +built with love by spf13 and friends in Go.
 +
 +Complete documentation is available at http://gohugo.io/.
 +
 +```
 +hugo [flags]
 +```
 +
 +### Options
 +
 +```
 +  -b, --baseURL string             hostname (and path) to the root, e.g. http://spf13.com/
 +  -D, --buildDrafts                include content marked as draft
 +  -E, --buildExpired               include expired content
 +  -F, --buildFuture                include content with publishdate in the future
 +      --cacheDir string            filesystem path to cache directory. Defaults: $TMPDIR/hugo_cache/
 +      --canonifyURLs               (deprecated) if true, all relative URLs will be canonicalized using baseURL
 +      --cleanDestinationDir        remove files from destination not found in static directories
 +      --config string              config file (default is path/config.yaml|json|toml)
 +  -c, --contentDir string          filesystem path to content directory
 +      --debug                      debug output
 +  -d, --destination string         filesystem path to write files to
 +      --disableKinds stringSlice   disable different kind of pages (home, RSS etc.)
 +      --enableGitInfo              add Git revision, date and author info to the pages
 +      --forceSyncStatic            copy all files when static is changed.
 +      --gc                         enable to run some cleanup tasks (remove unused cache files) after the build
 +  -h, --help                       help for hugo
 +      --i18n-warnings              print missing translations
 +      --ignoreCache                ignores the cache directory
 +  -l, --layoutDir string           filesystem path to layout directory
 +      --log                        enable Logging
 +      --logFile string             log File path (if set, logging enabled automatically)
 +      --noChmod                    don't sync permission mode of files
 +      --noTimes                    don't sync modification time of files
 +      --pluralizeListTitles        (deprecated) pluralize titles in lists using inflect (default true)
 +      --preserveTaxonomyNames      (deprecated) preserve taxonomy names as written ("Gérard Depardieu" vs "gerard-depardieu")
 +      --quiet                      build in quiet mode
 +      --renderToMemory             render to memory (only useful for benchmark testing)
 +  -s, --source string              filesystem path to read files relative from
 +      --stepAnalysis               display memory and timing of different steps of the program
 +      --templateMetrics            display metrics about template executions
 +      --templateMetricsHints       calculate some improvement hints when combined with --templateMetrics
 +  -t, --theme string               theme to use (located in /themes/THEMENAME/)
 +      --themesDir string           filesystem path to themes directory
 +      --uglyURLs                   (deprecated) if true, use /filename.html instead of /filename/
 +  -v, --verbose                    verbose output
 +      --verboseLog                 verbose logging
 +  -w, --watch                      watch filesystem for changes and recreate as needed
 +```
 +
 +### SEE ALSO
 +
 +* [hugo benchmark](/commands/hugo_benchmark/)  - Benchmark Hugo by building a site a number of times.
 +* [hugo check](/commands/hugo_check/)  - Contains some verification checks
 +* [hugo config](/commands/hugo_config/)        - Print the site configuration
 +* [hugo convert](/commands/hugo_convert/)      - Convert your content to different formats
 +* [hugo env](/commands/hugo_env/)      - Print Hugo version and environment info
 +* [hugo gen](/commands/hugo_gen/)      - A collection of several useful generators.
 +* [hugo import](/commands/hugo_import/)        - Import your site from others.
 +* [hugo list](/commands/hugo_list/)    - Listing out various types of content
 +* [hugo new](/commands/hugo_new/)      - Create new content for your site
 +* [hugo server](/commands/hugo_server/)        - A high performance webserver
 +* [hugo version](/commands/hugo_version/)      - Print the version number of Hugo
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo benchmark"
 +slug: hugo_benchmark
 +url: /commands/hugo_benchmark/
 +---
 +## hugo benchmark
 +
 +Benchmark Hugo by building a site a number of times.
 +
 +### Synopsis
 +
 +Hugo can build a site many times over and analyze the running process
 +creating a benchmark.
 +
 +```
 +hugo benchmark [flags]
 +```
 +
 +### Options
 +
 +```
 +  -b, --baseURL string             hostname (and path) to the root, e.g. http://spf13.com/
 +  -D, --buildDrafts                include content marked as draft
 +  -E, --buildExpired               include expired content
 +  -F, --buildFuture                include content with publishdate in the future
 +      --cacheDir string            filesystem path to cache directory. Defaults: $TMPDIR/hugo_cache/
 +      --canonifyURLs               (deprecated) if true, all relative URLs will be canonicalized using baseURL
 +      --cleanDestinationDir        remove files from destination not found in static directories
 +  -c, --contentDir string          filesystem path to content directory
 +  -n, --count int                  number of times to build the site (default 13)
 +      --cpuprofile string          path/filename for the CPU profile file
 +  -d, --destination string         filesystem path to write files to
 +      --disableKinds stringSlice   disable different kind of pages (home, RSS etc.)
 +      --enableGitInfo              add Git revision, date and author info to the pages
 +      --forceSyncStatic            copy all files when static is changed.
 +      --gc                         enable to run some cleanup tasks (remove unused cache files) after the build
 +  -h, --help                       help for benchmark
 +      --i18n-warnings              print missing translations
 +      --ignoreCache                ignores the cache directory
 +  -l, --layoutDir string           filesystem path to layout directory
 +      --memprofile string          path/filename for the memory profile file
 +      --noChmod                    don't sync permission mode of files
 +      --noTimes                    don't sync modification time of files
 +      --pluralizeListTitles        (deprecated) pluralize titles in lists using inflect (default true)
 +      --preserveTaxonomyNames      (deprecated) preserve taxonomy names as written ("Gérard Depardieu" vs "gerard-depardieu")
 +      --renderToMemory             render to memory (only useful for benchmark testing)
 +  -s, --source string              filesystem path to read files relative from
 +      --stepAnalysis               display memory and timing of different steps of the program
 +      --templateMetrics            display metrics about template executions
 +      --templateMetricsHints       calculate some improvement hints when combined with --templateMetrics
 +  -t, --theme string               theme to use (located in /themes/THEMENAME/)
 +      --themesDir string           filesystem path to themes directory
 +      --uglyURLs                   (deprecated) if true, use /filename.html instead of /filename/
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo check"
 +slug: hugo_check
 +url: /commands/hugo_check/
 +---
 +## hugo check
 +
 +Contains some verification checks
 +
 +### Synopsis
 +
 +Contains some verification checks
 +
 +### Options
 +
 +```
 +  -h, --help   help for check
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +* [hugo check ulimit](/commands/hugo_check_ulimit/)    - Check system ulimit settings
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo check ulimit"
 +slug: hugo_check_ulimit
 +url: /commands/hugo_check_ulimit/
 +---
 +## hugo check ulimit
 +
 +Check system ulimit settings
 +
 +### Synopsis
 +
 +Hugo will inspect the current ulimit settings on the system.
 +This is primarily to ensure that Hugo can watch enough files on some OSs
 +
 +```
 +hugo check ulimit [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for ulimit
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo check](/commands/hugo_check/)  - Contains some verification checks
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
-   -h, --help   help for config
++date: 2018-04-16
 +title: "hugo config"
 +slug: hugo_config
 +url: /commands/hugo_config/
 +---
 +## hugo config
 +
 +Print the site configuration
 +
 +### Synopsis
 +
 +Print the site configuration, both default and custom settings.
 +
 +```
 +hugo config [flags]
 +```
 +
 +### Options
 +
 +```
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++  -h, --help            help for config
++  -s, --source string   filesystem path to read files relative from
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo convert"
 +slug: hugo_convert
 +url: /commands/hugo_convert/
 +---
 +## hugo convert
 +
 +Convert your content to different formats
 +
 +### Synopsis
 +
 +Convert your content (e.g. front matter) to different formats.
 +
 +See convert's subcommands toJSON, toTOML and toYAML for more information.
 +
 +### Options
 +
 +```
 +  -h, --help            help for convert
 +  -o, --output string   filesystem path to write files to
 +  -s, --source string   filesystem path to read files relative from
 +      --unsafe          enable less safe operations, please backup first
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +* [hugo convert toJSON](/commands/hugo_convert_tojson/)        - Convert front matter to JSON
 +* [hugo convert toTOML](/commands/hugo_convert_totoml/)        - Convert front matter to TOML
 +* [hugo convert toYAML](/commands/hugo_convert_toyaml/)        - Convert front matter to YAML
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo convert toJSON"
 +slug: hugo_convert_toJSON
 +url: /commands/hugo_convert_tojson/
 +---
 +## hugo convert toJSON
 +
 +Convert front matter to JSON
 +
 +### Synopsis
 +
 +toJSON converts all front matter in the content directory
 +to use JSON for the front matter.
 +
 +```
 +hugo convert toJSON [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for toJSON
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +  -o, --output string    filesystem path to write files to
 +      --quiet            build in quiet mode
 +  -s, --source string    filesystem path to read files relative from
 +      --unsafe           enable less safe operations, please backup first
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo convert](/commands/hugo_convert/)      - Convert your content to different formats
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo convert toTOML"
 +slug: hugo_convert_toTOML
 +url: /commands/hugo_convert_totoml/
 +---
 +## hugo convert toTOML
 +
 +Convert front matter to TOML
 +
 +### Synopsis
 +
 +toTOML converts all front matter in the content directory
 +to use TOML for the front matter.
 +
 +```
 +hugo convert toTOML [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for toTOML
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +  -o, --output string    filesystem path to write files to
 +      --quiet            build in quiet mode
 +  -s, --source string    filesystem path to read files relative from
 +      --unsafe           enable less safe operations, please backup first
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo convert](/commands/hugo_convert/)      - Convert your content to different formats
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo convert toYAML"
 +slug: hugo_convert_toYAML
 +url: /commands/hugo_convert_toyaml/
 +---
 +## hugo convert toYAML
 +
 +Convert front matter to YAML
 +
 +### Synopsis
 +
 +toYAML converts all front matter in the content directory
 +to use YAML for the front matter.
 +
 +```
 +hugo convert toYAML [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for toYAML
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +  -o, --output string    filesystem path to write files to
 +      --quiet            build in quiet mode
 +  -s, --source string    filesystem path to read files relative from
 +      --unsafe           enable less safe operations, please backup first
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo convert](/commands/hugo_convert/)      - Convert your content to different formats
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo env"
 +slug: hugo_env
 +url: /commands/hugo_env/
 +---
 +## hugo env
 +
 +Print Hugo version and environment info
 +
 +### Synopsis
 +
 +Print Hugo version and environment info. This is useful in Hugo bug reports.
 +
 +```
 +hugo env [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for env
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo gen"
 +slug: hugo_gen
 +url: /commands/hugo_gen/
 +---
 +## hugo gen
 +
 +A collection of several useful generators.
 +
 +### Synopsis
 +
 +A collection of several useful generators.
 +
 +### Options
 +
 +```
 +  -h, --help   help for gen
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +* [hugo gen autocomplete](/commands/hugo_gen_autocomplete/)    - Generate shell autocompletion script for Hugo
 +* [hugo gen chromastyles](/commands/hugo_gen_chromastyles/)    - Generate CSS stylesheet for the Chroma code highlighter
 +* [hugo gen doc](/commands/hugo_gen_doc/)      - Generate Markdown documentation for the Hugo CLI.
 +* [hugo gen man](/commands/hugo_gen_man/)      - Generate man pages for the Hugo CLI
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo gen autocomplete"
 +slug: hugo_gen_autocomplete
 +url: /commands/hugo_gen_autocomplete/
 +---
 +## hugo gen autocomplete
 +
 +Generate shell autocompletion script for Hugo
 +
 +### Synopsis
 +
 +Generates a shell autocompletion script for Hugo.
 +
 +NOTE: The current version supports Bash only.
 +      This should work for *nix systems with Bash installed.
 +
 +By default, the file is written directly to /etc/bash_completion.d
 +for convenience, and the command may need superuser rights, e.g.:
 +
 +      $ sudo hugo gen autocomplete
 +
 +Add `--completionfile=/path/to/file` flag to set alternative
 +file-path and name.
 +
 +Logout and in again to reload the completion scripts,
 +or just source them in directly:
 +
 +      $ . /etc/bash_completion
 +
 +```
 +hugo gen autocomplete [flags]
 +```
 +
 +### Options
 +
 +```
 +      --completionfile string   autocompletion file (default "/etc/bash_completion.d/hugo.sh")
 +  -h, --help                    help for autocomplete
 +      --type string             autocompletion type (currently only bash supported) (default "bash")
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo gen](/commands/hugo_gen/)      - A collection of several useful generators.
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo gen chromastyles"
 +slug: hugo_gen_chromastyles
 +url: /commands/hugo_gen_chromastyles/
 +---
 +## hugo gen chromastyles
 +
 +Generate CSS stylesheet for the Chroma code highlighter
 +
 +### Synopsis
 +
 +Generate CSS stylesheet for the Chroma code highlighter for a given style. This stylesheet is needed if pygmentsUseClasses is enabled in config.
 +
 +See https://help.farbox.com/pygments.html for preview of available styles
 +
 +```
 +hugo gen chromastyles [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help                    help for chromastyles
 +      --highlightStyle string   style used for highlighting lines (see https://github.com/alecthomas/chroma) (default "bg:#ffffcc")
 +      --linesStyle string       style used for line numbers (see https://github.com/alecthomas/chroma)
 +      --style string            highlighter style (see https://help.farbox.com/pygments.html) (default "friendly")
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo gen](/commands/hugo_gen/)      - A collection of several useful generators.
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo gen doc"
 +slug: hugo_gen_doc
 +url: /commands/hugo_gen_doc/
 +---
 +## hugo gen doc
 +
 +Generate Markdown documentation for the Hugo CLI.
 +
 +### Synopsis
 +
 +Generate Markdown documentation for the Hugo CLI.
 +
 +This command is, mostly, used to create up-to-date documentation
 +of Hugo's command-line interface for http://gohugo.io/.
 +
 +It creates one Markdown file per command with front matter suitable
 +for rendering in Hugo.
 +
 +```
 +hugo gen doc [flags]
 +```
 +
 +### Options
 +
 +```
 +      --dir string   the directory to write the doc. (default "/tmp/hugodoc/")
 +  -h, --help         help for doc
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo gen](/commands/hugo_gen/)      - A collection of several useful generators.
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo gen man"
 +slug: hugo_gen_man
 +url: /commands/hugo_gen_man/
 +---
 +## hugo gen man
 +
 +Generate man pages for the Hugo CLI
 +
 +### Synopsis
 +
 +This command automatically generates up-to-date man pages of Hugo's
 +command-line interface.  By default, it creates the man page files
 +in the "man" directory under the current directory.
 +
 +```
 +hugo gen man [flags]
 +```
 +
 +### Options
 +
 +```
 +      --dir string   the directory to write the man pages. (default "man/")
 +  -h, --help         help for man
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo gen](/commands/hugo_gen/)      - A collection of several useful generators.
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo import"
 +slug: hugo_import
 +url: /commands/hugo_import/
 +---
 +## hugo import
 +
 +Import your site from others.
 +
 +### Synopsis
 +
 +Import your site from other web site generators like Jekyll.
 +
 +Import requires a subcommand, e.g. `hugo import jekyll jekyll_root_path target_path`.
 +
 +### Options
 +
 +```
 +  -h, --help   help for import
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +* [hugo import jekyll](/commands/hugo_import_jekyll/)  - hugo import from Jekyll
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo import jekyll"
 +slug: hugo_import_jekyll
 +url: /commands/hugo_import_jekyll/
 +---
 +## hugo import jekyll
 +
 +hugo import from Jekyll
 +
 +### Synopsis
 +
 +hugo import from Jekyll.
 +
 +Import from Jekyll requires two paths, e.g. `hugo import jekyll jekyll_root_path target_path`.
 +
 +```
 +hugo import jekyll [flags]
 +```
 +
 +### Options
 +
 +```
 +      --force   allow import into non-empty target directory
 +  -h, --help    help for jekyll
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo import](/commands/hugo_import/)        - Import your site from others.
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo list"
 +slug: hugo_list
 +url: /commands/hugo_list/
 +---
 +## hugo list
 +
 +Listing out various types of content
 +
 +### Synopsis
 +
 +Listing out various types of content.
 +
 +List requires a subcommand, e.g. `hugo list drafts`.
 +
 +### Options
 +
 +```
 +  -h, --help            help for list
 +  -s, --source string   filesystem path to read files relative from
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +* [hugo list drafts](/commands/hugo_list_drafts/)      - List all drafts
 +* [hugo list expired](/commands/hugo_list_expired/)    - List all posts already expired
 +* [hugo list future](/commands/hugo_list_future/)      - List all posts dated in the future
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo list drafts"
 +slug: hugo_list_drafts
 +url: /commands/hugo_list_drafts/
 +---
 +## hugo list drafts
 +
 +List all drafts
 +
 +### Synopsis
 +
 +List all of the drafts in your content directory.
 +
 +```
 +hugo list drafts [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for drafts
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -s, --source string    filesystem path to read files relative from
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo list](/commands/hugo_list/)    - Listing out various types of content
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo list expired"
 +slug: hugo_list_expired
 +url: /commands/hugo_list_expired/
 +---
 +## hugo list expired
 +
 +List all posts already expired
 +
 +### Synopsis
 +
 +List all of the posts in your content directory which has already
 +expired.
 +
 +```
 +hugo list expired [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for expired
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -s, --source string    filesystem path to read files relative from
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo list](/commands/hugo_list/)    - Listing out various types of content
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo list future"
 +slug: hugo_list_future
 +url: /commands/hugo_list_future/
 +---
 +## hugo list future
 +
 +List all posts dated in the future
 +
 +### Synopsis
 +
 +List all of the posts in your content directory which will be
 +posted in the future.
 +
 +```
 +hugo list future [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for future
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -s, --source string    filesystem path to read files relative from
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo list](/commands/hugo_list/)    - Listing out various types of content
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo new"
 +slug: hugo_new
 +url: /commands/hugo_new/
 +---
 +## hugo new
 +
 +Create new content for your site
 +
 +### Synopsis
 +
 +Create a new content file and automatically set the date and title.
 +It will guess which kind of file to create based on the path provided.
 +
 +You can also specify the kind with `-k KIND`.
 +
 +If archetypes are provided in your theme or site, they will be used.
 +
 +```
 +hugo new [path] [flags]
 +```
 +
 +### Options
 +
 +```
 +      --editor string   edit new content with this editor, if provided
 +  -h, --help            help for new
 +  -k, --kind string     content type to create
 +  -s, --source string   filesystem path to read files relative from
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +* [hugo new site](/commands/hugo_new_site/)    - Create a new site (skeleton)
 +* [hugo new theme](/commands/hugo_new_theme/)  - Create a new theme
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo new site"
 +slug: hugo_new_site
 +url: /commands/hugo_new_site/
 +---
 +## hugo new site
 +
 +Create a new site (skeleton)
 +
 +### Synopsis
 +
 +Create a new site in the provided directory.
 +The new site will have the correct structure, but no content or theme yet.
 +Use `hugo new [contentPath]` to create new content.
 +
 +```
 +hugo new site [path] [flags]
 +```
 +
 +### Options
 +
 +```
 +      --force           init inside non-empty directory
 +  -f, --format string   config & frontmatter format (default "toml")
 +  -h, --help            help for site
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -s, --source string    filesystem path to read files relative from
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo new](/commands/hugo_new/)      - Create new content for your site
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo new theme"
 +slug: hugo_new_theme
 +url: /commands/hugo_new_theme/
 +---
 +## hugo new theme
 +
 +Create a new theme
 +
 +### Synopsis
 +
 +Create a new theme (skeleton) called [name] in the current directory.
 +New theme is a skeleton. Please add content to the touched files. Add your
 +name to the copyright line in the license and adjust the theme.toml file
 +as you see fit.
 +
 +```
 +hugo new theme [name] [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for theme
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -s, --source string    filesystem path to read files relative from
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo new](/commands/hugo_new/)      - Create new content for your site
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo server"
 +slug: hugo_server
 +url: /commands/hugo_server/
 +---
 +## hugo server
 +
 +A high performance webserver
 +
 +### Synopsis
 +
 +Hugo provides its own webserver which builds and serves the site.
 +While hugo server is high performance, it is a webserver with limited options.
 +Many run it in production, but the standard behavior is for people to use it
 +in development and use a more full featured server such as Nginx or Caddy.
 +
 +'hugo server' will avoid writing the rendered and served content to disk,
 +preferring to store it in memory.
 +
 +By default hugo will also watch your files for any changes you make and
 +automatically rebuild the site. It will then live reload any open browser pages
 +and push the latest content to them. As most Hugo sites are built in a fraction
 +of a second, you will be able to save and see your changes nearly instantly.
 +
 +```
 +hugo server [flags]
 +```
 +
 +### Options
 +
 +```
 +      --appendPort                 append port to baseURL (default true)
 +  -b, --baseURL string             hostname (and path) to the root, e.g. http://spf13.com/
 +      --bind string                interface to which the server will bind (default "127.0.0.1")
 +  -D, --buildDrafts                include content marked as draft
 +  -E, --buildExpired               include expired content
 +  -F, --buildFuture                include content with publishdate in the future
 +      --cacheDir string            filesystem path to cache directory. Defaults: $TMPDIR/hugo_cache/
 +      --canonifyURLs               (deprecated) if true, all relative URLs will be canonicalized using baseURL
 +      --cleanDestinationDir        remove files from destination not found in static directories
 +  -c, --contentDir string          filesystem path to content directory
 +  -d, --destination string         filesystem path to write files to
 +      --disableFastRender          enables full re-renders on changes
 +      --disableKinds stringSlice   disable different kind of pages (home, RSS etc.)
 +      --disableLiveReload          watch without enabling live browser reload on rebuild
 +      --enableGitInfo              add Git revision, date and author info to the pages
 +      --forceSyncStatic            copy all files when static is changed.
 +      --gc                         enable to run some cleanup tasks (remove unused cache files) after the build
 +  -h, --help                       help for server
 +      --i18n-warnings              print missing translations
 +      --ignoreCache                ignores the cache directory
 +  -l, --layoutDir string           filesystem path to layout directory
 +      --liveReloadPort int         port for live reloading (i.e. 443 in HTTPS proxy situations) (default -1)
 +      --meminterval string         interval to poll memory usage (requires --memstats), valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h". (default "100ms")
 +      --memstats string            log memory usage to this file
 +      --navigateToChanged          navigate to changed content file on live browser reload
 +      --noChmod                    don't sync permission mode of files
 +      --noHTTPCache                prevent HTTP caching
 +      --noTimes                    don't sync modification time of files
 +      --pluralizeListTitles        (deprecated) pluralize titles in lists using inflect (default true)
 +  -p, --port int                   port on which the server will listen (default 1313)
 +      --preserveTaxonomyNames      (deprecated) preserve taxonomy names as written ("Gérard Depardieu" vs "gerard-depardieu")
 +      --renderToDisk               render to Destination path (default is render to memory & serve from there)
 +  -s, --source string              filesystem path to read files relative from
 +      --stepAnalysis               display memory and timing of different steps of the program
 +      --templateMetrics            display metrics about template executions
 +      --templateMetricsHints       calculate some improvement hints when combined with --templateMetrics
 +  -t, --theme string               theme to use (located in /themes/THEMENAME/)
 +      --themesDir string           filesystem path to themes directory
 +      --uglyURLs                   (deprecated) if true, use /filename.html instead of /filename/
 +  -w, --watch                      watch filesystem for changes and recreate as needed (default true)
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- date: 2018-01-31T11:40:21+01:00
 +---
- ###### Auto generated by spf13/cobra on 31-Jan-2018
++date: 2018-04-16
 +title: "hugo version"
 +slug: hugo_version
 +url: /commands/hugo_version/
 +---
 +## hugo version
 +
 +Print the version number of Hugo
 +
 +### Synopsis
 +
 +All software has versions. This is Hugo's.
 +
 +```
 +hugo version [flags]
 +```
 +
 +### Options
 +
 +```
 +  -h, --help   help for version
 +```
 +
 +### Options inherited from parent commands
 +
 +```
 +      --config string    config file (default is path/config.yaml|json|toml)
 +      --debug            debug output
 +      --log              enable Logging
 +      --logFile string   log File path (if set, logging enabled automatically)
 +      --quiet            build in quiet mode
 +  -v, --verbose          verbose output
 +      --verboseLog       verbose logging
 +```
 +
 +### SEE ALSO
 +
 +* [hugo](/commands/hugo/)      - hugo builds your site
 +
++###### Auto generated by spf13/cobra on 16-Apr-2018
 
--- /dev/null
- `aliases`
 +---
 +title: Front Matter
 +linktitle:
 +description: Hugo allows you to add front matter in yaml, toml, or json to your content files.
 +date: 2017-01-09
 +publishdate: 2017-01-09
 +lastmod: 2017-02-24
 +categories: [content management]
 +keywords: ["front matter", "yaml", "toml", "json", "metadata", "archetypes"]
 +menu:
 +  docs:
 +    parent: "content-management"
 +    weight: 30
 +weight: 30    #rem
 +draft: false
 +aliases: [/content/front-matter/]
 +toc: true
 +---
 +
 +**Front matter** allows you to keep metadata attached to an instance of a [content type][]---i.e., embedded inside a content file---and is one of the many features that gives Hugo its strength.
 +
 +{{< youtube Yh2xKRJGff4 >}}
 +
 +## Front Matter Formats
 +
 +Hugo supports three formats for front matter, each with their own identifying tokens.
 +
 +TOML
 +: identified by opening and closing `+++`.
 +
 +YAML
 +: identified by opening and closing `---`.
 +
 +JSON
 +: a single JSON object surrounded by '`{`' and '`}`', followed by a new line.
 +
 +### Example
 +
 +{{< code-toggle >}}
 ++++
 +title = "spf13-vim 3.0 release and new website"
 +description = "spf13-vim is a cross platform distribution of vim plugins and resources for Vim."
 +tags = [ ".vimrc", "plugins", "spf13-vim", "vim" ]
 +date = "2012-04-06"
 +categories = [
 +  "Development",
 +  "VIM"
 +]
 +slug = "spf13-vim-3-0-release-and-new-website"
 ++++
 +{{</ code-toggle >}}
 +
 +## Front Matter Variables
 +
 +### Predefined
 +
 +There are a few predefined variables that Hugo is aware of. See [Page Variables][pagevars] for how to call many of these predefined variables in your templates.
 +
- `date`
++aliases
 +: an array of one or more aliases (e.g., old published paths of renamed content) that will be created in the output directory structure . See [Aliases][aliases] for details.
 +
- `description`
++date
 +: the datetime at which the content was created; note this value is auto-populated according to Hugo's built-in [archetype][].
 +
- `draft`
++description
 +: the description for the content.
 +
- `expiryDate`
++draft
 +: if `true`, the content will not be rendered unless the `--buildDrafts` flag is passed to the `hugo` command.
 +
- `headless`
++expiryDate
 +: the datetime at which the content should no longer be published by Hugo; expired content will not be rendered unless the `--buildExpired` flag is passed to the `hugo` command.
 +
- `isCJKLanguage`
++headless
 +: if `true`, sets a leaf bundle to be [headless][headless-bundle].
 +
- `keywords`
++isCJKLanguage
 +: if `true`, Hugo will explicitly treat the content as a CJK language; both `.Summary` and `.WordCount` work properly in CJK languages.
 +
- `layout`
++keywords
 +: the meta keywords for the content.
 +
- `lastmod`
++layout
 +: the layout Hugo should select from the [lookup order][lookup] when rendering the content. If a `type` is not specified in the front matter, Hugo will look for the layout of the same name in the layout directory that corresponds with a content's section. See ["Defining a Content Type"][definetype]
 +
- `linkTitle`
++lastmod
 +: the datetime at which the content was last modified.
 +
- `markup`
++linkTitle
 +: used for creating links to content; if set, Hugo defaults to using the `linktitle` before the `title`. Hugo can also [order lists of content by `linktitle`][bylinktitle].
 +
- `outputs`
++markup
 +: **experimental**; specify `"rst"` for reStructuredText (requires`rst2html`) or `"md"` (default) for Markdown.
 +
- `publishDate`
++outputs
 +: allows you to specify output formats specific to the content. See [output formats][outputs].
 +
- `resources`
++publishDate
 +: if in the future, content will not be rendered unless the `--buildFuture` flag is passed to `hugo`.
 +
- `slug`
++resources
 +: used for configuring page bundle resources. See [Page Resources][page-resources].
 +
- `taxonomies`
- : these will use the field name of the plural form of the index; see the `tags` and `categories` in the above front matter examples.
- 
- `title`
++slug
 +: appears as the tail of the output URL. A value specified in front matter will override the segment of the URL based on the filename.
 +
- `type`
++title
 +: the title for the content.
 +
- `url`
++type
 +: the type of the content; this value will be automatically derived from the directory (i.e., the [section][]) if not specified in front matter.
 +
- `weight`
++url
 +: the full path to the content from the web root. It makes no assumptions about the path of the content file. It also ignores any language prefixes of
 +the multilingual feature.
 +
- ```
++weight
 +: used for [ordering your content in lists][ordering].
 +
++\<taxonomies\>
++: field name of the *plural* form of the index. See `tags` and `categories` in the above front matter examples. _Note that the plural form of user-defined taxonomies cannot be the same as any of the predefined front matter variables._
++
 +{{% note "Hugo's Default URL Destinations" %}}
 +If neither `slug` nor `url` is present and [permalinks are not configured otherwise in your site `config` file](/content-management/urls/#permalinks), Hugo will use the filename of your content to create the output URL. See [Content Organization](/content-management/organization) for an explanation of paths in Hugo and [URL Management](/content-management/urls/) for ways to customize Hugo's default behaviors.
 +{{% /note %}}
 +
 +### User-Defined
 +
 +You can add fields to your front matter arbitrarily to meet your needs. These user-defined key-values are placed into a single `.Params` variable for use in your templates.
 +
 +The following fields can be accessed via `.Params.include_toc` and `.Params.show_comments`, respectively. The [Variables][] section provides more information on using Hugo's page- and site-level variables in your templates.
 +
- ```
++{{< code-toggle copy="false" >}}
 +include_toc: true
 +show_comments: false
++{{</ code-toggle >}}
 +
 +
 +## Order Content Through Front Matter
 +
 +You can assign content-specific `weight` in the front matter of your content. These values are especially useful for [ordering][ordering] in list views. You can use `weight` for ordering of content and the convention of [`<TAXONOMY>_weight`][taxweight] for ordering content within a taxonomy. See [Ordering and Grouping Hugo Lists][lists] to see how `weight` can be used to organize your content in list views.
 +
 +## Override Global Markdown Configuration
 +
 +It's possible to set some options for Markdown rendering in a content's front matter as an override to the [BlackFriday rendering options set in your project configuration][config].
 +
 +## Front Matter Format Specs
 +
 +* [TOML Spec][toml]
 +* [YAML Spec][yaml]
 +* [JSON Spec][json]
 +
 +[variables]: /variables/
 +[aliases]: /content-management/urls/#aliases/
 +[archetype]: /content-management/archetypes/
 +[bylinktitle]: /templates/lists/#by-link-title
 +[config]: /getting-started/configuration/ "Hugo documentation for site configuration"
 +[content type]: /content-management/types/
 +[contentorg]: /content-management/organization/
 +[definetype]: /content-management/types/#defining-a-content-type "Learn how to specify a type and a layout in a content's front matter"
 +[headless-bundle]: /content-management/page-bundles/#headless-bundle
 +[json]: https://www.ecma-international.org/publications/files/ECMA-ST/ECMA-404.pdf "Specification for JSON, JavaScript Object Notation"
 +[lists]: /templates/lists/#ordering-content "See how to order content in list pages; for example, templates that look to specific _index.md for content and front matter."
 +[lookup]: /templates/lookup-order/ "Hugo traverses your templates in a specific order when rendering content to allow for DRYer templating."
 +[ordering]: /templates/lists/ "Hugo provides multiple ways to sort and order your content in list templates"
 +[outputs]: /templates/output-formats/ "With the release of v22, you can output your content to any text format using Hugo's familiar templating"
 +[page-resources]: /content-management/page-resources/
 +[pagevars]: /variables/page/
 +[section]: /content-management/sections/
 +[taxweight]: /content-management/taxonomies/
 +[toml]: https://github.com/toml-lang/toml "Specification for TOML, Tom's Obvious Minimal Language"
 +[urls]: /content-management/urls/
 +[variables]: /variables/
 +[yaml]: http://yaml.org/spec/ "Specification for YAML, YAML Ain't Markup Language"
 
--- /dev/null
- Note that the filename must be relative to the current project working directory.
 +---
 +title: readFile
 +description: Reads a file from disk relative to the current project working directory and returns a string.
 +godocref:
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-04-30
 +categories: [functions]
 +menu:
 +  docs:
 +    parent: "functions"
 +keywords: [files]
 +signature: ["readFile PATH"]
 +workson: []
 +hugoversion:
 +relatedfuncs: [readDir]
 +deprecated: false
 +aliases: []
 +---
 +
++Note that the filename must be relative to the current project working directory, or the project's `/content` folder. 
 +
 +So, if you have a file with the name `README.txt` in the root of your project with the content `Hugo Rocks!`:
 +
 +```
 +{{readFile "README.txt"}} → "Hugo Rocks!"
 +```
 +
++If you receive a "file doesn't exist" error with a path listed, do take note that the path is the last one checked by the function, and may not accurately reflect your target. You should generally double-check your path for mistakes.
++
 +For more information on using `readDir` and `readFile` in your templates, see [Local File Templates][local].
 +
 +[local]: /templates/files/
 
--- /dev/null
- In most cases you can do well without `Scratch`, but there are some use cases that aren't solvable with Go's templates without `Scratch`'s help, due to scoping issues.
 +---
 +title: .Scratch
 +description: Acts as a "scratchpad" to allow for writable page- or shortcode-scoped variables.
 +godocref:
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +keywords: [iteration]
 +categories: [functions]
 +menu:
 +  docs:
 +    parent: "functions"
 +toc:
 +signature: []
 +workson: []
 +hugoversion:
 +relatedfuncs: []
 +deprecated: false
 +draft: false
 +aliases: [/extras/scratch/,/doc/scratch/]
 +---
 +
- * `Set` and `Add` takes a `key` and the `value` to add.
- * `Get` returns the `value` for the `key` given.
- * `SetInMap` takes a `key`, `mapKey` and `value`
- * `GetSortedMapValues` returns array of values from `key` sorted by `mapKey`
- * `Delete` takes a `key` to remove
++In most cases you can do okay without `Scratch`, but due to scoping issues, there are many use cases that aren't solvable in Go Templates without `Scratch`'s help.
 +
 +{{% note %}}
 +See [this Go issue](https://github.com/golang/go/issues/10608) for the main motivation behind Scratch.
 +{{% /note %}}
 +
++{{% note %}}
++For a detailed analysis of `.Scratch` and in context use cases, see this [post](https://regisphilibert.com/blog/2017/04/hugo-scratch-explained-variable/).
++{{% /note %}}
++
++## Methods
++
 +`Scratch` is added to both `Page` and `Shortcode` -- with following methods:
 +
- `Set` and `SetInMap` can store values of any type.
++#### .Set
++Set the given value to a given key
++
++```go-html-template
++{{ .Scratch.Set "greeting" "Hello" }}
++```
++#### .Get
++Get the value of a given key
++
++```go-html-template
++{{ .Scratch.Set "greeting" "Hello" }}
++----
++{{ .Scratch.Get "greeting" }} > Hello
++```
 +
- The scope of the backing data is global for the given `Page` or `Shortcode`, and spans partial and shortcode includes.
++#### .Add
++Will add a given value to existing value of the given key. 
 +
 +For single values, `Add` accepts values that support Go's `+` operator. If the first `Add` for a key is an array or slice, the following adds will be appended to that list.
 +
- Note that `.Scratch` from a shortcode will return the shortcode's `Scratch`, which in most cases is what you want. If you want to store it in the page scroped Scratch, then use `.Page.Scratch`.
++```go-html-template
++{{ .Scratch.Add "greetings" "Hello" }}
++{{ .Scratch.Add "greetings" "Welcome" }}
++----
++{{ .Scratch.Get "greetings" }} > HelloWelcome
++```
 +
- ## Sample usage
++```go-html-template
++{{ .Scratch.Add "total" 3 }}
++{{ .Scratch.Add "total" 7 }}
++----
++{{ .Scratch.Get "total" }} > 10
++```
 +
- The usage is best illustrated with some samples:
 +
- {{ $.Scratch.Add "a1" 12 }}
- {{ $.Scratch.Get "a1" }} {{/* => 12 */}}
- {{ $.Scratch.Add "a1" 1 }}
- {{ $.Scratch.Get "a1" }} // {{/* => 13 */}}
- 
- {{ $.Scratch.Add "a2" "AB" }}
- {{ $.Scratch.Get "a2" }} {{/* => AB */}}
- {{ $.Scratch.Add "a2" "CD" }}
- {{ $.Scratch.Get "a2" }} {{/* => ABCD */}}
- 
- {{ $.Scratch.Add "l1" (slice "A" "B") }}
- {{ $.Scratch.Get "l1" }} {{/* => [A B]  */}}
- {{ $.Scratch.Add "l1" (slice "C" "D") }}
- {{ $.Scratch.Get "l1" }} {{/* => [A B C D] */}}
- 
- {{ $.Scratch.Set "v1" 123 }}
- {{ $.Scratch.Get "v1" }}  {{/* => 123 */}}
- 
- {{ $.Scratch.SetInMap "a3" "b" "XX" }}
- {{ $.Scratch.SetInMap "a3" "a" "AA" }}
- {{ $.Scratch.SetInMap "a3" "c" "CC" }}
- {{ $.Scratch.SetInMap "a3" "b" "BB" }}
- {{ $.Scratch.GetSortedMapValues "a3" }} {{/* => []interface {}{"AA", "BB", "CC"} */}}
- 
- {{ $.Scratch.Add "a" 1 }}
- {{ $.Scratch.Delete "a" }}
- {{ $.Scratch.Add "a" 2 }}
- {{ $.Scratch.Get "a" }} {{/* => 2 */}}
++```go-html-template
++{{ .Scratch.Add "greetings" (slice "Hello") }}
++{{ .Scratch.Add "greetings" (slice "Welcome" "Cheers") }}
++----
++{{ .Scratch.Get "greetings" }} > []interface {}{"Hello", "Welcome", "Cheers"}
++```
 +
++#### .SetInMap
++Takes a `key`, `mapKey` and `value` and add a map of `mapKey` and `value` to the given `key`.
++
++```go-html-template
++{{ .Scratch.SetInMap "greetings" "english" "Hello" }}
++{{ .Scratch.SetInMap "greetings" "french" "Bonjour" }}
++----
++{{ .Scratch.Get "greetings" }} > map[french:Bonjour english:Hello]
 +```
- {{% note %}}
- The examples above uses the special `$` variable, which refers to the top-level node. This is the behavior you most likely want, and will help remove some confusion when using `Scratch` inside page range loops -- and you start inadvertently calling the wrong `Scratch`. But there may be use cases for `{{ .Scratch.Add "key" "some value" }}`.
- {{% /note %}}
++
++#### .GetSortedMapValues
++Returns array of values from `key` sorted by `mapKey`
++
++```go-html-template
++{{ .Scratch.SetInMap "greetings" "english" "Hello" }}
++{{ .Scratch.SetInMap "greetings" "french" "Bonjour" }}
++----
++{{ .Scratch.GetSortedMapValues "greetings" }} > [Hello Bonjour]
 +```
++#### .Delete
++Removes the given key
++
++```go-html-template
++{{ .Scratch.Delete "greetings" }}
++```
++
++## Scope
++The scope of the backing data is global for the given `Page` or `Shortcode`, and spans partial and shortcode includes.
++
++Note that `.Scratch` from a shortcode will return the shortcode's `Scratch`, which in most cases is what you want. If you want to store it in the page scoped Scratch, then use `.Page.Scratch`.
++
 +
 +
 +
 +[pagevars]: /variables/page/
 
--- /dev/null
- : Fetches the date from the content file's filename. For example, `218-02-22-mypage.md` will extract the date `218-02-22`. Also, if `slug is not set, `mypage` will be used as the value for `.Slug`.
 +---
 +title: Configure Hugo
 +linktitle: Configuration
 +description: How to configure your Hugo site.
 +date: 2013-07-01
 +publishdate: 2017-01-02
 +lastmod: 2017-03-05
 +categories: [getting started,fundamentals]
 +keywords: [configuration,toml,yaml,json]
 +menu:
 +  docs:
 +    parent: "getting-started"
 +    weight: 60
 +weight: 60
 +sections_weight: 60
 +draft: false
 +aliases: [/overview/source-directory/,/overview/configuration/]
 +toc: true
 +---
 +
 +Hugo uses the `config.toml`, `config.yaml`, or `config.json` (if found in the
 +site root) as the default site config file.
 +
 +The user can choose to override that default with one or more site config files
 +using the command line `--config` switch.
 +
 +Examples:
 +
 +```
 +hugo --config debugconfig.toml
 +hugo --config a.toml,b.toml,c.toml
 +```
 +
 +{{% note %}}
 +Multiple site config files can be specified as a comma-separated string to the `--config` switch.
 +{{% /note %}}
 +
 +## All Configuration Settings
 +
 +The following is the full list of Hugo-defined variables with their default
 +value in parentheses. Users may choose to override those values in their site
 +config file(s).
 +
 +archetypeDir ("archetypes")
 +: The directory where Hugo finds archetype files (content templates).
 +
 +baseURL
 +: Hostname (and path) to the root, e.g. http://bep.is/
 +
 +blackfriday
 +: See [Configure Blackfriday](/getting-started/configuration/#configure-blackfriday)
 +
 +buildDrafts (false)
 +: Include drafts when building.
 +
 +buildExpired  (false)
 +: Include content already expired.
 +
 +buildFuture (false)
 +: Include content with publishdate in the future.
 +
 +canonifyURLs (false)
 +: Enable to turn relative URLs into absolute.
 +
 +contentDir ("content")
 +: The directory from where Hugo reads content files.
 +
 +dataDir ("data")
 +: The directory from where Hugo reads data files.
 +
 +defaultContentLanguage ("en")
 +: Content without language indicator will default to this language.
 +
 +defaultContentLanguageInSubdir (false)
 +: Render the default content language in subdir, e.g. `content/en/`. The site root `/` will then redirect to `/en/`.
 +
 +disableHugoGeneratorInject (false)
 +: Hugo will, by default, inject a generator meta tag in the HTML head on the _home page only_. You can turn it off, but we would really appreciate if you don't, as this is a good way to watch Hugo's popularity on the rise.
 +
 +disableKinds ([])
 +: Enable disabling of all pages of the specified *Kinds*. Allowed values in this list: `"page"`, `"home"`, `"section"`, `"taxonomy"`, `"taxonomyTerm"`, `"RSS"`, `"sitemap"`, `"robotsTXT"`, `"404"`.
 +
 +disableLiveReload (false)
 +: Disable automatic live reloading of browser window.
 +
 +disablePathToLower (false)
 +: Do not convert the url/path to lowercase.
 +
 +enableEmoji (false)
 +: Enable Emoji emoticons support for page content; see the [Emoji Cheat Sheet](https://www.webpagefx.com/tools/emoji-cheat-sheet/).
 +
 +enableGitInfo (false)
 +: Enable `.GitInfo` object for each page (if the Hugo site is versioned by Git). This will then update the `Lastmod` parameter for each page using the last git commit date for that content file.
 +
 +enableMissingTranslationPlaceholders (false)
 +: Show a placeholder instead of the default value or an empty string if a translation is missing.
 +
 +enableRobotsTXT (false)
 +: Enable generation of `robots.txt` file.
 +
 +frontmatter
 +
 +: See [Front matter Configuration](#configure-front-matter).
 +
 +footnoteAnchorPrefix ("")
 +: Prefix for footnote anchors.
 +
 +footnoteReturnLinkContents ("")
 +: Text to display for footnote return links.
 +
 +googleAnalytics ("")
 +: Google Analytics tracking ID.
 +
 +hasCJKLanguage (false)
 +: If true, auto-detect Chinese/Japanese/Korean Languages in the content. This will make `.Summary` and `.WordCount` behave correctly for CJK languages.
 +
 +imaging
 +: See [Image Processing Config](/content-management/image-processing/#image-processing-config).
 +
 +languages
 +: See [Configure Languages](/content-management/multilingual/#configure-languages).
 +
 +languageCode ("")
 +: The site's language code.
 +
 +disableLanguages
 +: See [Disable a Language](/content-management/multilingual/#disable-a-language)
 +
 +layoutDir ("layouts")
 +: The directory from where Hugo reads layouts (templates).
 +
 +log (false)
 +: Enable logging.
 +
 +logFile ("")
 +: Log File path (if set, logging enabled automatically).
 +
 +menu
 +: See [Add Non-content Entries to a Menu](/content-management/menus/#add-non-content-entries-to-a-menu).
 +
 +metaDataFormat ("toml")
 +: Front matter meta-data format. Valid values: `"toml"`, `"yaml"`, or `"json"`.
 +
 +newContentEditor ("")
 +: The editor to use when creating new content.
 +
 +noChmod (false)
 +: Don't sync permission mode of files.
 +
 +noTimes (false)
 +: Don't sync modification time of files.
 +
 +paginate (10)
 +: Default number of pages per page in [pagination](/templates/pagination/).
 +
 +paginatePath ("page")
 +: The path element used during pagination (https://example.com/page/2).
 +
 +permalinks
 +: See [Content Management](/content-management/urls/#permalinks).
 +
 +pluralizeListTitles (true)
 +: Pluralize titles in lists.
 +
 +preserveTaxonomyNames (false)
 +: Preserve special characters in taxonomy names ("Gérard Depardieu" vs "Gerard Depardieu").
 +
 +publishDir ("public")
 +: The directory to where Hugo will write the final static site (the HTML files etc.).
 +
 +pygmentsCodeFencesGuessSyntax (false)
 +: Enable syntax guessing for code fences without specified language.
 +
 +pygmentsStyle ("monokai")
 +: Color-theme or style for syntax highlighting. See [Pygments Color Themes](https://help.farbox.com/pygments.html).
 +
 +pygmentsUseClasses (false)
 +: Enable using external CSS for syntax highlighting.
 +
 +related
 +: See [Related Content](/content-management/related/#configure-related-content).
 +
 +relativeURLs (false)
 +: Enable this to make all relative URLs relative to content root. Note that this does not affect absolute URLs.
 +
 +rssLimit (unlimited)
 +: Maximum number of items in the RSS feed.
 +
 +sectionPagesMenu ("")
 +: See ["Section Menu for Lazy Bloggers"](/templates/menu-templates/#section-menu-for-lazy-bloggers).
 +
 +sitemap
 +: Default [sitemap configuration](/templates/sitemap-template/#configure-sitemap-xml).
 +
 +staticDir ("static")
 +: Relative directory from where Hugo reads static files.
 +
 +stepAnalysis (false)
 +: Display memory and timing of different steps of the program.
 +
 +summaryLength (70)
 +: The length of text to show in a [`.Summary`](/content-management/summaries/#hugo-defined-automatic-summary-splitting).
 +
 +taxonomies
 +: See [Configure Taxonomies](/content-management/taxonomies#configure-taxonomies).
 +
 +theme ("")
 +: Theme to use (located by default in `/themes/THEMENAME/`).
 +
 +themesDir ("themes")
 +: The directory where Hugo reads the themes from.
 +
 +title ("")
 +: Site title.
 +
 +uglyURLs (false)
 +: When enabled, creates URL of the form `/filename.html` instead of `/filename/`.
 +
 +verbose (false)
 +: Enable verbose output.
 +
 +verboseLog (false)
 +: Enable verbose logging.
 +
 +watch (false)
 +: Watch filesystem for changes and recreate as needed.
 +
 +{{% note %}}
 +If you are developing your site on a \*nix machine, here is a handy shortcut for finding a configuration option from the command line:
 +```
 +cd ~/sites/yourhugosite
 +hugo config | grep emoji
 +```
 +
 +which shows output like
 +
 +```
 +enableemoji: true
 +```
 +{{% /note %}}
 +
 +## Configuration Lookup Order
 +
 +Similar to the template [lookup order][], Hugo has a default set of rules for searching for a configuration file in the root of your website's source directory as a default behavior:
 +
 +1. `./config.toml`
 +2. `./config.yaml`
 +3. `./config.json`
 +
 +In your `config` file, you can direct Hugo as to how you want your website rendered, control your website's menus, and arbitrarily define site-wide parameters specific to your project.
 +
 +
 +## Example Configuration
 +
 +The following is a typical example of a configuration file. The values nested under `params:` will populate the [`.Site.Params`][] variable for use in [templates][]:
 +
 +{{< code-toggle file="config">}}
 +baseURL: "https://yoursite.example.com/"
 +title: "My Hugo Site"
 +footnoteReturnLinkContents: "↩"
 +permalinks:
 +  post: /:year/:month/:title/
 +params:
 +  Subtitle: "Hugo is Absurdly Fast!"
 +  AuthorName: "Jon Doe"
 +  GitHubUser: "spf13"
 +  ListOfFoo:
 +    - "foo1"
 +    - "foo2"
 +  SidebarRecentLimit: 5
 +{{< /code-toggle >}}
 +
 +## Configure with Environment Variables
 +
 +In addition to the 3 config options already mentioned, configuration key-values can be defined through operating system environment variables.
 +
 +For example, the following command will effectively set a website's title on Unix-like systems:
 +
 +```
 +$ env HUGO_TITLE="Some Title" hugo
 +```
 +
 +This is really useful if you use a service such as Netlify to deploy your site. Look at the Hugo docs [Netlify configuration file](https://github.com/gohugoio/hugoDocs/blob/master/netlify.toml) for an example.
 +
 +{{% note "Setting Environment Variables" %}}
 +Names must be prefixed with `HUGO_` and the configuration key must be set in uppercase when setting operating system environment variables.
 +{{% /note %}}
 +
 +{{< todo >}}
 +Test and document setting params via JSON env var.
 +{{< /todo >}}
 +
 +## Ignore Files When Rendering
 +
 +The following statement inside `./config.toml` will cause Hugo to ignore files ending with `.foo` and `.boo` when rendering:
 +
 +```
 +ignoreFiles = [ "\\.foo$", "\\.boo$" ]
 +```
 +
 +The above is a list of regular expressions. Note that the backslash (`\`) character is escaped in this example to keep TOML happy.
 +
 +## Configure Front Matter
 +
 +### Configure Dates
 +
 +Dates are important in Hugo, and you can configure how Hugo assigns dates to your content pages. You do this by adding a `frontmatter` section to your `config.toml`.
 +
 +
 +The default configuration is:
 +
 +```toml
 +[frontmatter]
 +date = ["date","publishDate", "lastmod"]
 +lastmod = [":git" "lastmod", "date","publishDate"]
 +publishDate = ["publishDate", "date"]
 +expiryDate = ["expiryDate"]
 +```
 +
 +If you, as an example, have a non-standard date parameter in some of your content, you can override the setting for `date`:
 +
 + ```toml
 +[frontmatter]
 +date = [ "myDate", ":default"]
 +```
 +
 +The `:default` is a shortcut to the default settings. The above will set `.Date` to the date value in `myDate` if present, if not we will look in `date`,`publishDate`, `lastmod` and pick the first valid date.
 +
 +In the list to the right, values starting with ":" are date handlers with a special meaning (see below). The others are just names of date parameters (case insensitive) in your front matter configuration.  Also note that Hugo have some built-in aliases to the above: `lastmod` => `modified`, `publishDate` => `pubdate`, `published` and `expiryDate` => `unpublishdate`. With that, as an example, using `pubDate` as a date in front matter, will, by default, be assigned to `.PublishDate`.
 +
 +The special date handlers are:
 +
 +
 +`:fileModTime`
 +: Fetches the date from the content file's last modification timestamp.
 +
 +An example:
 +
 + ```toml
 +[frontmatter]
 +lastmod = ["lastmod" ,":fileModTime", ":default"]
 +```
 +
 +
 +The above will try first to extract the value for `.Lastmod` starting with the `lastmod` front matter parameter, then the content file's modification timestamp. The last, `:default` should not be needed here, but Hugo will finally look for a valid date in `:git`, `date` and then `publishDate`.
 +
 +
 +`:filename`
++: Fetches the date from the content file's filename. For example, `218-02-22-mypage.md` will extract the date `218-02-22`. Also, if `slug` is not set, `mypage` will be used as the value for `.Slug`.
 +
 +An example:
 +
 +```toml
 +[frontmatter]
 +date  = [":filename", ":default"]
 +```
 +
 +The above will try first to extract the value for `.Date` from the filename, then it will look in front matter parameters `date`, `publishDate` and lastly `lastmod`.
 +
 +
 +`:git`
 +: This is the Git author date for the last revision of this content file. This will only be set if `--enableGitInfo` is set or `enableGitInfo = true` is set in site config.
 +
 +## Configure Blackfriday
 +
 +[Blackfriday](https://github.com/russross/blackfriday) is Hugo's built-in Markdown rendering engine.
 +
 +Hugo typically configures Blackfriday with sane default values that should fit most use cases reasonably well.
 +
 +However, if you have specific needs with respect to Markdown, Hugo exposes some of its Blackfriday behavior options for you to alter. The following table lists these Hugo options, paired with the corresponding flags from Blackfriday's source code ( [html.go](https://github.com/russross/blackfriday/blob/master/html.go) and [markdown.go](https://github.com/russross/blackfriday/blob/master/markdown.go)).
 +
 +{{< readfile file="/content/readfiles/bfconfig.md" markdown="true" >}}
 +
 +{{% note %}}
 +1. Blackfriday flags are *case sensitive* as of Hugo v0.15.
 +2. Blackfriday flags must be grouped under the `blackfriday` key and can be set on both the site level *and* the page level. Any setting on a page will override its respective site setting.
 +{{% /note %}}
 +
 +{{< code-toggle file="config" >}}
 +[blackfriday]
 +  angledQuotes = true
 +  fractions = false
 +  plainIDAnchors = true
 +  extensions = ["hardLineBreak"]
 +{{< /code-toggle >}}
 +
 +## Configure Additional Output Formats
 +
 +Hugo v0.20 introduced the ability to render your content to multiple output formats (e.g., to JSON, AMP html, or CSV). See [Output Formats][] for information on how to add these values to your Hugo project's configuration file.
 +
 +## Configuration Format Specs
 +
 +* [TOML Spec][toml]
 +* [YAML Spec][yaml]
 +* [JSON Spec][json]
 +
 +[`.Site.Params`]: /variables/site/
 +[directory structure]: /getting-started/directory-structure
 +[json]: https://www.ecma-international.org/publications/files/ECMA-ST/ECMA-404.pdf "Specification for JSON, JavaScript Object Notation"
 +[lookup order]: /templates/lookup-order/
 +[Output Formats]: /templates/output-formats/
 +[templates]: /templates/
 +[toml]: https://github.com/toml-lang/toml
 +[yaml]: http://yaml.org/spec/
 
--- /dev/null
- title: "0.39"
- description: "0.39"
 +
 +---
 +date: 2018-04-16
++title: "The Nat King Cole Stabilizer Edition"
++description: "Hugo 0.39: Rewrite of the /commands package, `Resource.Content`, several new template funcs, and more …"
 +categories: ["Releases"]
 +---
 +
 +      
 +**Nat King Cole** was a fantastic American jazz pianist. When his bass player had visited the bar a little too often, he started with his percussive  piano playing to keep the tempo flowing. Oscar Peterson called it _"Nat's stabilizers"_. This release is the software equivalent of that. We have been doing frequent main releases this year, but looking back, the patch releases that followed them seemed unneeded. And looking at the regressions, most of them stem from the `commands` package, a package that before this release was filled with globals and high coupling. This package is now rewritten and accompanied with decent test coverage.
 +
 +But this release isn't all boring and technical: It includes several important bug fixes, several useful new template functions, and `Resource.Content` allows you to get any resource's content without having to fiddle with file paths and `readFile`.
 +
 +This release represents **61 contributions by 4 contributors** to the main Hugo code base. A shout-out to [@bep](https://github.com/bep) for the implementation and [@it-gro](https://github.com/it-gro) and [@RickCogley](https://github.com/RickCogley) for the help testing it.
 +
 +[@bep](https://github.com/bep) leads the Hugo development with a significant amount of contributions and his witty Norwegian humour, but also a big shoutout to [@anthonyfok](https://github.com/anthonyfok), [@thedodobird2](https://github.com/thedodobird2), and [@neurocline](https://github.com/neurocline) for their ongoing contributions.
 +And a big thanks to [@digitalcraftsman](https://github.com/digitalcraftsman) for his relentless work on keeping the themes site in pristine condition and to [@kaushalmodi](https://github.com/kaushalmodi) for his great work on the documentation site.
 +
 +Many have also been busy writing and fixing the documentation in [hugoDocs](https://github.com/gohugoio/hugoDocs), 
 +which has received **6 contributions by 5 contributors**. A special thanks to [@kaushalmodi](https://github.com/kaushalmodi), [@regisphilibert](https://github.com/regisphilibert), [@bep](https://github.com/bep), and [@tomanistor](https://github.com/tomanistor) for their work on the documentation site.
 +
 +Hugo now has:
 +
 +* 24911+ [stars](https://github.com/gohugoio/hugo/stargazers)
 +* 446+ [contributors](https://github.com/gohugoio/hugo/graphs/contributors)
 +* 218+ [themes](http://themes.gohugo.io/)
 +
 +## Notes
 +
 +* The `main.Execute` function now returns a `Response` object and the global `Hugo` variable is removed. This is only relevant for people building some kind of API around Hugo.
 +* Remove deprecated `File.Bytes` [94c8b29c](https://github.com/gohugoio/hugo/commit/94c8b29c39d0c485ee91d98c08fd615c28802496) [@bep](https://github.com/bep) 
 +
 +## Enhancements
 +
 +### Templates
 +
 +* Add `anchorize` template func [4dba6ce1](https://github.com/gohugoio/hugo/commit/4dba6ce15ae9b5208b1e2d68c96d7b1dce0a07ab) [@bep](https://github.com/bep) 
 +* Add `path.Join` [880ca19f](https://github.com/gohugoio/hugo/commit/880ca19f209e68e6a8daa6686b361515ecacc91e) [@bep](https://github.com/bep) 
 +* Add `path.Split` template func [01b72eb5](https://github.com/gohugoio/hugo/commit/01b72eb592d0e0aefc5f7ae42f9f6ff112883bb6) [@bep](https://github.com/bep) 
 +
 +### Other
 +
 +* Implement `Resource.Content` [0e7716a4](https://github.com/gohugoio/hugo/commit/0e7716a42450401c7998aa81ad2ed98c8ab109e8) [@bep](https://github.com/bep) [#4622](https://github.com/gohugoio/hugo/issues/4622)
 +* Make `Page.Content` a method that returns interface{} [417c5e2b](https://github.com/gohugoio/hugo/commit/417c5e2b67b97fa80a0b6f77d259966f03b95344) [@bep](https://github.com/bep) [#4622](https://github.com/gohugoio/hugo/issues/4622)
 +* Remove accidental and breaking space in baseURL flag [1b4e0c41](https://github.com/gohugoio/hugo/commit/1b4e0c4161fb631add62e77f494a7e62c3619020) [@bep](https://github.com/bep) [#4607](https://github.com/gohugoio/hugo/issues/4607)
 +* Properly handle CLI slice arguments [27a524b0](https://github.com/gohugoio/hugo/commit/27a524b0905ec73c1eef233f94700feb9f465011) [@bep](https://github.com/bep) [#4607](https://github.com/gohugoio/hugo/issues/4607)
 +* Correctly handle destination and i18n-warnings [bede93de](https://github.com/gohugoio/hugo/commit/bede93de005dcf934f3ec9be6388310ac6c57acd) [@bep](https://github.com/bep) [#4607](https://github.com/gohugoio/hugo/issues/4607)
 +* Allow "*/" inside commented out shortcodes [14c35c8a](https://github.com/gohugoio/hugo/commit/14c35c8a56c4dc9a1ee0053e9ff976be7715ba99) [@bep](https://github.com/bep) [#4608](https://github.com/gohugoio/hugo/issues/4608)
 +* Make commands.Execute return a Response object [96689a5c](https://github.com/gohugoio/hugo/commit/96689a5c319f720368491226f034d0ff9585217c) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Remove some TODOs [e7010c1b](https://github.com/gohugoio/hugo/commit/e7010c1b621d68ee53411a5ba8143d07b976d9fe) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Add basic server test [a7d00fc3](https://github.com/gohugoio/hugo/commit/a7d00fc39e87a5cac99b3a2380f5cc8c135d2b4b) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Remove the Hugo global [b110d0ae](https://github.com/gohugoio/hugo/commit/b110d0ae04e13fb45c739bcebb580709745082e6) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make the limit command work again [73825cfc](https://github.com/gohugoio/hugo/commit/73825cfc1c0b007830b24bb1947a565175b52d36) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Move the commands related logic to its own file [a8f7fbbb](https://github.com/gohugoio/hugo/commit/a8f7fbbb10aa78f3ebac008d29d9969bb197393c) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Add CLI tests [e8d6ca95](https://github.com/gohugoio/hugo/commit/e8d6ca9531d19e4e898c57d77d2fd627ea38ade0) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make the hugo command non-global [4d32f2fa](https://github.com/gohugoio/hugo/commit/4d32f2fa8969f368b088dc9bcedb45f2c986cb27) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Extract some common types into its own file [018602c4](https://github.com/gohugoio/hugo/commit/018602c46db8d729af2871bd5f4c1e7480420f09) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make the server command non-global [2f0d98a1](https://github.com/gohugoio/hugo/commit/2f0d98a19b021d03930003217b0519afaef3a391) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make the gen commands non-global [e0621d20](https://github.com/gohugoio/hugo/commit/e0621d207ce3278a82f8a60607e9cdd304149029) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make the list commands non-global [e26a8b24](https://github.com/gohugoio/hugo/commit/e26a8b242a6434117d089a0799238add7025dbf4) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make the import commands non-global [2a2c9838](https://github.com/gohugoio/hugo/commit/2a2c9838671b5401331d20f8c72e2b934fe34e8d) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make the config command non-global [15b1e269](https://github.com/gohugoio/hugo/commit/15b1e269ade91ddc6a74c552bc61b0c5e527d268) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make the new commands non-global [56a13080](https://github.com/gohugoio/hugo/commit/56a13080446283ed1cde6b69fc6f4fac85076c84) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make convert command non-global [4b780ca7](https://github.com/gohugoio/hugo/commit/4b780ca778ee7f25af808da38ede964a01698c70) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make more commands non-global [7bc5e89f](https://github.com/gohugoio/hugo/commit/7bc5e89fbaa5c613b8853ff7b69fae570bd0b56d) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Make benchmark non-global [fdf1d94e](https://github.com/gohugoio/hugo/commit/fdf1d94ebc7d1aa4855c62237f2edbd4bdade1a7) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Start of flag cleaning [1157fef8](https://github.com/gohugoio/hugo/commit/1157fef85908ea54883fe0dba6adc4861ba02162) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Use short date format in CLI docs [e614d8a5](https://github.com/gohugoio/hugo/commit/e614d8a57c2ff5eef9270d51fcc6518398d7ff88) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Update README.md [fca49d6c](https://github.com/gohugoio/hugo/commit/fca49d6c608d227049cb2f26895cfecc685f1c89) [@thedodobird2](https://github.com/thedodobird2) 
 +* Sync dependencies [0e8b3cbc](https://github.com/gohugoio/hugo/commit/0e8b3cbcd274e1f2e14be694c794a544f49efb56) [@bep](https://github.com/bep) 
 +* Bump Go versions [230f2b8c](https://github.com/gohugoio/hugo/commit/230f2b8c4fce03f14847de2b22402e64d4d69783) [@bep](https://github.com/bep) [#4545](https://github.com/gohugoio/hugo/issues/4545)
 +* Add bash completion [874159b5](https://github.com/gohugoio/hugo/commit/874159b5436bc9080aec71a9c26d35f8f62c9fd0) [@anthonyfok](https://github.com/anthonyfok) 
 +* Handle mass content etc. edits in server mode [730b66b6](https://github.com/gohugoio/hugo/commit/730b66b6520f263af16f555d1d7be51205a8e51d) [@bep](https://github.com/bep) [#4563](https://github.com/gohugoio/hugo/issues/4563)
 +
 +## Fixes
 +
 +* Fix `livereload` of bundled pages [f3775877](https://github.com/gohugoio/hugo/commit/f3775877c61c11ab7c8fd1fc3e15470bf5da4820) [@bep](https://github.com/bep) [#4607](https://github.com/gohugoio/hugo/issues/4607)
 +* Do not reset `.Page.Scratch` on rebuilds [61d52f14](https://github.com/gohugoio/hugo/commit/61d52f146297950e283ae086d8b1af61099d22a0) [@bep](https://github.com/bep) [#4627](https://github.com/gohugoio/hugo/issues/4627)
 +* Fix failing Travis server test [9c782d51](https://github.com/gohugoio/hugo/commit/9c782d5147bfea0dd85cf3374f598f0176f204eb) [@bep](https://github.com/bep) 
 +* Fix the config command [f396cffa](https://github.com/gohugoio/hugo/commit/f396cffa239e948075af2224208671956d8b4a84) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Fix some flag diff [24d5c219](https://github.com/gohugoio/hugo/commit/24d5c219424a9777bb1dd366b43e68e6f47e1adb) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Fix TestFixURL [1e233b1c](https://github.com/gohugoio/hugo/commit/1e233b1c4598fd8cbce7da8a67bf2c4918c6047e) [@bep](https://github.com/bep) [#4598](https://github.com/gohugoio/hugo/issues/4598)
 +* Disable shallow clone to fix TestPageWithLastmodFromGitInfo [094ec171](https://github.com/gohugoio/hugo/commit/094ec171420e659cdf962a19dd90105912ce9901) [@anthonyfok](https://github.com/anthonyfok) [#4584](https://github.com/gohugoio/hugo/issues/4584)
 +* Fix livereload for the home page bundle [f87239e4](https://github.com/gohugoio/hugo/commit/f87239e4cab958bf59ecfb1beb8cac439441a553) [@bep](https://github.com/bep) [#4576](https://github.com/gohugoio/hugo/issues/4576)
 +* Fix empty `BuildDate` in "hugo version" [294c0f80](https://github.com/gohugoio/hugo/commit/294c0f8001fe598278c1eb8015deb6b98e8de686) [@anthonyfok](https://github.com/anthonyfok) 
 +* Fix some livereload content regressions [a4deaeff](https://github.com/gohugoio/hugo/commit/a4deaeff0cfd70abfbefa6d40c0b86839a216f6d) [@bep](https://github.com/bep) [#4566](https://github.com/gohugoio/hugo/issues/4566)
 +* Fix two tests that are broken on Windows [26f34fd5](https://github.com/gohugoio/hugo/commit/26f34fd59da1ce1885d4f2909c5d9ef9c1726944) [@neurocline](https://github.com/neurocline) 
 
--- /dev/null
 +{
 +  "chroma": {
 +    "lexers": [
 +      {
 +        "Name": "ABNF",
 +        "Aliases": [
 +          "abnf"
 +        ]
 +      },
 +      {
 +        "Name": "ANTLR",
 +        "Aliases": [
 +          "antlr"
 +        ]
 +      },
 +      {
 +        "Name": "APL",
 +        "Aliases": [
 +          "apl"
 +        ]
 +      },
 +      {
 +        "Name": "ActionScript",
 +        "Aliases": [
 +          "actionscript",
 +          "as"
 +        ]
 +      },
 +      {
 +        "Name": "ActionScript 3",
 +        "Aliases": [
 +          "actionscript3",
 +          "as",
 +          "as3"
 +        ]
 +      },
 +      {
 +        "Name": "Ada",
 +        "Aliases": [
 +          "ada",
 +          "ada2005",
 +          "ada95",
 +          "adb",
 +          "ads"
 +        ]
 +      },
 +      {
 +        "Name": "Angular2",
 +        "Aliases": [
 +          "ng2"
 +        ]
 +      },
 +      {
 +        "Name": "ApacheConf",
 +        "Aliases": [
 +          "aconf",
 +          "apache",
 +          "apacheconf",
 +          "conf",
 +          "htaccess"
 +        ]
 +      },
 +      {
 +        "Name": "AppleScript",
 +        "Aliases": [
 +          "applescript"
 +        ]
 +      },
 +      {
 +        "Name": "Awk",
 +        "Aliases": [
 +          "awk",
 +          "gawk",
 +          "mawk",
 +          "nawk"
 +        ]
 +      },
 +      {
 +        "Name": "BNF",
 +        "Aliases": [
 +          "bnf"
 +        ]
 +      },
 +      {
 +        "Name": "Base Makefile",
 +        "Aliases": [
 +          "*",
 +          "bsdmake",
 +          "mak",
 +          "make",
 +          "makefile",
 +          "mf",
 +          "mk"
 +        ]
 +      },
 +      {
 +        "Name": "Bash",
 +        "Aliases": [
 +          "bash",
 +          "bash_*",
 +          "bashrc",
 +          "ebuild",
 +          "eclass",
 +          "exheres-0",
 +          "exlib",
 +          "ksh",
 +          "sh",
 +          "shell",
 +          "zsh",
 +          "zshrc"
 +        ]
 +      },
 +      {
 +        "Name": "Batchfile",
 +        "Aliases": [
 +          "bat",
 +          "batch",
 +          "cmd",
 +          "dosbatch",
 +          "winbatch"
 +        ]
 +      },
 +      {
 +        "Name": "BlitzBasic",
 +        "Aliases": [
 +          "b3d",
 +          "bb",
 +          "blitzbasic",
 +          "bplus",
 +          "decls"
 +        ]
 +      },
 +      {
 +        "Name": "Brainfuck",
 +        "Aliases": [
 +          "b",
 +          "bf",
 +          "brainfuck"
 +        ]
 +      },
 +      {
 +        "Name": "C",
 +        "Aliases": [
 +          "c",
 +          "h",
 +          "idc"
 +        ]
 +      },
 +      {
 +        "Name": "C#",
 +        "Aliases": [
 +          "c#",
 +          "cs",
 +          "csharp"
 +        ]
 +      },
 +      {
 +        "Name": "C++",
 +        "Aliases": [
 +          "C",
 +          "CPP",
 +          "H",
 +          "c++",
 +          "cc",
 +          "cp",
 +          "cpp",
 +          "cxx",
 +          "h++",
 +          "hh",
 +          "hpp",
 +          "hxx"
 +        ]
 +      },
 +      {
 +        "Name": "CFEngine3",
 +        "Aliases": [
 +          "cf",
 +          "cf3",
 +          "cfengine3"
 +        ]
 +      },
 +      {
 +        "Name": "CMake",
 +        "Aliases": [
 +          "cmake",
 +          "txt"
 +        ]
 +      },
 +      {
 +        "Name": "COBOL",
 +        "Aliases": [
 +          "COB",
 +          "CPY",
 +          "cob",
 +          "cobol",
 +          "cpy"
 +        ]
 +      },
 +      {
 +        "Name": "CSS",
 +        "Aliases": [
 +          "css"
 +        ]
 +      },
 +      {
 +        "Name": "Cap'n Proto",
 +        "Aliases": [
 +          "capnp"
 +        ]
 +      },
 +      {
 +        "Name": "Ceylon",
 +        "Aliases": [
 +          "ceylon"
 +        ]
 +      },
 +      {
 +        "Name": "ChaiScript",
 +        "Aliases": [
 +          "chai",
 +          "chaiscript"
 +        ]
 +      },
 +      {
 +        "Name": "Cheetah",
 +        "Aliases": [
 +          "cheetah",
 +          "spitfire",
 +          "spt",
 +          "tmpl"
 +        ]
 +      },
 +      {
 +        "Name": "Clojure",
 +        "Aliases": [
 +          "clj",
 +          "clojure"
 +        ]
 +      },
 +      {
 +        "Name": "CoffeeScript",
 +        "Aliases": [
 +          "coffee",
 +          "coffee-script",
 +          "coffeescript"
 +        ]
 +      },
 +      {
 +        "Name": "Common Lisp",
 +        "Aliases": [
 +          "cl",
 +          "common-lisp",
 +          "lisp"
 +        ]
 +      },
 +      {
 +        "Name": "Coq",
 +        "Aliases": [
 +          "coq",
 +          "v"
 +        ]
 +      },
 +      {
 +        "Name": "Crystal",
 +        "Aliases": [
 +          "cr",
 +          "crystal"
 +        ]
 +      },
 +      {
 +        "Name": "Cython",
 +        "Aliases": [
 +          "cython",
 +          "pxd",
 +          "pxi",
 +          "pyrex",
 +          "pyx"
 +        ]
 +      },
 +      {
 +        "Name": "DTD",
 +        "Aliases": [
 +          "dtd"
 +        ]
 +      },
 +      {
 +        "Name": "Dart",
 +        "Aliases": [
 +          "dart"
 +        ]
 +      },
 +      {
 +        "Name": "Diff",
 +        "Aliases": [
 +          "diff",
 +          "patch",
 +          "udiff"
 +        ]
 +      },
 +      {
 +        "Name": "Django/Jinja",
 +        "Aliases": [
 +          "django",
 +          "jinja"
 +        ]
 +      },
 +      {
 +        "Name": "Docker",
 +        "Aliases": [
 +          "docker",
 +          "dockerfile"
 +        ]
 +      },
 +      {
 +        "Name": "EBNF",
 +        "Aliases": [
 +          "ebnf"
 +        ]
 +      },
 +      {
 +        "Name": "Elixir",
 +        "Aliases": [
 +          "elixir",
 +          "ex",
 +          "exs"
 +        ]
 +      },
 +      {
 +        "Name": "Elm",
 +        "Aliases": [
 +          "elm"
 +        ]
 +      },
 +      {
 +        "Name": "EmacsLisp",
 +        "Aliases": [
 +          "el",
 +          "elisp",
 +          "emacs",
 +          "emacs-lisp"
 +        ]
 +      },
 +      {
 +        "Name": "Erlang",
 +        "Aliases": [
 +          "erl",
 +          "erlang",
 +          "es",
 +          "escript",
 +          "hrl"
 +        ]
 +      },
 +      {
 +        "Name": "FSharp",
 +        "Aliases": [
 +          "fs",
 +          "fsharp",
 +          "fsi"
 +        ]
 +      },
 +      {
 +        "Name": "Factor",
 +        "Aliases": [
 +          "factor"
 +        ]
 +      },
 +      {
 +        "Name": "Fish",
 +        "Aliases": [
 +          "fish",
 +          "fishshell",
 +          "load"
 +        ]
 +      },
 +      {
 +        "Name": "Forth",
 +        "Aliases": [
 +          "forth",
 +          "frt",
 +          "fs"
 +        ]
 +      },
 +      {
 +        "Name": "Fortran",
 +        "Aliases": [
 +          "F03",
 +          "F90",
 +          "f03",
 +          "f90",
 +          "fortran"
 +        ]
 +      },
 +      {
 +        "Name": "GAS",
 +        "Aliases": [
 +          "S",
 +          "asm",
 +          "gas",
 +          "s"
 +        ]
 +      },
 +      {
 +        "Name": "GDScript",
 +        "Aliases": [
 +          "gd",
 +          "gdscript"
 +        ]
 +      },
 +      {
 +        "Name": "GLSL",
 +        "Aliases": [
 +          "frag",
 +          "geo",
 +          "glsl",
 +          "vert"
 +        ]
 +      },
 +      {
 +        "Name": "Genshi",
 +        "Aliases": [
 +          "genshi",
 +          "kid",
 +          "xml+genshi",
 +          "xml+kid"
 +        ]
 +      },
 +      {
 +        "Name": "Genshi HTML",
 +        "Aliases": [
 +          "html+genshi",
 +          "html+kid"
 +        ]
 +      },
 +      {
 +        "Name": "Genshi Text",
 +        "Aliases": [
 +          "genshitext"
 +        ]
 +      },
 +      {
 +        "Name": "Gnuplot",
 +        "Aliases": [
 +          "gnuplot",
 +          "plot",
 +          "plt"
 +        ]
 +      },
 +      {
 +        "Name": "Go",
 +        "Aliases": [
 +          "go",
 +          "golang"
 +        ]
 +      },
 +      {
 +        "Name": "Go HTML Template",
 +        "Aliases": [
 +          "go-html-template"
 +        ]
 +      },
 +      {
 +        "Name": "Go Text Template",
 +        "Aliases": [
 +          "go-text-template"
 +        ]
 +      },
 +      {
 +        "Name": "Groovy",
 +        "Aliases": [
 +          "gradle",
 +          "groovy"
 +        ]
 +      },
 +      {
 +        "Name": "HTML",
 +        "Aliases": [
 +          "htm",
 +          "html",
 +          "xhtml",
 +          "xslt"
 +        ]
 +      },
 +      {
 +        "Name": "HTTP",
 +        "Aliases": [
 +          "http"
 +        ]
 +      },
 +      {
 +        "Name": "Handlebars",
 +        "Aliases": [
 +          "handlebars"
 +        ]
 +      },
 +      {
 +        "Name": "Haskell",
 +        "Aliases": [
 +          "haskell",
 +          "hs"
 +        ]
 +      },
 +      {
 +        "Name": "Haxe",
 +        "Aliases": [
 +          "haxe",
 +          "hx",
 +          "hxsl"
 +        ]
 +      },
 +      {
 +        "Name": "Hexdump",
 +        "Aliases": [
 +          "hexdump"
 +        ]
 +      },
 +      {
 +        "Name": "Hy",
 +        "Aliases": [
 +          "hy",
 +          "hylang"
 +        ]
 +      },
 +      {
 +        "Name": "INI",
 +        "Aliases": [
 +          "cfg",
 +          "dosini",
 +          "inf",
 +          "ini"
 +        ]
 +      },
 +      {
 +        "Name": "Idris",
 +        "Aliases": [
 +          "idr",
 +          "idris"
 +        ]
 +      },
 +      {
 +        "Name": "Io",
 +        "Aliases": [
 +          "io"
 +        ]
 +      },
 +      {
 +        "Name": "JSON",
 +        "Aliases": [
 +          "json"
 +        ]
 +      },
 +      {
 +        "Name": "JSX",
 +        "Aliases": [
 +          "jsx",
 +          "react"
 +        ]
 +      },
 +      {
 +        "Name": "Java",
 +        "Aliases": [
 +          "java"
 +        ]
 +      },
 +      {
 +        "Name": "JavaScript",
 +        "Aliases": [
 +          "javascript",
 +          "js",
 +          "jsm"
 +        ]
 +      },
 +      {
 +        "Name": "Julia",
 +        "Aliases": [
 +          "jl",
 +          "julia"
 +        ]
 +      },
 +      {
 +        "Name": "Kotlin",
 +        "Aliases": [
 +          "kotlin",
 +          "kt"
 +        ]
 +      },
 +      {
 +        "Name": "LLVM",
 +        "Aliases": [
 +          "ll",
 +          "llvm"
 +        ]
 +      },
 +      {
 +        "Name": "Lighttpd configuration file",
 +        "Aliases": [
 +          "lighttpd",
 +          "lighty"
 +        ]
 +      },
 +      {
 +        "Name": "Lua",
 +        "Aliases": [
 +          "lua",
 +          "wlua"
 +        ]
 +      },
 +      {
 +        "Name": "Mako",
 +        "Aliases": [
 +          "mako",
 +          "mao"
 +        ]
 +      },
 +      {
 +        "Name": "Mason",
 +        "Aliases": [
 +          "m",
 +          "mason",
 +          "mc",
 +          "mhtml",
 +          "mi"
 +        ]
 +      },
 +      {
 +        "Name": "Mathematica",
 +        "Aliases": [
 +          "cdf",
 +          "ma",
 +          "mathematica",
 +          "mma",
 +          "nb",
 +          "nbp"
 +        ]
 +      },
 +      {
 +        "Name": "MiniZinc",
 +        "Aliases": [
 +          "MZN",
 +          "dzn",
 +          "fzn",
 +          "minizinc",
 +          "mzn"
 +        ]
 +      },
 +      {
 +        "Name": "Modula-2",
 +        "Aliases": [
 +          "def",
 +          "m2",
 +          "mod",
 +          "modula2"
 +        ]
 +      },
 +      {
 +        "Name": "MorrowindScript",
 +        "Aliases": [
 +          "morrowind",
 +          "mwscript"
 +        ]
 +      },
 +      {
 +        "Name": "MySQL",
 +        "Aliases": [
 +          "mysql",
 +          "sql"
 +        ]
 +      },
 +      {
 +        "Name": "Myghty",
 +        "Aliases": [
 +          "myghty",
 +          "myt"
 +        ]
 +      },
 +      {
 +        "Name": "NASM",
 +        "Aliases": [
 +          "ASM",
 +          "asm",
 +          "nasm"
 +        ]
 +      },
 +      {
 +        "Name": "Newspeak",
 +        "Aliases": [
 +          "newspeak",
 +          "ns2"
 +        ]
 +      },
 +      {
 +        "Name": "Nginx configuration file",
 +        "Aliases": [
 +          "conf",
 +          "nginx"
 +        ]
 +      },
 +      {
 +        "Name": "Nim",
 +        "Aliases": [
 +          "nim",
 +          "nimrod"
 +        ]
 +      },
 +      {
 +        "Name": "Nix",
 +        "Aliases": [
 +          "nix",
 +          "nixos"
 +        ]
 +      },
 +      {
 +        "Name": "OCaml",
 +        "Aliases": [
 +          "ml",
 +          "mli",
 +          "mll",
 +          "mly",
 +          "ocaml"
 +        ]
 +      },
 +      {
 +        "Name": "Objective-C",
 +        "Aliases": [
 +          "h",
 +          "m",
 +          "obj-c",
 +          "objc",
 +          "objective-c",
 +          "objectivec"
 +        ]
 +      },
 +      {
 +        "Name": "Octave",
 +        "Aliases": [
 +          "m",
 +          "octave"
 +        ]
 +      },
 +      {
 +        "Name": "PHP",
 +        "Aliases": [
 +          "inc",
 +          "php",
 +          "php3",
 +          "php4",
 +          "php5",
 +          "php[345]"
 +        ]
 +      },
 +      {
 +        "Name": "PL/pgSQL",
 +        "Aliases": [
 +          "plpgsql"
 +        ]
 +      },
 +      {
 +        "Name": "POVRay",
 +        "Aliases": [
 +          "inc",
 +          "pov"
 +        ]
 +      },
 +      {
 +        "Name": "PacmanConf",
 +        "Aliases": [
 +          "conf",
 +          "pacmanconf"
 +        ]
 +      },
 +      {
 +        "Name": "Perl",
 +        "Aliases": [
 +          "perl",
 +          "pl",
 +          "pm",
 +          "t"
 +        ]
 +      },
 +      {
 +        "Name": "Pig",
 +        "Aliases": [
 +          "pig"
 +        ]
 +      },
 +      {
 +        "Name": "PkgConfig",
 +        "Aliases": [
 +          "pc",
 +          "pkgconfig"
 +        ]
 +      },
 +      {
 +        "Name": "PostScript",
 +        "Aliases": [
 +          "eps",
 +          "postscr",
 +          "postscript",
 +          "ps"
 +        ]
 +      },
 +      {
 +        "Name": "PostgreSQL SQL dialect",
 +        "Aliases": [
 +          "postgres",
 +          "postgresql"
 +        ]
 +      },
 +      {
 +        "Name": "PowerShell",
 +        "Aliases": [
 +          "posh",
 +          "powershell",
 +          "ps1",
 +          "psm1"
 +        ]
 +      },
 +      {
 +        "Name": "Prolog",
 +        "Aliases": [
 +          "ecl",
 +          "pl",
 +          "pro",
 +          "prolog"
 +        ]
 +      },
 +      {
 +        "Name": "Protocol Buffer",
 +        "Aliases": [
 +          "proto",
 +          "protobuf"
 +        ]
 +      },
 +      {
 +        "Name": "Puppet",
 +        "Aliases": [
 +          "pp",
 +          "puppet"
 +        ]
 +      },
 +      {
 +        "Name": "Python",
 +        "Aliases": [
 +          "py",
 +          "python",
 +          "pyw",
 +          "sage",
 +          "sc",
 +          "tac"
 +        ]
 +      },
 +      {
 +        "Name": "Python 3",
 +        "Aliases": [
 +          "py3",
 +          "python3"
 +        ]
 +      },
 +      {
 +        "Name": "QBasic",
 +        "Aliases": [
 +          "BAS",
 +          "bas",
 +          "basic",
 +          "qbasic"
 +        ]
 +      },
 +      {
 +        "Name": "R",
 +        "Aliases": [
 +          "R",
 +          "Renviron",
 +          "Rhistory",
 +          "Rprofile",
 +          "S",
 +          "r",
 +          "s",
 +          "splus"
 +        ]
 +      },
 +      {
 +        "Name": "Racket",
 +        "Aliases": [
 +          "racket",
 +          "rkt",
 +          "rktd",
 +          "rktl"
 +        ]
 +      },
 +      {
 +        "Name": "Ragel",
 +        "Aliases": [
 +          "ragel"
 +        ]
 +      },
 +      {
 +        "Name": "Rexx",
 +        "Aliases": [
 +          "arexx",
 +          "rex",
 +          "rexx",
 +          "rx"
 +        ]
 +      },
 +      {
 +        "Name": "Ruby",
 +        "Aliases": [
 +          "duby",
 +          "gemspec",
 +          "rake",
 +          "rb",
 +          "rbw",
 +          "rbx",
 +          "ruby"
 +        ]
 +      },
 +      {
 +        "Name": "Rust",
 +        "Aliases": [
 +          "in",
 +          "rs",
 +          "rust"
 +        ]
 +      },
 +      {
 +        "Name": "SCSS",
 +        "Aliases": [
 +          "scss"
 +        ]
 +      },
 +      {
 +        "Name": "SPARQL",
 +        "Aliases": [
 +          "rq",
 +          "sparql"
 +        ]
 +      },
 +      {
 +        "Name": "SQL",
 +        "Aliases": [
 +          "sql"
 +        ]
 +      },
 +      {
 +        "Name": "Sass",
 +        "Aliases": [
 +          "sass"
 +        ]
 +      },
 +      {
 +        "Name": "Scala",
 +        "Aliases": [
 +          "scala"
 +        ]
 +      },
 +      {
 +        "Name": "Scheme",
 +        "Aliases": [
 +          "scheme",
 +          "scm",
 +          "ss"
 +        ]
 +      },
 +      {
 +        "Name": "Scilab",
 +        "Aliases": [
 +          "sce",
 +          "sci",
 +          "scilab",
 +          "tst"
 +        ]
 +      },
 +      {
 +        "Name": "Smalltalk",
 +        "Aliases": [
 +          "smalltalk",
 +          "squeak",
 +          "st"
 +        ]
 +      },
 +      {
 +        "Name": "Smarty",
 +        "Aliases": [
 +          "smarty",
 +          "tpl"
 +        ]
 +      },
 +      {
 +        "Name": "Snobol",
 +        "Aliases": [
 +          "snobol"
 +        ]
 +      },
 +      {
 +        "Name": "Solidity",
 +        "Aliases": [
 +          "sol",
 +          "solidity"
 +        ]
 +      },
 +      {
 +        "Name": "SquidConf",
 +        "Aliases": [
 +          "conf",
 +          "squid",
 +          "squid.conf",
 +          "squidconf"
 +        ]
 +      },
 +      {
 +        "Name": "Swift",
 +        "Aliases": [
 +          "swift"
 +        ]
 +      },
 +      {
 +        "Name": "TASM",
 +        "Aliases": [
 +          "ASM",
 +          "asm",
 +          "tasm"
 +        ]
 +      },
 +      {
 +        "Name": "TOML",
 +        "Aliases": [
 +          "toml"
 +        ]
 +      },
 +      {
 +        "Name": "Tcl",
 +        "Aliases": [
 +          "rvt",
 +          "tcl"
 +        ]
 +      },
 +      {
 +        "Name": "Tcsh",
 +        "Aliases": [
 +          "csh",
 +          "tcsh"
 +        ]
 +      },
 +      {
 +        "Name": "TeX",
 +        "Aliases": [
 +          "aux",
 +          "latex",
 +          "tex",
 +          "toc"
 +        ]
 +      },
 +      {
 +        "Name": "Termcap",
 +        "Aliases": [
 +          "src",
 +          "termcap"
 +        ]
 +      },
 +      {
 +        "Name": "Terminfo",
 +        "Aliases": [
 +          "src",
 +          "terminfo"
 +        ]
 +      },
 +      {
 +        "Name": "Terraform",
 +        "Aliases": [
 +          "terraform",
 +          "tf"
 +        ]
 +      },
 +      {
 +        "Name": "Thrift",
 +        "Aliases": [
 +          "thrift"
 +        ]
 +      },
 +      {
 +        "Name": "Transact-SQL",
 +        "Aliases": [
 +          "t-sql",
 +          "tsql"
 +        ]
 +      },
 +      {
 +        "Name": "Turtle",
 +        "Aliases": [
 +          "ttl",
 +          "turtle"
 +        ]
 +      },
 +      {
 +        "Name": "Twig",
 +        "Aliases": [
 +          "twig"
 +        ]
 +      },
 +      {
 +        "Name": "TypeScript",
 +        "Aliases": [
 +          "ts",
 +          "tsx",
 +          "typescript"
 +        ]
 +      },
 +      {
 +        "Name": "TypoScript",
 +        "Aliases": [
 +          "ts",
 +          "txt",
 +          "typoscript"
 +        ]
 +      },
 +      {
 +        "Name": "TypoScriptCssData",
 +        "Aliases": [
 +          "typoscriptcssdata"
 +        ]
 +      },
 +      {
 +        "Name": "TypoScriptHtmlData",
 +        "Aliases": [
 +          "typoscripthtmldata"
 +        ]
 +      },
 +      {
 +        "Name": "VHDL",
 +        "Aliases": [
 +          "vhd",
 +          "vhdl"
 +        ]
 +      },
 +      {
 +        "Name": "VimL",
 +        "Aliases": [
 +          "exrc",
 +          "gvimrc",
 +          "vim",
 +          "vimrc"
 +        ]
 +      },
 +      {
 +        "Name": "WDTE",
 +        "Aliases": [
 +          "wdte"
 +        ]
 +      },
 +      {
 +        "Name": "XML",
 +        "Aliases": [
 +          "rss",
 +          "svg",
 +          "wsdl",
 +          "wsf",
 +          "xml",
 +          "xsd",
 +          "xsl",
 +          "xslt"
 +        ]
 +      },
 +      {
 +        "Name": "Xorg",
 +        "Aliases": [
 +          "conf",
 +          "xorg.conf"
 +        ]
 +      },
 +      {
 +        "Name": "YAML",
 +        "Aliases": [
 +          "yaml",
 +          "yml"
 +        ]
 +      },
 +      {
 +        "Name": "cfstatement",
 +        "Aliases": [
 +          "cfs"
 +        ]
 +      },
 +      {
 +        "Name": "markdown",
 +        "Aliases": [
 +          "markdown",
 +          "md",
 +          "mkd"
 +        ]
 +      },
 +      {
 +        "Name": "reStructuredText",
 +        "Aliases": [
 +          "rest",
 +          "restructuredtext",
 +          "rst"
 +        ]
 +      },
 +      {
 +        "Name": "reg",
 +        "Aliases": [
 +          "reg",
 +          "registry"
 +        ]
 +      },
 +      {
 +        "Name": "systemverilog",
 +        "Aliases": [
 +          "sv",
 +          "svh",
 +          "systemverilog"
 +        ]
 +      },
 +      {
 +        "Name": "verilog",
 +        "Aliases": [
 +          "v",
 +          "verilog"
 +        ]
 +      }
 +    ]
 +  },
 +  "media": {
 +    "types": [
 +      {
 +        "type": "application/javascript",
 +        "string": "application/javascript+js",
 +        "mainType": "application",
 +        "subType": "javascript",
 +        "suffix": "js",
 +        "delimiter": "."
 +      },
 +      {
 +        "type": "application/json",
 +        "string": "application/json+json",
 +        "mainType": "application",
 +        "subType": "json",
 +        "suffix": "json",
 +        "delimiter": "."
 +      },
 +      {
 +        "type": "application/rss",
 +        "string": "application/rss+xml",
 +        "mainType": "application",
 +        "subType": "rss",
 +        "suffix": "xml",
 +        "delimiter": "."
 +      },
 +      {
 +        "type": "application/xml",
 +        "string": "application/xml+xml",
 +        "mainType": "application",
 +        "subType": "xml",
 +        "suffix": "xml",
 +        "delimiter": "."
 +      },
 +      {
 +        "type": "text/calendar",
 +        "string": "text/calendar+ics",
 +        "mainType": "text",
 +        "subType": "calendar",
 +        "suffix": "ics",
 +        "delimiter": "."
 +      },
 +      {
 +        "type": "text/css",
 +        "string": "text/css+css",
 +        "mainType": "text",
 +        "subType": "css",
 +        "suffix": "css",
 +        "delimiter": "."
 +      },
 +      {
 +        "type": "text/csv",
 +        "string": "text/csv+csv",
 +        "mainType": "text",
 +        "subType": "csv",
 +        "suffix": "csv",
 +        "delimiter": "."
 +      },
 +      {
 +        "type": "text/html",
 +        "string": "text/html+html",
 +        "mainType": "text",
 +        "subType": "html",
 +        "suffix": "html",
 +        "delimiter": "."
 +      },
 +      {
 +        "type": "text/plain",
 +        "string": "text/plain+txt",
 +        "mainType": "text",
 +        "subType": "plain",
 +        "suffix": "txt",
 +        "delimiter": "."
 +      }
 +    ]
 +  },
 +  "output": {
 +    "formats": [
 +      {
 +        "MediaType": "text/html+html",
 +        "name": "AMP",
 +        "mediaType": {
 +          "type": "text/html",
 +          "string": "text/html+html",
 +          "mainType": "text",
 +          "subType": "html",
 +          "suffix": "html",
 +          "delimiter": "."
 +        },
 +        "path": "amp",
 +        "baseName": "index",
 +        "rel": "amphtml",
 +        "protocol": "",
 +        "isPlainText": false,
 +        "isHTML": true,
 +        "noUgly": false,
 +        "notAlternative": false
 +      },
 +      {
 +        "MediaType": "text/css+css",
 +        "name": "CSS",
 +        "mediaType": {
 +          "type": "text/css",
 +          "string": "text/css+css",
 +          "mainType": "text",
 +          "subType": "css",
 +          "suffix": "css",
 +          "delimiter": "."
 +        },
 +        "path": "",
 +        "baseName": "styles",
 +        "rel": "stylesheet",
 +        "protocol": "",
 +        "isPlainText": true,
 +        "isHTML": false,
 +        "noUgly": false,
 +        "notAlternative": true
 +      },
 +      {
 +        "MediaType": "text/csv+csv",
 +        "name": "CSV",
 +        "mediaType": {
 +          "type": "text/csv",
 +          "string": "text/csv+csv",
 +          "mainType": "text",
 +          "subType": "csv",
 +          "suffix": "csv",
 +          "delimiter": "."
 +        },
 +        "path": "",
 +        "baseName": "index",
 +        "rel": "alternate",
 +        "protocol": "",
 +        "isPlainText": true,
 +        "isHTML": false,
 +        "noUgly": false,
 +        "notAlternative": false
 +      },
 +      {
 +        "MediaType": "text/calendar+ics",
 +        "name": "Calendar",
 +        "mediaType": {
 +          "type": "text/calendar",
 +          "string": "text/calendar+ics",
 +          "mainType": "text",
 +          "subType": "calendar",
 +          "suffix": "ics",
 +          "delimiter": "."
 +        },
 +        "path": "",
 +        "baseName": "index",
 +        "rel": "alternate",
 +        "protocol": "webcal://",
 +        "isPlainText": true,
 +        "isHTML": false,
 +        "noUgly": false,
 +        "notAlternative": false
 +      },
 +      {
 +        "MediaType": "text/html+html",
 +        "name": "HTML",
 +        "mediaType": {
 +          "type": "text/html",
 +          "string": "text/html+html",
 +          "mainType": "text",
 +          "subType": "html",
 +          "suffix": "html",
 +          "delimiter": "."
 +        },
 +        "path": "",
 +        "baseName": "index",
 +        "rel": "canonical",
 +        "protocol": "",
 +        "isPlainText": false,
 +        "isHTML": true,
 +        "noUgly": false,
 +        "notAlternative": false
 +      },
 +      {
 +        "MediaType": "application/json+json",
 +        "name": "JSON",
 +        "mediaType": {
 +          "type": "application/json",
 +          "string": "application/json+json",
 +          "mainType": "application",
 +          "subType": "json",
 +          "suffix": "json",
 +          "delimiter": "."
 +        },
 +        "path": "",
 +        "baseName": "index",
 +        "rel": "alternate",
 +        "protocol": "",
 +        "isPlainText": true,
 +        "isHTML": false,
 +        "noUgly": false,
 +        "notAlternative": false
 +      },
 +      {
 +        "MediaType": "text/plain+txt",
 +        "name": "ROBOTS",
 +        "mediaType": {
 +          "type": "text/plain",
 +          "string": "text/plain+txt",
 +          "mainType": "text",
 +          "subType": "plain",
 +          "suffix": "txt",
 +          "delimiter": "."
 +        },
 +        "path": "",
 +        "baseName": "robots",
 +        "rel": "alternate",
 +        "protocol": "",
 +        "isPlainText": true,
 +        "isHTML": false,
 +        "noUgly": false,
 +        "notAlternative": false
 +      },
 +      {
 +        "MediaType": "application/rss+xml",
 +        "name": "RSS",
 +        "mediaType": {
 +          "type": "application/rss",
 +          "string": "application/rss+xml",
 +          "mainType": "application",
 +          "subType": "rss",
 +          "suffix": "xml",
 +          "delimiter": "."
 +        },
 +        "path": "",
 +        "baseName": "index",
 +        "rel": "alternate",
 +        "protocol": "",
 +        "isPlainText": false,
 +        "isHTML": false,
 +        "noUgly": true,
 +        "notAlternative": false
 +      },
 +      {
 +        "MediaType": "application/xml+xml",
 +        "name": "Sitemap",
 +        "mediaType": {
 +          "type": "application/xml",
 +          "string": "application/xml+xml",
 +          "mainType": "application",
 +          "subType": "xml",
 +          "suffix": "xml",
 +          "delimiter": "."
 +        },
 +        "path": "",
 +        "baseName": "sitemap",
 +        "rel": "sitemap",
 +        "protocol": "",
 +        "isPlainText": false,
 +        "isHTML": false,
 +        "noUgly": true,
 +        "notAlternative": false
 +      }
 +    ],
 +    "layouts": [
 +      {
 +        "Example": "Single page in \"posts\" section",
 +        "Kind": "page",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/posts/single.html.html",
 +          "layouts/posts/single.html",
 +          "layouts/_default/single.html.html",
 +          "layouts/_default/single.html"
 +        ]
 +      },
 +      {
 +        "Example": "Single page in \"posts\" section with layout set",
 +        "Kind": "page",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/posts/demolayout.html.html",
 +          "layouts/posts/single.html.html",
 +          "layouts/posts/demolayout.html",
 +          "layouts/posts/single.html",
 +          "layouts/_default/demolayout.html.html",
 +          "layouts/_default/single.html.html",
 +          "layouts/_default/demolayout.html",
 +          "layouts/_default/single.html"
 +        ]
 +      },
 +      {
 +        "Example": "Single page in \"posts\" section with theme",
 +        "Kind": "page",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/posts/single.html.html",
 +          "demoTheme/layouts/posts/single.html.html",
 +          "layouts/posts/single.html",
 +          "demoTheme/layouts/posts/single.html",
 +          "layouts/_default/single.html.html",
 +          "demoTheme/layouts/_default/single.html.html",
 +          "layouts/_default/single.html",
 +          "demoTheme/layouts/_default/single.html"
 +        ]
 +      },
 +      {
 +        "Example": "AMP single page",
 +        "Kind": "page",
 +        "OutputFormat": "AMP",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/posts/single.amp.html",
 +          "layouts/posts/single.html",
 +          "layouts/_default/single.amp.html",
 +          "layouts/_default/single.html"
 +        ]
 +      },
 +      {
 +        "Example": "AMP single page, French language",
 +        "Kind": "page",
 +        "OutputFormat": "AMP",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/posts/single.fr.amp.html",
 +          "layouts/posts/single.amp.html",
 +          "layouts/posts/single.fr.html",
 +          "layouts/posts/single.html",
 +          "layouts/_default/single.fr.amp.html",
 +          "layouts/_default/single.amp.html",
 +          "layouts/_default/single.fr.html",
 +          "layouts/_default/single.html"
 +        ]
 +      },
 +      {
 +        "Example": "Home page",
 +        "Kind": "home",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/index.html.html",
 +          "layouts/home.html.html",
 +          "layouts/list.html.html",
 +          "layouts/index.html",
 +          "layouts/home.html",
 +          "layouts/list.html",
 +          "layouts/_default/index.html.html",
 +          "layouts/_default/home.html.html",
 +          "layouts/_default/list.html.html",
 +          "layouts/_default/index.html",
 +          "layouts/_default/home.html",
 +          "layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "Home page with type set",
 +        "Kind": "home",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/demotype/index.html.html",
 +          "layouts/demotype/home.html.html",
 +          "layouts/demotype/list.html.html",
 +          "layouts/demotype/index.html",
 +          "layouts/demotype/home.html",
 +          "layouts/demotype/list.html",
 +          "layouts/index.html.html",
 +          "layouts/home.html.html",
 +          "layouts/list.html.html",
 +          "layouts/index.html",
 +          "layouts/home.html",
 +          "layouts/list.html",
 +          "layouts/_default/index.html.html",
 +          "layouts/_default/home.html.html",
 +          "layouts/_default/list.html.html",
 +          "layouts/_default/index.html",
 +          "layouts/_default/home.html",
 +          "layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "Home page with layout set",
 +        "Kind": "home",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/demolayout.html.html",
 +          "layouts/index.html.html",
 +          "layouts/home.html.html",
 +          "layouts/list.html.html",
 +          "layouts/demolayout.html",
 +          "layouts/index.html",
 +          "layouts/home.html",
 +          "layouts/list.html",
 +          "layouts/_default/demolayout.html.html",
 +          "layouts/_default/index.html.html",
 +          "layouts/_default/home.html.html",
 +          "layouts/_default/list.html.html",
 +          "layouts/_default/demolayout.html",
 +          "layouts/_default/index.html",
 +          "layouts/_default/home.html",
 +          "layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "Home page with theme",
 +        "Kind": "home",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/index.html.html",
 +          "demoTheme/layouts/index.html.html",
 +          "layouts/home.html.html",
 +          "demoTheme/layouts/home.html.html",
 +          "layouts/list.html.html",
 +          "demoTheme/layouts/list.html.html",
 +          "layouts/index.html",
 +          "demoTheme/layouts/index.html",
 +          "layouts/home.html",
 +          "demoTheme/layouts/home.html",
 +          "layouts/list.html",
 +          "demoTheme/layouts/list.html",
 +          "layouts/_default/index.html.html",
 +          "demoTheme/layouts/_default/index.html.html",
 +          "layouts/_default/home.html.html",
 +          "demoTheme/layouts/_default/home.html.html",
 +          "layouts/_default/list.html.html",
 +          "demoTheme/layouts/_default/list.html.html",
 +          "layouts/_default/index.html",
 +          "demoTheme/layouts/_default/index.html",
 +          "layouts/_default/home.html",
 +          "demoTheme/layouts/_default/home.html",
 +          "layouts/_default/list.html",
 +          "demoTheme/layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "AMP home, French language\"",
 +        "Kind": "home",
 +        "OutputFormat": "AMP",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/index.fr.amp.html",
 +          "layouts/home.fr.amp.html",
 +          "layouts/list.fr.amp.html",
 +          "layouts/index.amp.html",
 +          "layouts/home.amp.html",
 +          "layouts/list.amp.html",
 +          "layouts/index.fr.html",
 +          "layouts/home.fr.html",
 +          "layouts/list.fr.html",
 +          "layouts/index.html",
 +          "layouts/home.html",
 +          "layouts/list.html",
 +          "layouts/_default/index.fr.amp.html",
 +          "layouts/_default/home.fr.amp.html",
 +          "layouts/_default/list.fr.amp.html",
 +          "layouts/_default/index.amp.html",
 +          "layouts/_default/home.amp.html",
 +          "layouts/_default/list.amp.html",
 +          "layouts/_default/index.fr.html",
 +          "layouts/_default/home.fr.html",
 +          "layouts/_default/list.fr.html",
 +          "layouts/_default/index.html",
 +          "layouts/_default/home.html",
 +          "layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "JSON home",
 +        "Kind": "home",
 +        "OutputFormat": "JSON",
 +        "Suffix": "json",
 +        "Template Lookup Order": [
 +          "layouts/index.json.json",
 +          "layouts/home.json.json",
 +          "layouts/list.json.json",
 +          "layouts/index.json",
 +          "layouts/home.json",
 +          "layouts/list.json",
 +          "layouts/_default/index.json.json",
 +          "layouts/_default/home.json.json",
 +          "layouts/_default/list.json.json",
 +          "layouts/_default/index.json",
 +          "layouts/_default/home.json",
 +          "layouts/_default/list.json"
 +        ]
 +      },
 +      {
 +        "Example": "RSS home with theme",
 +        "Kind": "home",
 +        "OutputFormat": "RSS",
 +        "Suffix": "xml",
 +        "Template Lookup Order": [
 +          "layouts/index.rss.xml",
 +          "demoTheme/layouts/index.rss.xml",
 +          "layouts/home.rss.xml",
 +          "demoTheme/layouts/home.rss.xml",
 +          "layouts/rss.xml",
 +          "demoTheme/layouts/rss.xml",
 +          "layouts/list.rss.xml",
 +          "demoTheme/layouts/list.rss.xml",
 +          "layouts/index.xml",
 +          "demoTheme/layouts/index.xml",
 +          "layouts/home.xml",
 +          "demoTheme/layouts/home.xml",
 +          "layouts/list.xml",
 +          "demoTheme/layouts/list.xml",
 +          "layouts/_default/index.rss.xml",
 +          "demoTheme/layouts/_default/index.rss.xml",
 +          "layouts/_default/home.rss.xml",
 +          "demoTheme/layouts/_default/home.rss.xml",
 +          "layouts/_default/rss.xml",
 +          "demoTheme/layouts/_default/rss.xml",
 +          "layouts/_default/list.rss.xml",
 +          "demoTheme/layouts/_default/list.rss.xml",
 +          "layouts/_default/index.xml",
 +          "demoTheme/layouts/_default/index.xml",
 +          "layouts/_default/home.xml",
 +          "demoTheme/layouts/_default/home.xml",
 +          "layouts/_default/list.xml",
 +          "demoTheme/layouts/_default/list.xml",
 +          "layouts/_internal/_default/rss.xml"
 +        ]
 +      },
 +      {
 +        "Example": "RSS section posts",
 +        "Kind": "section",
 +        "OutputFormat": "RSS",
 +        "Suffix": "xml",
 +        "Template Lookup Order": [
 +          "layouts/posts/section.rss.xml",
 +          "layouts/posts/rss.xml",
 +          "layouts/posts/list.rss.xml",
 +          "layouts/posts/section.xml",
 +          "layouts/posts/list.xml",
 +          "layouts/section/section.rss.xml",
 +          "layouts/section/rss.xml",
 +          "layouts/section/list.rss.xml",
 +          "layouts/section/section.xml",
 +          "layouts/section/list.xml",
 +          "layouts/_default/section.rss.xml",
 +          "layouts/_default/rss.xml",
 +          "layouts/_default/list.rss.xml",
 +          "layouts/_default/section.xml",
 +          "layouts/_default/list.xml",
 +          "layouts/_internal/_default/rss.xml"
 +        ]
 +      },
 +      {
 +        "Example": "Taxonomy list in categories",
 +        "Kind": "taxonomy",
 +        "OutputFormat": "RSS",
 +        "Suffix": "xml",
 +        "Template Lookup Order": [
 +          "layouts/categories/category.rss.xml",
 +          "layouts/categories/taxonomy.rss.xml",
 +          "layouts/categories/rss.xml",
 +          "layouts/categories/list.rss.xml",
 +          "layouts/categories/category.xml",
 +          "layouts/categories/taxonomy.xml",
 +          "layouts/categories/list.xml",
 +          "layouts/taxonomy/category.rss.xml",
 +          "layouts/taxonomy/taxonomy.rss.xml",
 +          "layouts/taxonomy/rss.xml",
 +          "layouts/taxonomy/list.rss.xml",
 +          "layouts/taxonomy/category.xml",
 +          "layouts/taxonomy/taxonomy.xml",
 +          "layouts/taxonomy/list.xml",
 +          "layouts/category/category.rss.xml",
 +          "layouts/category/taxonomy.rss.xml",
 +          "layouts/category/rss.xml",
 +          "layouts/category/list.rss.xml",
 +          "layouts/category/category.xml",
 +          "layouts/category/taxonomy.xml",
 +          "layouts/category/list.xml",
 +          "layouts/_default/category.rss.xml",
 +          "layouts/_default/taxonomy.rss.xml",
 +          "layouts/_default/rss.xml",
 +          "layouts/_default/list.rss.xml",
 +          "layouts/_default/category.xml",
 +          "layouts/_default/taxonomy.xml",
 +          "layouts/_default/list.xml",
 +          "layouts/_internal/_default/rss.xml"
 +        ]
 +      },
 +      {
 +        "Example": "Taxonomy terms in categories",
 +        "Kind": "taxonomyTerm",
 +        "OutputFormat": "RSS",
 +        "Suffix": "xml",
 +        "Template Lookup Order": [
 +          "layouts/categories/category.terms.rss.xml",
 +          "layouts/categories/terms.rss.xml",
 +          "layouts/categories/rss.xml",
 +          "layouts/categories/list.rss.xml",
 +          "layouts/categories/category.terms.xml",
 +          "layouts/categories/terms.xml",
 +          "layouts/categories/list.xml",
 +          "layouts/taxonomy/category.terms.rss.xml",
 +          "layouts/taxonomy/terms.rss.xml",
 +          "layouts/taxonomy/rss.xml",
 +          "layouts/taxonomy/list.rss.xml",
 +          "layouts/taxonomy/category.terms.xml",
 +          "layouts/taxonomy/terms.xml",
 +          "layouts/taxonomy/list.xml",
 +          "layouts/category/category.terms.rss.xml",
 +          "layouts/category/terms.rss.xml",
 +          "layouts/category/rss.xml",
 +          "layouts/category/list.rss.xml",
 +          "layouts/category/category.terms.xml",
 +          "layouts/category/terms.xml",
 +          "layouts/category/list.xml",
 +          "layouts/_default/category.terms.rss.xml",
 +          "layouts/_default/terms.rss.xml",
 +          "layouts/_default/rss.xml",
 +          "layouts/_default/list.rss.xml",
 +          "layouts/_default/category.terms.xml",
 +          "layouts/_default/terms.xml",
 +          "layouts/_default/list.xml",
 +          "layouts/_internal/_default/rss.xml"
 +        ]
 +      },
 +      {
 +        "Example": "Section list for \"posts\" section",
 +        "Kind": "section",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/posts/posts.html.html",
 +          "layouts/posts/section.html.html",
 +          "layouts/posts/list.html.html",
 +          "layouts/posts/posts.html",
 +          "layouts/posts/section.html",
 +          "layouts/posts/list.html",
 +          "layouts/section/posts.html.html",
 +          "layouts/section/section.html.html",
 +          "layouts/section/list.html.html",
 +          "layouts/section/posts.html",
 +          "layouts/section/section.html",
 +          "layouts/section/list.html",
 +          "layouts/_default/posts.html.html",
 +          "layouts/_default/section.html.html",
 +          "layouts/_default/list.html.html",
 +          "layouts/_default/posts.html",
 +          "layouts/_default/section.html",
 +          "layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "Section list for \"posts\" section with type set to \"blog\"",
 +        "Kind": "section",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/blog/posts.html.html",
 +          "layouts/blog/section.html.html",
 +          "layouts/blog/list.html.html",
 +          "layouts/blog/posts.html",
 +          "layouts/blog/section.html",
 +          "layouts/blog/list.html",
 +          "layouts/posts/posts.html.html",
 +          "layouts/posts/section.html.html",
 +          "layouts/posts/list.html.html",
 +          "layouts/posts/posts.html",
 +          "layouts/posts/section.html",
 +          "layouts/posts/list.html",
 +          "layouts/section/posts.html.html",
 +          "layouts/section/section.html.html",
 +          "layouts/section/list.html.html",
 +          "layouts/section/posts.html",
 +          "layouts/section/section.html",
 +          "layouts/section/list.html",
 +          "layouts/_default/posts.html.html",
 +          "layouts/_default/section.html.html",
 +          "layouts/_default/list.html.html",
 +          "layouts/_default/posts.html",
 +          "layouts/_default/section.html",
 +          "layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "Section list for \"posts\" section with layout set to \"demoLayout\"",
 +        "Kind": "section",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/posts/demolayout.html.html",
 +          "layouts/posts/posts.html.html",
 +          "layouts/posts/section.html.html",
 +          "layouts/posts/list.html.html",
 +          "layouts/posts/demolayout.html",
 +          "layouts/posts/posts.html",
 +          "layouts/posts/section.html",
 +          "layouts/posts/list.html",
 +          "layouts/section/demolayout.html.html",
 +          "layouts/section/posts.html.html",
 +          "layouts/section/section.html.html",
 +          "layouts/section/list.html.html",
 +          "layouts/section/demolayout.html",
 +          "layouts/section/posts.html",
 +          "layouts/section/section.html",
 +          "layouts/section/list.html",
 +          "layouts/_default/demolayout.html.html",
 +          "layouts/_default/posts.html.html",
 +          "layouts/_default/section.html.html",
 +          "layouts/_default/list.html.html",
 +          "layouts/_default/demolayout.html",
 +          "layouts/_default/posts.html",
 +          "layouts/_default/section.html",
 +          "layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "Taxonomy list in categories",
 +        "Kind": "taxonomy",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/categories/category.html.html",
 +          "layouts/categories/taxonomy.html.html",
 +          "layouts/categories/list.html.html",
 +          "layouts/categories/category.html",
 +          "layouts/categories/taxonomy.html",
 +          "layouts/categories/list.html",
 +          "layouts/taxonomy/category.html.html",
 +          "layouts/taxonomy/taxonomy.html.html",
 +          "layouts/taxonomy/list.html.html",
 +          "layouts/taxonomy/category.html",
 +          "layouts/taxonomy/taxonomy.html",
 +          "layouts/taxonomy/list.html",
 +          "layouts/category/category.html.html",
 +          "layouts/category/taxonomy.html.html",
 +          "layouts/category/list.html.html",
 +          "layouts/category/category.html",
 +          "layouts/category/taxonomy.html",
 +          "layouts/category/list.html",
 +          "layouts/_default/category.html.html",
 +          "layouts/_default/taxonomy.html.html",
 +          "layouts/_default/list.html.html",
 +          "layouts/_default/category.html",
 +          "layouts/_default/taxonomy.html",
 +          "layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "Taxonomy term in categories",
 +        "Kind": "taxonomyTerm",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/categories/category.terms.html.html",
 +          "layouts/categories/terms.html.html",
 +          "layouts/categories/list.html.html",
 +          "layouts/categories/category.terms.html",
 +          "layouts/categories/terms.html",
 +          "layouts/categories/list.html",
 +          "layouts/taxonomy/category.terms.html.html",
 +          "layouts/taxonomy/terms.html.html",
 +          "layouts/taxonomy/list.html.html",
 +          "layouts/taxonomy/category.terms.html",
 +          "layouts/taxonomy/terms.html",
 +          "layouts/taxonomy/list.html",
 +          "layouts/category/category.terms.html.html",
 +          "layouts/category/terms.html.html",
 +          "layouts/category/list.html.html",
 +          "layouts/category/category.terms.html",
 +          "layouts/category/terms.html",
 +          "layouts/category/list.html",
 +          "layouts/_default/category.terms.html.html",
 +          "layouts/_default/terms.html.html",
 +          "layouts/_default/list.html.html",
 +          "layouts/_default/category.terms.html",
 +          "layouts/_default/terms.html",
 +          "layouts/_default/list.html"
 +        ]
 +      }
 +    ]
 +  },
 +  "tpl": {
 +    "funcs": {
 +      "cast": {
 +        "ToFloat": {
 +          "Description": "ToFloat converts the given value to a float.",
 +          "Args": [
 +            "v"
 +          ],
 +          "Aliases": [
 +            "float"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"1234\" | float | printf \"%T\" }}",
 +              "float64"
 +            ]
 +          ]
 +        },
 +        "ToInt": {
 +          "Description": "ToInt converts the given value to an int.",
 +          "Args": [
 +            "v"
 +          ],
 +          "Aliases": [
 +            "int"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"1234\" | int | printf \"%T\" }}",
 +              "int"
 +            ]
 +          ]
 +        },
 +        "ToString": {
 +          "Description": "ToString converts the given value to a string.",
 +          "Args": [
 +            "v"
 +          ],
 +          "Aliases": [
 +            "string"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ 1234 | string | printf \"%T\" }}",
 +              "string"
 +            ]
 +          ]
 +        }
 +      },
 +      "compare": {
 +        "Conditional": {
 +          "Description": "Conditional can be used as a ternary operator.\nIt returns a if condition, else b.",
 +          "Args": [
 +            "condition",
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "cond"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ cond (eq (add 2 2) 4) \"2+2 is 4\" \"what?\" | safeHTML }}",
 +              "2+2 is 4"
 +            ]
 +          ]
 +        },
 +        "Default": {
 +          "Description": "Default checks whether a given value is set and returns a default value if it\nis not.  \"Set\" in this context means non-zero for numeric types and times;\nnon-zero length for strings, arrays, slices, and maps;\nany boolean or struct value; or non-nil for any other types.",
 +          "Args": [
 +            "dflt",
 +            "given"
 +          ],
 +          "Aliases": [
 +            "default"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"Hugo Rocks!\" | default \"Hugo Rules!\" }}",
 +              "Hugo Rocks!"
 +            ],
 +            [
 +              "{{ \"\" | default \"Hugo Rules!\" }}",
 +              "Hugo Rules!"
 +            ]
 +          ]
 +        },
 +        "Eq": {
 +          "Description": "Eq returns the boolean truth of arg1 == arg2.",
 +          "Args": [
 +            "x",
 +            "y"
 +          ],
 +          "Aliases": [
 +            "eq"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ if eq .Section \"blog\" }}current{{ end }}",
 +              "current"
 +            ]
 +          ]
 +        },
 +        "Ge": {
 +          "Description": "Ge returns the boolean truth of arg1 \u003e= arg2.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "ge"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ if ge .Hugo.Version \"0.36\" }}Reasonable new Hugo version!{{ end }}",
 +              "Reasonable new Hugo version!"
 +            ]
 +          ]
 +        },
 +        "Gt": {
 +          "Description": "Gt returns the boolean truth of arg1 \u003e arg2.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "gt"
 +          ],
 +          "Examples": []
 +        },
 +        "Le": {
 +          "Description": "Le returns the boolean truth of arg1 \u003c= arg2.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "le"
 +          ],
 +          "Examples": []
 +        },
 +        "Lt": {
 +          "Description": "Lt returns the boolean truth of arg1 \u003c arg2.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "lt"
 +          ],
 +          "Examples": []
 +        },
 +        "Ne": {
 +          "Description": "Ne returns the boolean truth of arg1 != arg2.",
 +          "Args": [
 +            "x",
 +            "y"
 +          ],
 +          "Aliases": [
 +            "ne"
 +          ],
 +          "Examples": []
 +        }
 +      },
 +      "collections": {
 +        "After": {
 +          "Description": "After returns all the items after the first N in a rangeable list.",
 +          "Args": [
 +            "index",
 +            "seq"
 +          ],
 +          "Aliases": [
 +            "after"
 +          ],
 +          "Examples": []
 +        },
 +        "Apply": {
 +          "Description": "Apply takes a map, array, or slice and returns a new slice with the function fname applied over it.",
 +          "Args": [
 +            "seq",
 +            "fname",
 +            "args"
 +          ],
 +          "Aliases": [
 +            "apply"
 +          ],
 +          "Examples": []
 +        },
 +        "Delimit": {
 +          "Description": "Delimit takes a given sequence and returns a delimited HTML string.\nIf last is passed to the function, it will be used as the final delimiter.",
 +          "Args": [
 +            "seq",
 +            "delimiter",
 +            "last"
 +          ],
 +          "Aliases": [
 +            "delimit"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ delimit (slice \"A\" \"B\" \"C\") \", \" \" and \" }}",
 +              "A, B and C"
 +            ]
 +          ]
 +        },
 +        "Dictionary": {
 +          "Description": "Dictionary creates a map[string]interface{} from the given parameters by\nwalking the parameters and treating them as key-value pairs.  The number\nof parameters must be even.",
 +          "Args": [
 +            "values"
 +          ],
 +          "Aliases": [
 +            "dict"
 +          ],
 +          "Examples": []
 +        },
 +        "EchoParam": {
 +          "Description": "EchoParam returns a given value if it is set; otherwise, it returns an\nempty string.",
 +          "Args": [
 +            "a",
 +            "key"
 +          ],
 +          "Aliases": [
 +            "echoParam"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ echoParam .Params \"langCode\" }}",
 +              "en"
 +            ]
 +          ]
 +        },
 +        "First": {
 +          "Description": "First returns the first N items in a rangeable list.",
 +          "Args": [
 +            "limit",
 +            "seq"
 +          ],
 +          "Aliases": [
 +            "first"
 +          ],
 +          "Examples": []
 +        },
 +        "In": {
 +          "Description": "In returns whether v is in the set l.  l may be an array or slice.",
 +          "Args": [
 +            "l",
 +            "v"
 +          ],
 +          "Aliases": [
 +            "in"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ if in \"this string contains a substring\" \"substring\" }}Substring found!{{ end }}",
 +              "Substring found!"
 +            ]
 +          ]
 +        },
 +        "Index": {
 +          "Description": "Index returns the result of indexing its first argument by the following\narguments. Thus \"index x 1 2 3\" is, in Go syntax, x[1][2][3]. Each\nindexed item must be a map, slice, or array.\n\nCopied from Go stdlib src/text/template/funcs.go.\n\nWe deviate from the stdlib due to https://github.com/golang/go/issues/14751.\n\nTODO(moorereason): merge upstream changes.",
 +          "Args": [
 +            "item",
 +            "indices"
 +          ],
 +          "Aliases": [
 +            "index"
 +          ],
 +          "Examples": []
 +        },
 +        "Intersect": {
 +          "Description": "Intersect returns the common elements in the given sets, l1 and l2.  l1 and\nl2 must be of the same type and may be either arrays or slices.",
 +          "Args": [
 +            "l1",
 +            "l2"
 +          ],
 +          "Aliases": [
 +            "intersect"
 +          ],
 +          "Examples": []
 +        },
 +        "IsSet": {
 +          "Description": "IsSet returns whether a given array, channel, slice, or map has a key\ndefined.",
 +          "Args": [
 +            "a",
 +            "key"
 +          ],
 +          "Aliases": [
 +            "isSet",
 +            "isset"
 +          ],
 +          "Examples": []
 +        },
 +        "KeyVals": {
 +          "Description": "KeyVals creates a key and values wrapper.",
 +          "Args": [
 +            "key",
 +            "vals"
 +          ],
 +          "Aliases": [
 +            "keyVals"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ keyVals \"key\" \"a\" \"b\" }}",
 +              "key: [a b]"
 +            ]
 +          ]
 +        },
 +        "Last": {
 +          "Description": "Last returns the last N items in a rangeable list.",
 +          "Args": [
 +            "limit",
 +            "seq"
 +          ],
 +          "Aliases": [
 +            "last"
 +          ],
 +          "Examples": []
 +        },
 +        "Querify": {
 +          "Description": "Querify encodes the given parameters in URL-encoded form (\"bar=baz\u0026foo=quux\") sorted by key.",
 +          "Args": [
 +            "params"
 +          ],
 +          "Aliases": [
 +            "querify"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ (querify \"foo\" 1 \"bar\" 2 \"baz\" \"with spaces\" \"qux\" \"this\u0026that=those\") | safeHTML }}",
 +              "bar=2\u0026baz=with+spaces\u0026foo=1\u0026qux=this%26that%3Dthose"
 +            ],
 +            [
 +              "\u003ca href=\"https://www.google.com?{{ (querify \"q\" \"test\" \"page\" 3) | safeURL }}\"\u003eSearch\u003c/a\u003e",
 +              "\u003ca href=\"https://www.google.com?page=3\u0026amp;q=test\"\u003eSearch\u003c/a\u003e"
 +            ]
 +          ]
 +        },
 +        "Seq": {
 +          "Description": "Seq creates a sequence of integers.  It's named and used as GNU's seq.\n\nExamples:\n    3 =\u003e 1, 2, 3\n    1 2 4 =\u003e 1, 3\n    -3 =\u003e -1, -2, -3\n    1 4 =\u003e 1, 2, 3, 4\n    1 -2 =\u003e 1, 0, -1, -2",
 +          "Args": [
 +            "args"
 +          ],
 +          "Aliases": [
 +            "seq"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ seq 3 }}",
 +              "[1 2 3]"
 +            ]
 +          ]
 +        },
 +        "Shuffle": {
 +          "Description": "Shuffle returns the given rangeable list in a randomised order.",
 +          "Args": [
 +            "seq"
 +          ],
 +          "Aliases": [
 +            "shuffle"
 +          ],
 +          "Examples": []
 +        },
 +        "Slice": {
 +          "Description": "Slice returns a slice of all passed arguments.",
 +          "Args": [
 +            "args"
 +          ],
 +          "Aliases": [
 +            "slice"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ slice \"B\" \"C\" \"A\" | sort }}",
 +              "[A B C]"
 +            ]
 +          ]
 +        },
 +        "Sort": {
 +          "Description": "Sort returns a sorted sequence.",
 +          "Args": [
 +            "seq",
 +            "args"
 +          ],
 +          "Aliases": [
 +            "sort"
 +          ],
 +          "Examples": []
 +        },
 +        "Union": {
 +          "Description": "Union returns the union of the given sets, l1 and l2. l1 and\nl2 must be of the same type and may be either arrays or slices.\nIf l1 and l2 aren't of the same type then l1 will be returned.\nIf either l1 or l2 is nil then the non-nil list will be returned.",
 +          "Args": [
 +            "l1",
 +            "l2"
 +          ],
 +          "Aliases": [
 +            "union"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ union (slice 1 2 3) (slice 3 4 5) }}",
 +              "[1 2 3 4 5]"
 +            ]
 +          ]
 +        },
 +        "Uniq": {
 +          "Description": "Uniq takes in a slice or array and returns a slice with subsequent\nduplicate elements removed.",
 +          "Args": [
 +            "l"
 +          ],
 +          "Aliases": [
 +            "uniq"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ slice 1 2 3 2 | uniq }}",
 +              "[1 2 3]"
 +            ]
 +          ]
 +        },
 +        "Where": {
 +          "Description": "Where returns a filtered subset of a given data type.",
 +          "Args": [
 +            "seq",
 +            "key",
 +            "args"
 +          ],
 +          "Aliases": [
 +            "where"
 +          ],
 +          "Examples": []
 +        }
 +      },
 +      "crypto": {
 +        "MD5": {
 +          "Description": "MD5 hashes the given input and returns its MD5 checksum.",
 +          "Args": [
 +            "in"
 +          ],
 +          "Aliases": [
 +            "md5"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ md5 \"Hello world, gophers!\" }}",
 +              "b3029f756f98f79e7f1b7f1d1f0dd53b"
 +            ],
 +            [
 +              "{{ crypto.MD5 \"Hello world, gophers!\" }}",
 +              "b3029f756f98f79e7f1b7f1d1f0dd53b"
 +            ]
 +          ]
 +        },
 +        "SHA1": {
 +          "Description": "SHA1 hashes the given input and returns its SHA1 checksum.",
 +          "Args": [
 +            "in"
 +          ],
 +          "Aliases": [
 +            "sha1"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ sha1 \"Hello world, gophers!\" }}",
 +              "c8b5b0e33d408246e30f53e32b8f7627a7a649d4"
 +            ]
 +          ]
 +        },
 +        "SHA256": {
 +          "Description": "SHA256 hashes the given input and returns its SHA256 checksum.",
 +          "Args": [
 +            "in"
 +          ],
 +          "Aliases": [
 +            "sha256"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ sha256 \"Hello world, gophers!\" }}",
 +              "6ec43b78da9669f50e4e422575c54bf87536954ccd58280219c393f2ce352b46"
 +            ]
 +          ]
 +        }
 +      },
 +      "data": {
 +        "GetCSV": {
 +          "Description": "GetCSV expects a data separator and one or n-parts of a URL to a resource which\ncan either be a local or a remote one.\nThe data separator can be a comma, semi-colon, pipe, etc, but only one character.\nIf you provide multiple parts for the URL they will be joined together to the final URL.\nGetCSV returns nil or a slice slice to use in a short code.",
 +          "Args": [
 +            "sep",
 +            "urlParts"
 +          ],
 +          "Aliases": [
 +            "getCSV"
 +          ],
 +          "Examples": []
 +        },
 +        "GetJSON": {
 +          "Description": "GetJSON expects one or n-parts of a URL to a resource which can either be a local or a remote one.\nIf you provide multiple parts they will be joined together to the final URL.\nGetJSON returns nil or parsed JSON to use in a short code.",
 +          "Args": [
 +            "urlParts"
 +          ],
 +          "Aliases": [
 +            "getJSON"
 +          ],
 +          "Examples": []
 +        }
 +      },
 +      "encoding": {
 +        "Base64Decode": {
 +          "Description": "Base64Decode returns the base64 decoding of the given content.",
 +          "Args": [
 +            "content"
 +          ],
 +          "Aliases": [
 +            "base64Decode"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"SGVsbG8gd29ybGQ=\" | base64Decode }}",
 +              "Hello world"
 +            ],
 +            [
 +              "{{ 42 | base64Encode | base64Decode }}",
 +              "42"
 +            ]
 +          ]
 +        },
 +        "Base64Encode": {
 +          "Description": "Base64Encode returns the base64 encoding of the given content.",
 +          "Args": [
 +            "content"
 +          ],
 +          "Aliases": [
 +            "base64Encode"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"Hello world\" | base64Encode }}",
 +              "SGVsbG8gd29ybGQ="
 +            ]
 +          ]
 +        },
 +        "Jsonify": {
 +          "Description": "Jsonify encodes a given object to JSON.",
 +          "Args": [
 +            "v"
 +          ],
 +          "Aliases": [
 +            "jsonify"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ (slice \"A\" \"B\" \"C\") | jsonify }}",
 +              "[\"A\",\"B\",\"C\"]"
 +            ]
 +          ]
 +        }
 +      },
 +      "fmt": {
 +        "Errorf": {
 +          "Description": "",
 +          "Args": [
 +            "format",
 +            "a"
 +          ],
 +          "Aliases": [
 +            "errorf"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ errorf \"%s.\" \"failed\" }}",
 +              "failed."
 +            ]
 +          ]
 +        },
 +        "Print": {
 +          "Description": "Print returns string representation of the passed arguments.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "print"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ print \"works!\" }}",
 +              "works!"
 +            ]
 +          ]
 +        },
 +        "Printf": {
 +          "Description": "Printf returns a formatted string representation of the passed arguments.",
 +          "Args": [
 +            "format",
 +            "a"
 +          ],
 +          "Aliases": [
 +            "printf"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ printf \"%s!\" \"works\" }}",
 +              "works!"
 +            ]
 +          ]
 +        },
 +        "Println": {
 +          "Description": "Println returns string representation of the passed arguments ending with a newline.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "println"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ println \"works!\" }}",
 +              "works!\n"
 +            ]
 +          ]
 +        }
 +      },
 +      "images": {
 +        "Config": {
 +          "Description": "Config returns the image.Config for the specified path relative to the\nworking directory.",
 +          "Args": [
 +            "path"
 +          ],
 +          "Aliases": [
 +            "imageConfig"
 +          ],
 +          "Examples": []
 +        }
 +      },
 +      "inflect": {
 +        "Humanize": {
 +          "Description": "Humanize returns the humanized form of a single parameter.\n\nIf the parameter is either an integer or a string containing an integer\nvalue, the behavior is to add the appropriate ordinal.\n\n    Example:  \"my-first-post\" -\u003e \"My first post\"\n    Example:  \"103\" -\u003e \"103rd\"\n    Example:  52 -\u003e \"52nd\"",
 +          "Args": [
 +            "in"
 +          ],
 +          "Aliases": [
 +            "humanize"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ humanize \"my-first-post\" }}",
 +              "My first post"
 +            ],
 +            [
 +              "{{ humanize \"myCamelPost\" }}",
 +              "My camel post"
 +            ],
 +            [
 +              "{{ humanize \"52\" }}",
 +              "52nd"
 +            ],
 +            [
 +              "{{ humanize 103 }}",
 +              "103rd"
 +            ]
 +          ]
 +        },
 +        "Pluralize": {
 +          "Description": "Pluralize returns the plural form of a single word.",
 +          "Args": [
 +            "in"
 +          ],
 +          "Aliases": [
 +            "pluralize"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"cat\" | pluralize }}",
 +              "cats"
 +            ]
 +          ]
 +        },
 +        "Singularize": {
 +          "Description": "Singularize returns the singular form of a single word.",
 +          "Args": [
 +            "in"
 +          ],
 +          "Aliases": [
 +            "singularize"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"cats\" | singularize }}",
 +              "cat"
 +            ]
 +          ]
 +        }
 +      },
 +      "lang": {
 +        "Merge": {
 +          "Description": "",
 +          "Args": null,
 +          "Aliases": null,
 +          "Examples": null
 +        },
 +        "NumFmt": {
 +          "Description": "NumFmt formats a number with the given precision using the\nnegative, decimal, and grouping options.  The `options`\nparameter is a string consisting of `\u003cnegative\u003e \u003cdecimal\u003e \u003cgrouping\u003e`.  The\ndefault `options` value is `- . ,`.\n\nNote that numbers are rounded up at 5 or greater.\nSo, with precision set to 0, 1.5 becomes `2`, and 1.4 becomes `1`.",
 +          "Args": [
 +            "precision",
 +            "number",
 +            "options"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{ lang.NumFmt 2 12345.6789 }}",
 +              "12,345.68"
 +            ],
 +            [
 +              "{{ lang.NumFmt 2 12345.6789 \"- , .\" }}",
 +              "12.345,68"
 +            ],
 +            [
 +              "{{ lang.NumFmt 6 -12345.6789 \"- .\" }}",
 +              "-12345.678900"
 +            ],
 +            [
 +              "{{ lang.NumFmt 0 -12345.6789 \"- . ,\" }}",
 +              "-12,346"
 +            ],
 +            [
 +              "{{ -98765.4321 | lang.NumFmt 2 }}",
 +              "-98,765.43"
 +            ]
 +          ]
 +        },
 +        "Translate": {
 +          "Description": "Translate ...",
 +          "Args": [
 +            "id",
 +            "args"
 +          ],
 +          "Aliases": [
 +            "i18n",
 +            "T"
 +          ],
 +          "Examples": []
 +        }
 +      },
 +      "math": {
 +        "Add": {
 +          "Description": "Add adds two numbers.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "add"
 +          ],
 +          "Examples": [
 +            [
 +              "{{add 1 2}}",
 +              "3"
 +            ]
 +          ]
 +        },
 +        "Ceil": {
 +          "Description": "Ceil returns the least integer value greater than or equal to x.",
 +          "Args": [
 +            "x"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{math.Ceil 2.1}}",
 +              "3"
 +            ]
 +          ]
 +        },
 +        "Div": {
 +          "Description": "Div divides two numbers.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "div"
 +          ],
 +          "Examples": [
 +            [
 +              "{{div 6 3}}",
 +              "2"
 +            ]
 +          ]
 +        },
 +        "Floor": {
 +          "Description": "Floor returns the greatest integer value less than or equal to x.",
 +          "Args": [
 +            "x"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{math.Floor 1.9}}",
 +              "1"
 +            ]
 +          ]
 +        },
 +        "Log": {
 +          "Description": "Log returns the natural logarithm of a number.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{math.Log 1}}",
 +              "0"
 +            ]
 +          ]
 +        },
 +        "Mod": {
 +          "Description": "Mod returns a % b.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "mod"
 +          ],
 +          "Examples": [
 +            [
 +              "{{mod 15 3}}",
 +              "0"
 +            ]
 +          ]
 +        },
 +        "ModBool": {
 +          "Description": "ModBool returns the boolean of a % b.  If a % b == 0, return true.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "modBool"
 +          ],
 +          "Examples": [
 +            [
 +              "{{modBool 15 3}}",
 +              "true"
 +            ]
 +          ]
 +        },
 +        "Mul": {
 +          "Description": "Mul multiplies two numbers.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "mul"
 +          ],
 +          "Examples": [
 +            [
 +              "{{mul 2 3}}",
 +              "6"
 +            ]
 +          ]
 +        },
 +        "Round": {
 +          "Description": "Round returns the nearest integer, rounding half away from zero.",
 +          "Args": [
 +            "x"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{math.Round 1.5}}",
 +              "2"
 +            ]
 +          ]
 +        },
 +        "Sub": {
 +          "Description": "Sub subtracts two numbers.",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "sub"
 +          ],
 +          "Examples": [
 +            [
 +              "{{sub 3 2}}",
 +              "1"
 +            ]
 +          ]
 +        }
 +      },
 +      "os": {
 +        "FileExists": {
 +          "Description": "FileExists checks whether a file exists under the given path.",
 +          "Args": [
 +            "i"
 +          ],
 +          "Aliases": [
 +            "fileExists"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ fileExists \"foo.txt\" }}",
 +              "false"
 +            ]
 +          ]
 +        },
 +        "Getenv": {
 +          "Description": "Getenv retrieves the value of the environment variable named by the key.\nIt returns the value, which will be empty if the variable is not present.",
 +          "Args": [
 +            "key"
 +          ],
 +          "Aliases": [
 +            "getenv"
 +          ],
 +          "Examples": []
 +        },
 +        "ReadDir": {
 +          "Description": "ReadDir lists the directory contents relative to the configured WorkingDir.",
 +          "Args": [
 +            "i"
 +          ],
 +          "Aliases": [
 +            "readDir"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ range (readDir \".\") }}{{ .Name }}{{ end }}",
 +              "README.txt"
 +            ]
 +          ]
 +        },
 +        "ReadFile": {
 +          "Description": "ReadFile reads the file named by filename relative to the configured WorkingDir.\nIt returns the contents as a string.\nThere is an upper size limit set at 1 megabytes.",
 +          "Args": [
 +            "i"
 +          ],
 +          "Aliases": [
 +            "readFile"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ readFile \"README.txt\" }}",
 +              "Hugo Rocks!"
 +            ]
 +          ]
 +        }
 +      },
 +      "partials": {
 +        "Include": {
 +          "Description": "Include executes the named partial and returns either a string,\nwhen the partial is a text/template, or template.HTML when html/template.",
 +          "Args": [
 +            "name",
 +            "contextList"
 +          ],
 +          "Aliases": [
 +            "partial"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ partial \"header.html\" . }}",
 +              "\u003ctitle\u003eHugo Rocks!\u003c/title\u003e"
 +            ]
 +          ]
 +        },
 +        "IncludeCached": {
 +          "Description": "IncludeCached executes and caches partial templates.  An optional variant\nstring parameter (a string slice actually, but be only use a variadic\nargument to make it optional) can be passed so that a given partial can have\nmultiple uses. The cache is created with name+variant as the key.",
 +          "Args": [
 +            "name",
 +            "context",
 +            "variant"
 +          ],
 +          "Aliases": [
 +            "partialCached"
 +          ],
 +          "Examples": []
 +        }
 +      },
++      "path": {
++        "Join": {
++          "Description": "Join joins any number of path elements into a single path, adding a\nseparating slash if necessary. All the input\npath elements are passed into filepath.ToSlash converting any Windows slashes\nto forward slashes.\nThe result is Cleaned; in particular,\nall empty strings are ignored.",
++          "Args": [
++            "elements"
++          ],
++          "Aliases": null,
++          "Examples": [
++            [
++              "{{ slice \"my/path\" \"filename.txt\" | path.Join  }}",
++              "my/path/filename.txt"
++            ],
++            [
++              "{{  path.Join \"my\" \"path\" \"filename.txt\" }}",
++              "my/path/filename.txt"
++            ]
++          ]
++        },
++        "Split": {
++          "Description": "Split splits path immediately following the final slash,\nseparating it into a directory and file name component.\nIf there is no slash in path, Split returns an empty dir and\nfile set to path.\nThe input path is passed into filepath.ToSlash converting any Windows slashes\nto forward slashes.\nThe returned values have the property that path = dir+file.",
++          "Args": [
++            "path"
++          ],
++          "Aliases": null,
++          "Examples": [
++            [
++              "{{ \"/my/path/filename.txt\" | path.Split }}",
++              "/my/path/|filename.txt"
++            ],
++            [
++              "{{ \"/my/path/filename.txt\" | path.Split }}",
++              "/my/path/|filename.txt"
++            ]
++          ]
++        }
++      },
 +      "safe": {
 +        "CSS": {
 +          "Description": "CSS returns a given string as html/template CSS content.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "safeCSS"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"Bat\u0026Man\" | safeCSS | safeCSS }}",
 +              "Bat\u0026amp;Man"
 +            ]
 +          ]
 +        },
 +        "HTML": {
 +          "Description": "HTML returns a given string as html/template HTML content.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "safeHTML"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"Bat\u0026Man\" | safeHTML | safeHTML }}",
 +              "Bat\u0026Man"
 +            ],
 +            [
 +              "{{ \"Bat\u0026Man\" | safeHTML }}",
 +              "Bat\u0026Man"
 +            ]
 +          ]
 +        },
 +        "HTMLAttr": {
 +          "Description": "HTMLAttr returns a given string as html/template HTMLAttr content.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "safeHTMLAttr"
 +          ],
 +          "Examples": []
 +        },
 +        "JS": {
 +          "Description": "JS returns the given string as a html/template JS content.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "safeJS"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"(1*2)\" | safeJS | safeJS }}",
 +              "(1*2)"
 +            ]
 +          ]
 +        },
 +        "JSStr": {
 +          "Description": "JSStr returns the given string as a html/template JSStr content.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "safeJSStr"
 +          ],
 +          "Examples": []
 +        },
 +        "SanitizeURL": {
 +          "Description": "SanitizeURL returns a given string as html/template URL content.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "sanitizeURL",
 +            "sanitizeurl"
 +          ],
 +          "Examples": []
 +        },
 +        "URL": {
 +          "Description": "URL returns a given string as html/template URL content.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "safeURL"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"http://gohugo.io\" | safeURL | safeURL }}",
 +              "http://gohugo.io"
 +            ]
 +          ]
 +        }
 +      },
 +      "strings": {
 +        "Chomp": {
 +          "Description": "Chomp returns a copy of s with all trailing newline characters removed.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "chomp"
 +          ],
 +          "Examples": [
 +            [
 +              "{{chomp \"\u003cp\u003eBlockhead\u003c/p\u003e\\n\" | safeHTML }}",
 +              "\u003cp\u003eBlockhead\u003c/p\u003e"
 +            ]
 +          ]
 +        },
 +        "Contains": {
 +          "Description": "",
 +          "Args": null,
 +          "Aliases": null,
 +          "Examples": null
 +        },
 +        "ContainsAny": {
 +          "Description": "",
 +          "Args": null,
 +          "Aliases": null,
 +          "Examples": null
 +        },
 +        "CountRunes": {
 +          "Description": "CountRunes returns the number of runes in s, excluding whitepace.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "countrunes"
 +          ],
 +          "Examples": []
 +        },
 +        "CountWords": {
 +          "Description": "CountWords returns the approximate word count in s.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "countwords"
 +          ],
 +          "Examples": []
 +        },
 +        "FindRE": {
 +          "Description": "FindRE returns a list of strings that match the regular expression. By default all matches\nwill be included. The number of matches can be limited with an optional third parameter.",
 +          "Args": [
 +            "expr",
 +            "content",
 +            "limit"
 +          ],
 +          "Aliases": [
 +            "findRE"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ findRE \"[G|g]o\" \"Hugo is a static side generator written in Go.\" \"1\" }}",
 +              "[go]"
 +            ]
 +          ]
 +        },
 +        "HasPrefix": {
 +          "Description": "HasPrefix tests whether the input s begins with prefix.",
 +          "Args": [
 +            "s",
 +            "prefix"
 +          ],
 +          "Aliases": [
 +            "hasPrefix"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ hasPrefix \"Hugo\" \"Hu\" }}",
 +              "true"
 +            ],
 +            [
 +              "{{ hasPrefix \"Hugo\" \"Fu\" }}",
 +              "false"
 +            ]
 +          ]
 +        },
 +        "HasSuffix": {
 +          "Description": "",
 +          "Args": null,
 +          "Aliases": null,
 +          "Examples": null
 +        },
 +        "Replace": {
 +          "Description": "Replace returns a copy of the string s with all occurrences of old replaced\nwith new.",
 +          "Args": [
 +            "s",
 +            "old",
 +            "new"
 +          ],
 +          "Aliases": [
 +            "replace"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ replace \"Batman and Robin\" \"Robin\" \"Catwoman\" }}",
 +              "Batman and Catwoman"
 +            ]
 +          ]
 +        },
 +        "ReplaceRE": {
 +          "Description": "ReplaceRE returns a copy of s, replacing all matches of the regular\nexpression pattern with the replacement text repl.",
 +          "Args": [
 +            "pattern",
 +            "repl",
 +            "s"
 +          ],
 +          "Aliases": [
 +            "replaceRE"
 +          ],
 +          "Examples": []
 +        },
 +        "SliceString": {
 +          "Description": "SliceString slices a string by specifying a half-open range with\ntwo indices, start and end. 1 and 4 creates a slice including elements 1 through 3.\nThe end index can be omitted, it defaults to the string's length.",
 +          "Args": [
 +            "a",
 +            "startEnd"
 +          ],
 +          "Aliases": [
 +            "slicestr"
 +          ],
 +          "Examples": [
 +            [
 +              "{{slicestr \"BatMan\" 0 3}}",
 +              "Bat"
 +            ],
 +            [
 +              "{{slicestr \"BatMan\" 3}}",
 +              "Man"
 +            ]
 +          ]
 +        },
 +        "Split": {
 +          "Description": "Split slices an input string into all substrings separated by delimiter.",
 +          "Args": [
 +            "a",
 +            "delimiter"
 +          ],
 +          "Aliases": [
 +            "split"
 +          ],
 +          "Examples": []
 +        },
 +        "Substr": {
 +          "Description": "Substr extracts parts of a string, beginning at the character at the specified\nposition, and returns the specified number of characters.\n\nIt normally takes two parameters: start and length.\nIt can also take one parameter: start, i.e. length is omitted, in which case\nthe substring starting from start until the end of the string will be returned.\n\nTo extract characters from the end of the string, use a negative start number.\n\nIn addition, borrowing from the extended behavior described at http://php.net/substr,\nif length is given and is negative, then that many characters will be omitted from\nthe end of string.",
 +          "Args": [
 +            "a",
 +            "nums"
 +          ],
 +          "Aliases": [
 +            "substr"
 +          ],
 +          "Examples": [
 +            [
 +              "{{substr \"BatMan\" 0 -3}}",
 +              "Bat"
 +            ],
 +            [
 +              "{{substr \"BatMan\" 3 3}}",
 +              "Man"
 +            ]
 +          ]
 +        },
 +        "Title": {
 +          "Description": "Title returns a copy of the input s with all Unicode letters that begin words\nmapped to their title case.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "title"
 +          ],
 +          "Examples": [
 +            [
 +              "{{title \"Bat man\"}}",
 +              "Bat Man"
 +            ],
 +            [
 +              "{{title \"somewhere over the rainbow\"}}",
 +              "Somewhere Over the Rainbow"
 +            ]
 +          ]
 +        },
 +        "ToLower": {
 +          "Description": "ToLower returns a copy of the input s with all Unicode letters mapped to their\nlower case.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "lower"
 +          ],
 +          "Examples": [
 +            [
 +              "{{lower \"BatMan\"}}",
 +              "batman"
 +            ]
 +          ]
 +        },
 +        "ToUpper": {
 +          "Description": "ToUpper returns a copy of the input s with all Unicode letters mapped to their\nupper case.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "upper"
 +          ],
 +          "Examples": [
 +            [
 +              "{{upper \"BatMan\"}}",
 +              "BATMAN"
 +            ]
 +          ]
 +        },
 +        "Trim": {
 +          "Description": "Trim returns a string with all leading and trailing characters defined\ncontained in cutset removed.",
 +          "Args": [
 +            "s",
 +            "cutset"
 +          ],
 +          "Aliases": [
 +            "trim"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ trim \"++Batman--\" \"+-\" }}",
 +              "Batman"
 +            ]
 +          ]
 +        },
 +        "TrimLeft": {
 +          "Description": "TrimLeft returns a slice of the string s with all leading characters\ncontained in cutset removed.",
 +          "Args": [
 +            "cutset",
 +            "s"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{ \"aabbaa\" | strings.TrimLeft \"a\" }}",
 +              "bbaa"
 +            ]
 +          ]
 +        },
 +        "TrimPrefix": {
 +          "Description": "TrimPrefix returns s without the provided leading prefix string. If s doesn't\nstart with prefix, s is returned unchanged.",
 +          "Args": [
 +            "prefix",
 +            "s"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{ \"aabbaa\" | strings.TrimPrefix \"a\" }}",
 +              "abbaa"
 +            ],
 +            [
 +              "{{ \"aabbaa\" | strings.TrimPrefix \"aa\" }}",
 +              "bbaa"
 +            ]
 +          ]
 +        },
 +        "TrimRight": {
 +          "Description": "TrimRight returns a slice of the string s with all trailing characters\ncontained in cutset removed.",
 +          "Args": [
 +            "cutset",
 +            "s"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{ \"aabbaa\" | strings.TrimRight \"a\" }}",
 +              "aabb"
 +            ]
 +          ]
 +        },
 +        "TrimSuffix": {
 +          "Description": "TrimSuffix returns s without the provided trailing suffix string. If s\ndoesn't end with suffix, s is returned unchanged.",
 +          "Args": [
 +            "suffix",
 +            "s"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{ \"aabbaa\" | strings.TrimSuffix \"a\" }}",
 +              "aabba"
 +            ],
 +            [
 +              "{{ \"aabbaa\" | strings.TrimSuffix \"aa\" }}",
 +              "aabb"
 +            ]
 +          ]
 +        },
 +        "Truncate": {
 +          "Description": "Truncate truncates a given string to the specified length.",
 +          "Args": [
 +            "a",
 +            "options"
 +          ],
 +          "Aliases": [
 +            "truncate"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"this is a very long text\" | truncate 10 \" ...\" }}",
 +              "this is a ..."
 +            ],
 +            [
 +              "{{ \"With [Markdown](/markdown) inside.\" | markdownify | truncate 14 }}",
 +              "With \u003ca href=\"/markdown\"\u003eMarkdown …\u003c/a\u003e"
 +            ]
 +          ]
 +        }
 +      },
 +      "time": {
 +        "AsTime": {
 +          "Description": "AsTime converts the textual representation of the datetime string into\na time.Time interface.",
 +          "Args": [
 +            "v"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{ (time \"2015-01-21\").Year }}",
 +              "2015"
 +            ]
 +          ]
 +        },
 +        "Duration": {
 +          "Description": "Duration converts the given number to a time.Duration.\nUnit is one of nanosecond/ns, microsecond/us/µs, millisecond/ms, second/s, minute/m or hour/h.",
 +          "Args": [
 +            "unit",
 +            "number"
 +          ],
 +          "Aliases": [
 +            "duration"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ mul 60 60 | duration \"second\" }}",
 +              "1h0m0s"
 +            ]
 +          ]
 +        },
 +        "Format": {
 +          "Description": "Format converts the textual representation of the datetime string into\nthe other form or returns it of the time.Time value. These are formatted\nwith the layout string",
 +          "Args": [
 +            "layout",
 +            "v"
 +          ],
 +          "Aliases": [
 +            "dateFormat"
 +          ],
 +          "Examples": [
 +            [
 +              "dateFormat: {{ dateFormat \"Monday, Jan 2, 2006\" \"2015-01-21\" }}",
 +              "dateFormat: Wednesday, Jan 21, 2015"
 +            ]
 +          ]
 +        },
 +        "Now": {
 +          "Description": "Now returns the current local time.",
 +          "Args": null,
 +          "Aliases": [
 +            "now"
 +          ],
 +          "Examples": []
 +        },
 +        "ParseDuration": {
 +          "Description": "ParseDuration parses a duration string.\nA duration string is a possibly signed sequence of\ndecimal numbers, each with optional fraction and a unit suffix,\nsuch as \"300ms\", \"-1.5h\" or \"2h45m\".\nValid time units are \"ns\", \"us\" (or \"µs\"), \"ms\", \"s\", \"m\", \"h\".\nSee https://golang.org/pkg/time/#ParseDuration",
 +          "Args": [
 +            "in"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{ \"1h12m10s\" | time.ParseDuration }}",
 +              "1h12m10s"
 +            ]
 +          ]
 +        }
 +      },
 +      "transform": {
 +        "Emojify": {
 +          "Description": "Emojify returns a copy of s with all emoji codes replaced with actual emojis.\n\nSee http://www.emoji-cheat-sheet.com/",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "emojify"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ \"I :heart: Hugo\" | emojify }}",
 +              "I ❤️ Hugo"
 +            ]
 +          ]
 +        },
 +        "HTMLEscape": {
 +          "Description": "HTMLEscape returns a copy of s with reserved HTML characters escaped.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "htmlEscape"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ htmlEscape \"Cathal Garvey \u0026 The Sunshine Band \u003ccathal@foo.bar\u003e\" | safeHTML}}",
 +              "Cathal Garvey \u0026amp; The Sunshine Band \u0026lt;cathal@foo.bar\u0026gt;"
 +            ],
 +            [
 +              "{{ htmlEscape \"Cathal Garvey \u0026 The Sunshine Band \u003ccathal@foo.bar\u003e\"}}",
 +              "Cathal Garvey \u0026amp;amp; The Sunshine Band \u0026amp;lt;cathal@foo.bar\u0026amp;gt;"
 +            ],
 +            [
 +              "{{ htmlEscape \"Cathal Garvey \u0026 The Sunshine Band \u003ccathal@foo.bar\u003e\" | htmlUnescape | safeHTML }}",
 +              "Cathal Garvey \u0026 The Sunshine Band \u003ccathal@foo.bar\u003e"
 +            ]
 +          ]
 +        },
 +        "HTMLUnescape": {
 +          "Description": "HTMLUnescape returns a copy of with HTML escape requences converted to plain\ntext.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "htmlUnescape"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ htmlUnescape \"Cathal Garvey \u0026amp; The Sunshine Band \u0026lt;cathal@foo.bar\u0026gt;\" | safeHTML}}",
 +              "Cathal Garvey \u0026 The Sunshine Band \u003ccathal@foo.bar\u003e"
 +            ],
 +            [
 +              "{{\"Cathal Garvey \u0026amp;amp; The Sunshine Band \u0026amp;lt;cathal@foo.bar\u0026amp;gt;\" | htmlUnescape | htmlUnescape | safeHTML}}",
 +              "Cathal Garvey \u0026 The Sunshine Band \u003ccathal@foo.bar\u003e"
 +            ],
 +            [
 +              "{{\"Cathal Garvey \u0026amp;amp; The Sunshine Band \u0026amp;lt;cathal@foo.bar\u0026amp;gt;\" | htmlUnescape | htmlUnescape }}",
 +              "Cathal Garvey \u0026amp; The Sunshine Band \u0026lt;cathal@foo.bar\u0026gt;"
 +            ],
 +            [
 +              "{{ htmlUnescape \"Cathal Garvey \u0026amp; The Sunshine Band \u0026lt;cathal@foo.bar\u0026gt;\" | htmlEscape | safeHTML }}",
 +              "Cathal Garvey \u0026amp; The Sunshine Band \u0026lt;cathal@foo.bar\u0026gt;"
 +            ]
 +          ]
 +        },
 +        "Highlight": {
 +          "Description": "Highlight returns a copy of s as an HTML string with syntax\nhighlighting applied.",
 +          "Args": [
 +            "s",
 +            "lang",
 +            "opts"
 +          ],
 +          "Aliases": [
 +            "highlight"
 +          ],
 +          "Examples": []
 +        },
 +        "Markdownify": {
 +          "Description": "Markdownify renders a given input from Markdown to HTML.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "markdownify"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ .Title | markdownify}}",
 +              "\u003cstrong\u003eBatMan\u003c/strong\u003e"
 +            ]
 +          ]
 +        },
 +        "Plainify": {
 +          "Description": "Plainify returns a copy of s with all HTML tags removed.",
 +          "Args": [
 +            "s"
 +          ],
 +          "Aliases": [
 +            "plainify"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ plainify  \"Hello \u003cstrong\u003eworld\u003c/strong\u003e, gophers!\" }}",
 +              "Hello world, gophers!"
 +            ]
 +          ]
 +        },
 +        "Remarshal": {
 +          "Description": "Remarshal is used in the Hugo documentation to convert configuration\nexamples from YAML to JSON, TOML (and possibly the other way around).\nThe is primarily a helper for the Hugo docs site.\nIt is not a general purpose YAML to TOML converter etc., and may\nchange without notice if it serves a purpose in the docs.\nFormat is one of json, yaml or toml.",
 +          "Args": [
 +            "format",
 +            "data"
 +          ],
 +          "Aliases": null,
 +          "Examples": [
 +            [
 +              "{{ \"title = \\\"Hello World\\\"\" | transform.Remarshal \"json\" | safeHTML }}",
 +              "{\n   \"title\": \"Hello World\"\n}\n"
 +            ]
 +          ]
 +        }
 +      },
 +      "urls": {
 +        "AbsLangURL": {
 +          "Description": "AbsLangURL takes a given string and converts it to an absolute URL according\nto a page's position in the project directory structure and the current\nlanguage.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "absLangURL"
 +          ],
 +          "Examples": []
 +        },
 +        "AbsURL": {
 +          "Description": "AbsURL takes a given string and converts it to an absolute URL.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "absURL"
 +          ],
 +          "Examples": []
 +        },
++        "Anchorize": {
++          "Description": "Anchorize creates sanitized anchor names that are compatible with Blackfriday.",
++          "Args": [
++            "a"
++          ],
++          "Aliases": [
++            "anchorize"
++          ],
++          "Examples": [
++            [
++              "{{ \"This is a title\" | anchorize }}",
++              "this-is-a-title"
++            ]
++          ]
++        },
 +        "Parse": {
 +          "Description": "",
 +          "Args": null,
 +          "Aliases": null,
 +          "Examples": null
 +        },
 +        "Ref": {
 +          "Description": "Ref returns the absolute URL path to a given content item.",
 +          "Args": [
 +            "in",
 +            "refs"
 +          ],
 +          "Aliases": [
 +            "ref"
 +          ],
 +          "Examples": []
 +        },
 +        "RelLangURL": {
 +          "Description": "RelLangURL takes a given string and prepends the relative path according to a\npage's position in the project directory structure and the current language.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "relLangURL"
 +          ],
 +          "Examples": []
 +        },
 +        "RelRef": {
 +          "Description": "RelRef returns the relative URL path to a given content item.",
 +          "Args": [
 +            "in",
 +            "refs"
 +          ],
 +          "Aliases": [
 +            "relref"
 +          ],
 +          "Examples": []
 +        },
 +        "RelURL": {
 +          "Description": "RelURL takes a given string and prepends the relative path according to a\npage's position in the project directory structure.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "relURL"
 +          ],
 +          "Examples": []
 +        },
 +        "URLize": {
 +          "Description": "URLize returns the given argument formatted as URL.",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "urlize"
 +          ],
 +          "Examples": []
 +        }
 +      }
 +    }
 +  }
 +}
 
--- /dev/null
- HUGO_VERSION = "0.38.2"
 +[build]
 +publish = "public"
 +command = "hugo"
 +
 +[context.production.environment]
- HUGO_VERSION = "0.38.2"
++HUGO_VERSION = "0.39"
 +HUGO_ENV = "production"
 +HUGO_ENABLEGITINFO = "true"
 +
 +[context.split1]
 +command = "hugo --enableGitInfo"
 +
 +[context.split1.environment]
- HUGO_VERSION = "0.38.2"
++HUGO_VERSION = "0.39"
 +HUGO_ENV = "production"
 +
 +[context.deploy-preview]
 +command = "hugo -b $DEPLOY_PRIME_URL"
 +
 +[context.deploy-preview.environment]
- HUGO_VERSION = "0.38.2"
++HUGO_VERSION = "0.39"
 +
 +[context.branch-deploy]
 +command = "hugo -b $DEPLOY_PRIME_URL"
 +
 +[context.branch-deploy.environment]
++HUGO_VERSION = "0.39"
 +
 +[context.next.environment]
 +HUGO_ENABLEGITINFO = "true"
 +