2013-07-06 23:36:30 +00:00
---
2014-05-29 22:42:05 +00:00
aliases:
- /doc/configuration/
date: 2013-07-01
linktitle: Configuration
2014-04-23 07:00:11 +00:00
menu:
main:
2014-05-29 22:42:05 +00:00
parent: getting started
next: /overview/source-directory
notoc: true
prev: /overview/usage
title: Configuring Hugo
weight: 40
2013-07-08 21:57:01 +00:00
---
2013-07-04 15:32:55 +00:00
The directory structure and templates provide the majority of the
2014-09-03 04:12:26 +00:00
configuration for a site. In fact, a config file isn't even needed for many
2014-05-27 22:32:57 +00:00
websites since the defaults follow commonly used patterns.
2013-07-04 15:32:55 +00:00
2013-07-12 02:04:57 +00:00
Hugo expects to find the config file in the root of the source directory and
2014-09-03 04:12:26 +00:00
will look there first for a `config.toml` file. If none is present, it will
2014-05-27 22:32:57 +00:00
then look for a `config.yaml` file, followed by a `config.json` file.
2013-07-07 02:31:43 +00:00
2014-05-27 22:32:57 +00:00
The config file is a site-wide config. The config file provides directions to
hugo on how to build the site as well as site-wide parameters and menus.
2013-07-12 02:04:57 +00:00
## Examples
2014-05-27 22:32:57 +00:00
The following is an example of a typical yaml config file:
2014-05-15 13:58:55 +00:00
---
baseurl: "http://yoursite.example.com/"
...
2013-07-12 02:04:57 +00:00
2015-08-05 22:24:03 +00:00
The following is an example of a toml config file with some of the default values.
Values under `[params]` will populate the `.Site.Params` variable for use in templates:
2013-07-12 02:04:57 +00:00
2013-08-05 18:14:40 +00:00
contentdir = "content"
2013-07-12 02:04:57 +00:00
layoutdir = "layouts"
publishdir = "public"
builddrafts = false
2013-11-18 23:31:02 +00:00
baseurl = "http://yoursite.example.com/"
2014-01-03 23:36:53 +00:00
canonifyurls = true
2015-03-18 06:44:12 +00:00
2015-01-29 19:34:56 +00:00
[taxonomies]
2015-01-05 10:37:47 +00:00
category = "categories"
tag = "tags"
2015-03-18 06:44:12 +00:00
2015-01-05 10:37:47 +00:00
[params]
description = "Tesla's Awesome Hugo Site"
author = "Nikola Tesla"
2013-07-12 02:04:57 +00:00
2015-08-05 22:24:03 +00:00
Here is a yaml configuration file which sets a few more options:
2013-11-18 23:31:02 +00:00
2014-05-15 13:58:55 +00:00
---
baseurl: "http://yoursite.example.com/"
title: "Yoyodyne Widget Blogging"
2014-09-27 03:44:09 +00:00
footnotereturnlinkcontents: "↩"
2014-05-15 13:58:55 +00:00
permalinks:
post: /:year/:month/:title/
params:
Subtitle: "Spinning the cogs in the widgets"
AuthorName: "John Doe"
GitHubUser: "spf13"
ListOfFoo:
- "foo1"
- "foo2"
SidebarRecentLimit: 5
...
2014-05-27 22:32:57 +00:00
2015-02-16 19:43:20 +00:00
## Configuration variables
Following is a list of Hugo-defined variables that you can configure and their current default values:
---
archetypedir: "archetype"
2015-09-09 05:29:04 +00:00
# hostname (and path) to the root, e.g. http://spf13.com/
2015-03-18 06:44:12 +00:00
baseURL: ""
2015-02-16 19:43:20 +00:00
# include content marked as draft
2015-03-18 06:44:12 +00:00
buildDrafts: false
2015-05-10 18:38:05 +00:00
# include content with publishdate in the future
2015-03-18 06:44:12 +00:00
buildFuture: false
2015-05-17 13:44:43 +00:00
# enable this to make all relative URLs relative to content root. Note that this does not affect absolute URLs.
2015-08-04 18:00:08 +00:00
relativeURLs: false
2015-03-18 06:44:12 +00:00
canonifyURLs: false
2015-02-16 19:43:20 +00:00
# config file (default is path/config.yaml|json|toml)
2015-03-18 06:44:12 +00:00
config: "config.toml"
2015-02-16 19:43:20 +00:00
contentdir: "content"
dataDir: "data"
defaultExtension: "html"
defaultLayout: "post"
# filesystem path to write files to
2015-03-18 06:44:12 +00:00
destination: ""
2015-02-16 19:43:20 +00:00
disableLiveReload: false
# Do not build RSS files
2015-03-18 06:44:12 +00:00
disableRSS: false
2015-02-16 19:43:20 +00:00
# Do not build Sitemap file
2015-03-18 06:44:12 +00:00
disableSitemap: false
2015-02-16 19:43:20 +00:00
# edit new content with this editor, if provided
2015-03-18 06:44:12 +00:00
editor: ""
2015-02-16 19:43:20 +00:00
footnoteAnchorPrefix: ""
footnoteReturnLinkContents: ""
languageCode: ""
layoutdir: "layouts"
# Enable Logging
2015-03-18 06:44:12 +00:00
log: false
2015-02-16 19:43:20 +00:00
# Log File path (if set, logging enabled automatically)
2015-03-18 06:44:12 +00:00
logFile: ""
2015-02-16 19:43:20 +00:00
# "yaml", "toml", "json"
2015-03-18 06:44:12 +00:00
metaDataFormat: "toml"
2015-02-16 19:43:20 +00:00
newContentEditor: ""
# Don't sync modification time of files
2015-03-18 06:44:12 +00:00
noTimes: false
2015-02-16 19:43:20 +00:00
paginate: 10
paginatePath: "page"
2015-03-18 06:44:12 +00:00
permalinks:
2015-02-16 19:43:20 +00:00
# Pluralize titles in lists using inflect
2015-03-18 06:44:12 +00:00
pluralizeListTitles: true
2015-02-16 19:43:20 +00:00
publishdir: "public"
# color-codes for highlighting derived from this style
pygmentsStyle: "monokai"
# true: use pygments-css or false: color-codes directly
2015-03-18 06:44:12 +00:00
pygmentsUseClasses: false
2015-08-06 05:39:49 +00:00
# default sitemap configuration map
sitemap:
2015-03-18 06:44:12 +00:00
# filesystem path to read files relative from
source: ""
2015-02-16 19:43:20 +00:00
staticdir: "static"
# display memory and timing of different steps of the program
2015-03-18 06:44:12 +00:00
stepAnalysis: false
2015-02-16 19:43:20 +00:00
# theme to use (located in /themes/THEMENAME/)
2015-03-18 06:44:12 +00:00
theme: ""
2015-02-16 19:43:20 +00:00
title: ""
# if true, use /filename.html instead of /filename/
2015-03-18 06:44:12 +00:00
uglyURLs: false
2015-09-01 12:53:25 +00:00
# Do not make the url/path to lowercase
disablePathToLower: false
2015-02-16 19:43:20 +00:00
# verbose output
2015-03-18 06:44:12 +00:00
verbose: false
2015-02-16 19:43:20 +00:00
# verbose logging
2015-03-18 06:44:12 +00:00
verboseLog: false
2015-02-16 19:43:20 +00:00
# watch filesystem for changes and recreate as needed
2015-03-18 06:44:12 +00:00
watch: false
2015-02-16 19:43:20 +00:00
---
2015-06-03 11:46:55 +00:00
## Ignore files on build
2015-08-04 19:01:25 +00:00
The following inside `config.toml` will ignore files ending with `.foo` and `.boo` when building with `hugo` :
2015-06-03 11:46:55 +00:00
```
ignoreFiles = [ "\\.foo$", "\\.boo$" ]
```
2015-08-04 19:01:25 +00:00
The above is a list of Regular Expressions, but note the escaping of the `\` to make TOML happy.
2015-02-16 19:43:20 +00:00
2014-12-26 15:04:49 +00:00
## Configure Blackfriday rendering
[Blackfriday ](https://github.com/russross/blackfriday ) is the [Markdown ](http://daringfireball.net/projects/markdown/ ) rendering engine used in Hugo. The Blackfriday configuration in Hugo is mostly a set of sane defaults that should fit most use cases.
2015-01-25 11:08:02 +00:00
But Hugo does expose some options---as listed in the table below, matched with the corresponding flag in the Blackfriday source ([html.go](https://github.com/russross/blackfriday/blob/master/html.go) and [markdown.go ](https://github.com/russross/blackfriday/blob/master/markdown.go )):
2015-01-09 18:51:15 +00:00
< table class = "table table-bordered" >
< thead >
< tr >
< th > Flag< / th > < th > Default< / th > < th > Blackfriday flag< / th >
< / tr >
< / thead >
< tbody >
2015-08-04 19:05:48 +00:00
< tr >
< td > < code > < strong > smartypants< / strong > < / code > < / td >
< td > < code > true< / code > < / td >
< td > < code > HTML_USE_SMARTYPANTS< / code > < / td >
< / tr >
< tr >
< td class = "purpose-title" > Purpose:< / td >
2015-08-05 22:24:03 +00:00
< td class = "purpose-description" colspan = "2" > Enable/Disable smart punctuation substitutions such as smart quotes, smart dashes, etc.
May be fine-tuned with the < code > angledQuotes< / code > , < code > fractions< / code > and < code > latexDashes< / code > flags below.< / td >
2015-08-04 19:05:48 +00:00
< / tr >
2015-01-09 18:51:15 +00:00
< tr >
2015-08-04 18:34:47 +00:00
< td > < code > < strong > angledQuotes< / strong > < / code > < / td >
2015-01-09 18:51:15 +00:00
< td > < code > false< / code > < / td >
< td > < code > HTML_SMARTYPANTS_ANGLED_QUOTES< / code > < / td >
< / tr >
< tr >
< td class = "purpose-title" > Purpose:< / td >
2015-08-05 22:24:03 +00:00
< td class = "purpose-description" colspan = "2" > Enable/Disable smart angled double quotes.< br >
< small > < strong > Example:< / strong > < code > "Hugo"< / code > renders to «Hugo» instead of “Hugo”.< / small > < / td >
2015-01-09 18:51:15 +00:00
< / tr >
2015-01-24 19:37:02 +00:00
< tr >
2015-08-04 18:34:47 +00:00
< td > < code > < strong > fractions< / strong > < / code > < / td >
2015-01-24 19:37:02 +00:00
< td > < code > true< / code > < / td >
< td > < code > HTML_SMARTYPANTS_FRACTIONS< / code > < / td >
< / tr >
< tr >
< td class = "purpose-title" > Purpose:< / td >
2015-08-05 22:24:03 +00:00
< td class = "purpose-description" colspan = "2" > Enable/Disable smart fractions.< br >
< small > < strong > Example:< / strong > < code > 5/12< / code > renders to < sup > 5< / sup > ⁄ < sub > 12< / sub > (< code > < sup> 5< /sup> & frasl;< sub> 12< /sub> < / code > )< br >
2015-01-24 19:37:02 +00:00
< strong > Caveat:< / strong > Even with < code > fractions = false< / code > ,
Blackfriday would still convert 1/2, 1/4 and 3/4 to ½ (< code > & frac12;< / code > ),
¼ (< code > & frac14;< / code > ) and ¾ (< code > & frac34;< / code > ) respectively,
but only these three.< / small > < / td >
< / tr >
2015-06-28 13:27:47 +00:00
< tr >
2015-08-04 19:05:48 +00:00
< td > < code > < strong > latexDashes< / strong > < / code > < / td >
< td > < code > true< / code > < / td >
< td > < code > HTML_SMARTYPANTS_LATEX_DASHES< / code > < / td >
2015-06-28 13:27:47 +00:00
< / tr >
< tr >
< td class = "purpose-title" > Purpose:< / td >
2015-08-05 22:24:03 +00:00
< td class = "purpose-description" colspan = "2" > Choose between LaTeX-style smart dashes and “conventional” smart dashes.< br >
< strong > If < code > true< / code > ,< / strong > < code > --< / code > is translated into “– ” (< code > & ndash;< / code > ), and < code > ---< / code > is translated into “— ” (< code > & mdash;< / code > ).< br >
< strong > If < code > false< / code > ,< / strong > < code > --< / code > is translated into “— ” (< code > & mdash;< / code > ), whereas a < em > spaced< / em > single hyphen between two words is turned into an en dash, e.g. < code > 12 June - 3 July< / code > becomes < code > 12 June & ndash; 3 July< / code > .< / td >
2015-06-28 13:27:47 +00:00
< / tr >
2015-08-05 22:24:03 +00:00
< tr style = "height: 0.5em;" > < / tr >
2015-08-04 19:05:48 +00:00
2015-06-28 13:27:47 +00:00
< tr >
2015-08-04 19:05:48 +00:00
< td > < code > < strong > hrefTargetBlank< / strong > < / code > < / td >
< td > < code > false< / code > < / td >
< td > < code > HTML_HREF_TARGET_BLANK< / code > < / td >
2015-06-28 13:27:47 +00:00
< / tr >
< tr >
< td class = "purpose-title" > Purpose:< / td >
2015-08-05 22:24:03 +00:00
< td class = "purpose-description" colspan = "2" > Open external links in a new window/tab.< / td >
2015-06-28 13:27:47 +00:00
< / tr >
2015-01-09 18:51:15 +00:00
< tr >
2015-08-04 18:34:47 +00:00
< td > < code > < strong > plainIdAnchors< / strong > < / code > < / td >
2015-01-09 18:51:15 +00:00
< td > < code > false< / code > < / td >
< td > < code > FootnoteAnchorPrefix< / code > and < code > HeaderIDSuffix< / code > < / td >
< / tr >
< tr >
< td class = "purpose-title" > Purpose:< / td >
2015-08-05 22:24:03 +00:00
< td class = "purpose-description" colspan = "2" > If < code > true< / code > , then header and footnote IDs are generated without the document ID.< br >
< small > < strong > Example:< / strong > < code > #my-header< / code > instead of < code > #my-header:bec3ed8ba720b9073ab75abcf3ba5d97< / code > .< / small > < / td >
2015-01-09 18:51:15 +00:00
< / tr >
2015-01-25 11:08:02 +00:00
2015-08-05 22:24:03 +00:00
< tr style = "height: 0.5em;" > < / tr >
2015-08-04 19:05:48 +00:00
2015-01-25 11:08:02 +00:00
< tr >
2015-08-04 18:34:47 +00:00
< td > < code > < strong > extensions< / strong > < / code > < / td >
2015-01-25 11:08:02 +00:00
< td > < code > []< / code > < / td >
< td > < code > EXTENSION_*< / code > < / td >
< / tr >
< tr >
< td class = "purpose-title" > Purpose:< / td >
2015-08-05 22:24:03 +00:00
< td class = "purpose-description" colspan = "2" > Use non-default additional extensions.< br >
< small > < strong > Example:< / strong > Add < code > "hardLineBreak"< / code > to use < code > EXTENSION_HARD_LINE_BREAK< / code > .< / small > < / td >
2015-01-25 11:08:02 +00:00
< / tr >
2015-04-16 01:54:10 +00:00
< tr >
2015-08-04 18:34:47 +00:00
< td > < code > < strong > extensionsmask< / strong > < / code > < / td >
2015-04-16 01:54:10 +00:00
< td > < code > []< / code > < / td >
< td > < code > EXTENSION_*< / code > < / td >
< / tr >
< tr >
< td class = "purpose-title" > Purpose:< / td >
2015-08-05 22:24:03 +00:00
< td class = "purpose-description" colspan = "2" > Extensions in this option won't be loaded.< br >
< small > < strong > Example:< / strong > Add < code > "autoHeaderIds"< / code > to disable < code > EXTENSION_AUTO_HEADER_IDS< / code > .< / small > < / td >
2015-04-16 01:54:10 +00:00
< / tr >
2015-01-09 18:51:15 +00:00
< / tbody >
< / table >
2014-12-26 15:04:49 +00:00
2015-01-18 20:25:20 +00:00
**Note** that these flags must be grouped under the `blackfriday` key and can be set on **both site and page level** . If set on page, it will override the site setting. Example:
2014-12-26 15:04:49 +00:00
2015-01-18 20:25:20 +00:00
< table class = "table" >
2015-01-28 02:17:09 +00:00
< thead >
2015-01-18 20:25:20 +00:00
< tr >
< th > TOML< / th > < th > YAML< / th >
< / tr >
2015-01-28 02:17:09 +00:00
< / thead >
< tbody >
2015-08-04 18:34:47 +00:00
< tr style = "vertical-align: top;" >
< td style = "width: 50%;" > < pre > < code > [blackfriday]
2015-01-24 19:37:02 +00:00
angledQuotes = true
fractions = false
plainIdAnchors = true
2015-01-25 11:08:02 +00:00
extensions = ["hardLineBreak"]
2015-01-18 20:25:20 +00:00
< / code > < / pre > < / td >
< td > < pre > < code > blackfriday:
angledQuotes: true
2015-01-24 19:37:02 +00:00
fractions: false
2015-01-18 20:25:20 +00:00
plainIdAnchors: true
2015-01-25 11:08:02 +00:00
extensions:
- hardLineBreak
2015-01-18 20:25:20 +00:00
< / code > < / pre > < / td >
< / tr >
2015-01-28 02:17:09 +00:00
< / tbody >
2015-01-18 20:25:20 +00:00
< / table >
2014-12-26 15:04:49 +00:00
2014-08-15 18:39:12 +00:00
## Notes
2015-01-28 02:17:09 +00:00
Config changes are not reflected with [LiveReload ](/extras/livereload/ ).
2014-08-15 18:39:12 +00:00
Please restart `hugo server --watch` whenever you make a config change.