Merge commit 'e81208265bb3cdb7606d051a23d83aeebcb7d34d'
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sun, 6 Aug 2017 15:24:51 +0000 (17:24 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sun, 6 Aug 2017 15:24:51 +0000 (17:24 +0200)
21 files changed:
1  2 
docs/config.toml
docs/content/content-management/cross-references.md
docs/content/content-management/front-matter.md
docs/content/content-management/menus.md
docs/content/content-management/organization.md
docs/content/content-management/taxonomies.md
docs/content/content-management/urls.md
docs/content/contribute/development.md
docs/content/contribute/themes.md
docs/content/functions/abslangurl.md
docs/content/functions/absurl.md
docs/content/functions/math.md
docs/content/functions/relLangURL.md
docs/content/functions/relurl.md
docs/content/functions/title.md
docs/content/getting-started/quick-start.md
docs/content/templates/output-formats.md
docs/content/templates/rss.md
docs/content/variables/page.md
docs/content/variables/site.md
docs/data/docs.json

index 61df5b8739a7ba2d4fe274ad3979201fd812d2db,0000000000000000000000000000000000000000..2671675566dd51b385ef4d8347086ac0be12d4ca
mode 100644,000000..100644
--- /dev/null
@@@ -1,234 -1,0 +1,236 @@@
 +baseURL = "https://gohugo.io/"
 +paginate =  100
 +defaultContentLanguage = "en"
 +enableEmoji = true
 +# Set the unicode character used for the "return" link in page footnotes.
 +footnotereturnlinkcontents = "↩"
 +languageCode = "en-us"
 +metaDataFormat = "yaml"
 +title = "Hugo"
 +theme = "gohugoioTheme"
 +
 +googleAnalytics = "UA-7131036-4"
 +
 +pluralizeListTitles = false
 +
 +# We do redirects via Netlify's _redirects file, generated by Hugo (see "outputs" below).
 +disableAliases = true
 +
 +
 +# Highlighting config (Pygments)
 +# It is (currently) not in use, but you can do ```go in a content file if you want to.
 +pygmentsCodeFences = true
 +
 +# See https://help.farbox.com/pygments.html
 +pygmentsStyle = "friendly"
 +
 +[outputs]
 +home = [ "HTML", "RSS", "REDIR", "HEADERS" ]
 +section = [ "HTML", "RSS"]
 +
 +[mediaTypes]
 +[mediaTypes."text/netlify"]
 +suffix = ""
 +delimiter = ""
 +
 +[outputFormats]
 +[outputFormats.REDIR]
 +mediatype = "text/netlify"
 +baseName = "_redirects"
 +isPlainText = true
 +notAlternative = true
 +[outputFormats.HEADERS]
 +mediatype = "text/netlify"
 +baseName = "_headers"
 +isPlainText = true
 +notAlternative = true
 +
 +[social]
 +twitter = "GoHugoIO"
 +
 +#CUSTOM PARAMS
 +[params]
 +  description = "The world’s fastest framework for building websites"
 +  ## Used for views in rendered HTML (i.e., rather than using the .Hugo variable)
 +  release = "Hugo-Next"
 +  ## Setting this to true will add a "noindex" to *EVERY* page on the site
 +  removefromexternalsearch = false
 +  ## Gh repo for site footer (include trailing slash)
 +  ghrepo = "https://github.com/gohugoio/hugoDocs/"
++  ## GH Repo for filing a new issue
++  github_repo = "https://github.com/gohugoio/hugo/issues/new"
 +  ### Edit content repo (set to automatically enter "edit" mode; this is good for "improve this page" links)
 +  ghdocsrepo = "https://github.com/gohugoio/hugoDocs/tree/master/docs"
 +  ## Gitter URL
 +  gitter = "https://gitter.im/spf13/hugo"
 +  ## Discuss Forum URL
 +  forum = "https://discourse.gohugo.io/"
 +  ## Google Tag Manager
 +  gtmid = ""
 +
 +  # First one is picked as the Twitter card image if not set on page.
 +  images = ["images/gohugoio-card.png"]
 +
 +  flex_box_interior_classes = "flex-auto w-100 w-40-l mr3 mb3 bg-white ba b--moon-gray nested-copy-line-height"
 +
 +  #sidebar_direction = "sidebar_left"
 +
 +# MARKDOWN
 +## Configuration for BlackFriday markdown parser: https://github.com/russross/blackfriday
 +[blackfriday]
 +      plainIDAnchors = true
 +      hrefTargetBlank = true
 +  angledQuotes = false
 +  latexDashes = true
 +
 +## As of v0.20, all content files include a default "categories" value that's the same as the section. This was a cheap future-proofing method and should/could be changed accordingly.
 +[taxonomies]
 +  category = "categories"
 +
 +# High level items
 +
 +[[menu.docs]]
 +  name = "About Hugo"
 +  weight = 1
 +  identifier = "about"
 +  url = "/about/"
 +
 +[[menu.docs]]
 +  name = "Getting Started"
 +  weight = 5
 +  identifier = "getting-started"
 +  url = "/getting-started/"
 +
 +
 +[[menu.docs]]
 +  name = "Themes"
 +  weight = 15
 +  identifier = "themes"
 +  post = "break"
 +  url = "/themes/"
 +
 +# Core Menus
 +
 +[[menu.docs]]
 +  name = "Content Management"
 +  weight = 20
 +  identifier = "content-management"
 +  post = "expanded"
 +  url = "/content-management/"
 +
 +[[menu.docs]]
 +  name = "Templates"
 +  weight = 25
 +  identifier = "templates"
 +
 +  url = "/templates/"
 +
 +[[menu.docs]]
 +  name = "Functions"
 +  weight = 30
 +  identifier = "functions"
 +  url = "/functions/"
 +
 +[[menu.docs]]
 +  name = "Variables"
 +  weight = 35
 +  identifier = "variables"
 +  url = "/variables/"
 +
 +[[menu.docs]]
 +  name = "CLI"
 +  weight = 40
 +  post = "break"
 +  identifier = "commands"
 +  url = "/commands/"
 +
 +
 +
 +# LOW LEVEL ITEMS
 +
 +
 +[[menu.docs]]
 +  name = "Troubleshooting"
 +  weight = 60
 +  identifier = "troubleshooting"
 +  url = "/troubleshooting/"
 +
 +[[menu.docs]]
 +  name = "Tools"
 +  weight = 70
 +  identifier = "tools"
 +  url = "/tools/"
 +
 +[[menu.docs]]
 +  name = "Hosting & Deployment"
 +  weight = 80
 +  identifier = "hosting-and-deployment"
 +  url = "/hosting-and-deployment/"
 +
 +[[menu.docs]]
 +  name = "Contribute"
 +  weight = 100
 +  post = "break"
 +  identifier = "contribute"
 +  url = "/contribute/"
 +
 +#[[menu.docs]]
 +#  name = "Tags"
 +#  weight = 120
 +#  identifier = "tags"
 +#  url = "/tags/"
 +
 +
 +# [[menu.docs]]
 +#   name = "Categories"
 +#   weight = 140
 +#   identifier = "categories"
 +#   url = "/categories/"
 +
 +######## QUICKLINKS
 +
 +  [[menu.quicklinks]]
 +    name = "Fundamentals"
 +    weight = 1
 +    identifier = "fundamentals"
 +    url = "/tags/fundamentals/"
 +
 +
 +
 +
 +######## GLOBAL ITEMS TO BE SHARED WITH THE HUGO SITES
 +
 +[[menu.global]]
 +    name = "News"
 +    weight = 1
 +    identifier = "news"
 +    url = "/news/"
 +
 +  [[menu.global]]
 +    name = "Docs"
 +    weight = 5
 +    identifier = "docs"
 +    url = "/documentation/"
 +
 +  [[menu.global]]
 +    name = "Themes"
 +    weight = 10
 +    identifier = "themes"
 +    url = "https://themes.gohugo.io/"
 +
 +  # Anything with a weight > 100 gets an external icon
 +  [[menu.global]]
 +    name = "Community"
 +    weight = 150
 +    icon = true
 +    identifier = "community"
 +    post = "external"
 +    url = "https://discourse.gohugo.io/"
 +
 +
 +  [[menu.global]]
 +    name = "GitHub"
 +    weight = 200
 +    identifier = "github"
 +    post = "external"
 +    url = "https://github.com/gohugoio/hugo"
index 7ee81f3dbd2a96902781fb9acf2ece0b2426ea47,0000000000000000000000000000000000000000..358152672fae0ab283d2a3776e82783e80c89166
mode 100644,000000..100644
--- /dev/null
@@@ -1,123 -1,0 +1,123 @@@
- * `{{</* ref "blog/post.md" */>}}` => `http://example.com/blog/post/`
- * `{{</* ref "post.md#tldr" */>}}` => `http://example.com/blog/post/#tldr:caffebad`
 +---
 +title: Cross References
 +description: Hugo makes it easy to link documents together.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-03-31
 +categories: [content management]
 +#tags: ["cross references","references", "anchors", "urls"]
 +menu:
 +  docs:
 +    parent: "content-management"
 +    weight: 100
 +weight: 100   #rem
 +aliases: [/extras/crossreferences/]
 +toc: true
 +---
 +
 +
 + The `ref` and `relref` shortcodes link documents together, both of which are [built-in Hugo shortcodes][]. These shortcodes are also used to provide links to headings inside of your content, whether across documents or within a document. The only difference between `ref` and `relref` is whether the resulting URL is absolute (`http://1.com/about/`) or relative (`/about/`), respectively.
 +
 +## Use `ref` and `relref`
 +
 +```
 +{{</* ref "document" */>}}
 +{{</* ref "#anchor" */>}}
 +{{</* ref "document#anchor" */>}}
 +{{</* relref "document" */>}}
 +{{</* relref "#anchor" */>}}
 +{{</* relref "document#anchor" */>}}
 +```
 +
 +The single parameter to `ref` is a string with a content `documentname` (e.g., `about.md`) with or without an appended in-document `anchor` (`#who`) without spaces.
 +
 +### Document Names
 +
 +The `documentname` is the name of a document, including the format extension; this may be just the filename, or the relative path from the `content/` directory. With a document `content/blog/post.md`, either format will produce the same result:
 +
 +```
 +{{</* relref "blog/post.md" */>}} => `/blog/post/`
 +{{</* relref "post.md" */>}} => `/blog/post/`
 +```
 +
 +If you have the same filename used across multiple sections, you should only use the relative path format; otherwise, the behavior will be `undefined`. This is best illustrated with an example `content` directory:
 +
 +```
 +.
 +└── content
 +    ├── events
 +    │   └── my-birthday.md
 +    ├── galleries
 +    │   └── my-birthday.md
 +    ├── meta
 +    │   └── my-article.md
 +    └── posts
 +        └── my-birthday.md
 +```
 +
 +To be sure to get the correct reference in this case, use the full path: 
 +
 +{{< code file="content/meta/my-article.md" copy="false" >}}
 +{{</* relref "events/my-birthday.md" */>}} => /events/my-birthday/
 +{{< /code >}}
 +
 +{{< todo >}}Remove this warning when https://github.com/gohugoio/hugo/issues/3703 is released.{{< /todo >}}
 +
 +A relative document name must *not* begin with a slash (`/`).
 +```
 +{{</* relref "/events/my-birthday.md" */>}} => ""
 +```
 +
 +### With Multiple Output Formats
 +
 +If the page exists in multiple [output formats][], `ref` or `relref` can be used with a output format name:
 +
 +```
 + [Neat]({{</* ref "blog/neat.md" "amp" */>}})
 +```
 +
 +### Anchors
 +
 +When an `anchor` is provided by itself, the current page’s unique identifier will be appended; when an `anchor` is provided appended to `documentname`, the found page's unique identifier will be appended:
 +
 +```
 +{{</* relref "#anchors" */>}} => #anchors:9decaf7
 +{{</* relref "about-hugo/hugo-features.md#content" */>}} => /blog/post/#who:badcafe
 +```
 +
 +The above examples render as follows for this very page as well as a reference to the "Content" heading in the Hugo docs features pageyoursite
 +
 +```
 +{{</* relref "#who" */>}} => #who:9decaf7
 +{{</* relref "blog/post.md#who" */>}} => /blog/post/#who:badcafe
 +```
 +
 +More information about document unique identifiers and headings can be found [below]({{< ref "#hugo-heading-anchors" >}}).
 +
 +### Examples
 +
++* `{{</* ref "blog/post.md" */>}}` => `https://example.com/blog/post/`
++* `{{</* ref "post.md#tldr" */>}}` => `https://example.com/blog/post/#tldr:caffebad`
 +* `{{</* relref "post.md" */>}}` => `/blog/post/`
 +* `{{</* relref "blog/post.md#tldr" */>}}` => `/blog/post/#tldr:caffebad`
 +* `{{</* ref "#tldr" */>}}` => `#tldr:badcaffe`
 +* `{{</* relref "#tldr" */>}}` => `#tldr:badcaffe`
 +
 +## Hugo Heading Anchors
 +
 +When using Markdown document types, Hugo generates heading anchors automatically. The generated anchor for this section is `hugo-heading-anchors`. Because the heading anchors are generated automatically, Hugo takes some effort to ensure that heading anchors are unique both inside a document and across the entire site.
 +
 +Ensuring heading uniqueness across the site is accomplished with a unique identifier for each document based on its path. Unless a document is renamed or moved between sections *in the filesystem*, the unique identifier for the document will not change: `blog/post.md` will always have a unique identifier of `81df004c333b392d34a49fd3a91ba720`.
 +
 +`ref` and `relref` were added so you can make these reference links without having to know the document’s unique identifier. (The links in document tables of contents are automatically up-to-date with this value.)
 +
 +```
 +{{</* relref "content-management/cross-references.md#hugo-heading-anchors" */>}}
 +/content-management/cross-references/#hugo-heading-anchors:77cd9ea530577debf4ce0f28c8dca242
 +```
 +
 +
 +[built-in Hugo shortcodes]: /content-management/shortcodes/#using-the-built-in-shortcodes
 +[lists]: /templates/lists/
 +[output formats]: /templates/output-formats/
 +[shortcode]: /content-management/shortcodes/
index 070328670e6e1d16ceb7196ad8197a48ce409eaf,0000000000000000000000000000000000000000..22c1eb110b784ef44d7952a9d72fd71f6a9ca63a
mode 100644,000000..100644
--- /dev/null
@@@ -1,198 -1,0 +1,198 @@@
- #tags: [ ".vimrc", "plugins", "spf13-vim", "vim" ]
 +---
 +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]
 +#tags: ["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.
 +
 +## 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.
 +
 +### TOML Example
 +
 +```
 ++++
 +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"
 ++++
 +```
 +
 +### YAML Example
 +
 +```
 +---
 +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" ]
 +lastmod: 2015-12-23
 +date: "2012-04-06"
 +categories:
 +  - "Development"
 +  - "VIM"
 +slug: "spf13-vim-3-0-release-and-new-website"
 +---
 +```
 +
 +### JSON Example
 +
 +```
 +{
 +    "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"
 +}
 +```
 +
 +## 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.
 +
 +`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.
 +
 +`date`
 +: the datetime at which the content was created; note this value is auto-populated according to Hugo's built-in [archetype][].
 +
 +`description`
 +: the description for the content.
 +
 +`draft`
 +: if `true`, the content will not be rendered unless the `--buildDrafts` flag is passed to the `hugo` command.
 +
 +`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`
 +: if `true`, Hugo will explicitly treat the content as a CJK language; both `.Summary` and `.WordCount` work properly in CJK languages.
 +
 +`keywords`
 +: the meta keywords for the content.
 +
 +`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]
 +
 +`lastmod`
 +: the datetime at which the content was last modified.
 +
 +`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].
 +
 +`markup`
 +: **experimental**; specify `"rst"` for reStructuredText (requires`rst2html`) or `"md"` (default) for Markdown.
 +
 +`outputs`
 +: allows you to specify output formats specific to the content. See [output formats][outputs].
 +
 +`publishDate`
 +: if in the future, content will not be rendered unless the `--buildFuture` flag is passed to `hugo`.
 +
 +`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.
 +
 +`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`
 +: the title for the content.
 +
 +`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.
 +
 +`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].
 +
 +{{% 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.
 +
 +```
 +include_toc: true
 +show_comments: false
 +```
 +
 +These two user-defined fields can then be accessed via `.Params.include_toc` and `.Params.show_comments`, respectively. The [Variables][variables] section provides more information on using Hugo's page- and site-level variables in your templates.
 +
 +
 +## 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"
 +[json]: /documents/ecma-404-json-spec.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"
 +[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"
index 7c877afc8b379217c542a5e4e1cfde18be0a0481,0000000000000000000000000000000000000000..364867c675c2ba57365a3952520568515f27ba96
mode 100644,000000..100644
--- /dev/null
@@@ -1,179 -1,0 +1,179 @@@
- The URLs must be relative to the context root. If the `baseURL` is `http://example.com/mysite/`, then the URLs in the menu must not include the context root `mysite`. Using an absolute URL will overide the baseURL. If the value used for `URL` in the above example is `http://subdomain.example.com/`, the output will be `http://subdomain.example.com`.
 +---
 +title: Menus
 +linktitle: Menus
 +description: Hugo has a simple yet powerful menu system.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-03-31
 +categories: [content management]
 +#tags: [menus]
 +draft: false
 +menu:
 +  docs:
 +    parent: "content-management"
 +    weight: 120
 +weight: 120   #rem
 +aliases: [/extras/menus/]
 +toc: true
 +---
 +
 +{{% note "Lazy Blogger"%}}
 +If all you want is a simple menu for your sections, see the ["Section Menu for Lazy Bloggers" in Menu Templates](/templates/menu-templates/#section-menu-for-lazy-blogger).
 +{{% /note %}}
 +
 +You can do this:
 +
 +* Place content in one or many menus
 +* Handle nested menus with unlimited depth
 +* Create menu entries without being attached to any content
 +* Distinguish active element (and active branch)
 +
 +## What is a Menu in Hugo?
 +
 +A **menu** is a named array of menu entries accessible by name via the [`.Site.Menus` site variable][sitevars]. For example, you can access your site's `main` menu via `.Site.Menus.main`.
 +
 +{{% note "Menus on Multilingual Sites" %}}
 +If you make use of the [multilingual feature](/content-management/multilingual/), you can define language-independent menus.
 +{{% /note %}}
 +
 +A menu entry has the following properties (i.e., variables) available to it:
 +
 +`.URL`
 +: string
 +
 +`.Name`
 +: string
 +
 +`.Menu`
 +: string
 +
 +`.Identifier`
 +: string
 +
 +`.Pre`
 +: template.HTML
 +
 +`.Post`
 +: template.HTML
 +
 +`.Weight`
 +: int
 +
 +`.Parent`
 +: string
 +
 +`.Children`
 +: Menu
 +
 +Note that menus also have the following functions available as well:
 +
 +`.HasChildren`
 +: boolean
 +
 +Additionally, there are some relevant functions available to menus on a page:
 +
 +`.IsMenuCurrent`
 +: (menu string, menuEntry *MenuEntry ) boolean
 +
 +`.HasMenuCurrent`
 +: (menu string, menuEntry *MenuEntry) boolean
 +
 +## Add content to menus
 +
 +Hugo allows you to add content to a menu via the content's [front matter](/content-management/front-matter/).
 +
 +### Simple
 +
 +If all you need to do is add an entry to a menu, the simple form works well.
 +
 +#### A Single Menu
 +
 +```
 +---
 +menu: "main"
 +---
 +```
 +
 +#### Multiple Menus
 +
 +```
 +---
 +menu: ["main", "footer"]
 +---
 +```
 +
 +#### Advanced
 +
 +
 +```
 +---
 +menu:
 +  docs:
 +    parent: 'extras'
 +    weight: 20
 +---
 +```
 +
 +## Add Non-content Entries to a Menu
 +
 +You can also add entries to menus that aren’t attached to a piece of content. This takes place in your Hugo project's [`config` file][config].
 +
 +Here’s an example snippet pulled from a `config.toml`:
 +
 +{{< code file="config.toml" >}}
 +[[menu.main]]
 +    name = "about hugo"
 +    pre = "<i class='fa fa-heart'></i>"
 +    weight = -110
 +    identifier = "about"
 +    url = "/about/"
 +[[menu.main]]
 +    name = "getting started"
 +    pre = "<i class='fa fa-road'></i>"
 +    weight = -100
 +    url = "/getting-started/"
 +{{< /code >}}
 +
 +Here's the equivalent snippet in a `config.yaml`:
 +
 +{{< code file="config.yml" >}}
 +---
 +menu:
 +  docs:
 +      - Name: "about hugo"
 +        Pre: "<i class='fa fa-heart'></i>"
 +        Weight: -110
 +        Identifier: "about"
 +        URL: "/about/"
 +      - Name: "getting started"
 +        Pre: "<i class='fa fa-road'></i>"
 +        Weight: -100
 +        URL: "/getting-started/"
 +---
 +{{< /code >}}
 +
 +{{% note %}}
++The URLs must be relative to the context root. If the `baseURL` is `https://example.com/mysite/`, then the URLs in the menu must not include the context root `mysite`. Using an absolute URL will overide the baseURL. If the value used for `URL` in the above example is `https://subdomain.example.com/`, the output will be `https://subdomain.example.com`.
 +{{% /note %}}
 +
 +## Nesting
 + 
 +All nesting of content is done via the `parent` field.
 +
 +The parent of an entry should be the identifier of another entry. The identifier should be unique (within a menu).
 +
 +The following order is used to determine an Identifier:
 +
 +`.Name > .LinkTitle > .Title`
 +
 +This means that `.Title` will be used unless `.LinkTitle` is present, etc. In practice, `.Name` and `.Identifier` are only used to structure relationships and therefore never displayed.
 +
 +In this example, the top level of the menu is defined in your [site `config` file][config]). All content entries are attached to one of these entries via the `.Parent` field.
 +
 +## Render Menus
 +
 +See [Menu Templates](/templates/menu-templates/) for information on how to render your site menus within your templates.
 +
 +[config]: /getting-started/configuration/
 +[multilingual]: /content-management/multilingual/
 +[sitevars]: /variables/
index 33780c0ebdf44371dadeace7f94b96c98e4f40ec,0000000000000000000000000000000000000000..95fd3562a2fa59803f2d026f0a91b81e82e87b9f
mode 100644,000000..100644
--- /dev/null
@@@ -1,241 -1,0 +1,241 @@@
-     |   └── _index.md  // <- http://example.com/about/
 +---
 +title: Content Organization
 +linktitle: Organization
 +description: Hugo assumes that the same structure that works to organize your source content is used to organize the rendered site.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +categories: [content management,fundamentals]
 +#tags: [sections,content,organization]
 +menu:
 +  docs:
 +    parent: "content-management"
 +    weight: 10
 +weight: 10    #rem
 +draft: false
 +aliases: [/content/sections/]
 +toc: true
 +---
 +
 +{{% note %}}
 +This section is not updated with the new nested sections support in Hugo 0.24, see https://github.com/gohugoio/hugoDocs/issues/36
 +{{% /note %}}
 +{{% todo %}}
 +See above
 +{{% /todo %}}
 +
 +## Organization of Content Source
 +
 +In Hugo, your content should be organized in a manner that reflects the rendered website.
 +
 +While Hugo supports content nested at any level, the top levels (i.e. `content/<DIRECTORIES>`) are special in Hugo and are considered the content [sections][]. Without any additional configuration, the following will just work:
 +
 +```
 +.
 +└── content
 +    └── about
-     |   ├── firstpost.md   // <- http://example.com/post/firstpost/
++    |   └── _index.md  // <- https://example.com/about/
 +    ├── post
-     |   |   └── ness.md  // <- http://example.com/post/happy/ness/
-     |   └── secondpost.md  // <- http://example.com/post/secondpost/
++    |   ├── firstpost.md   // <- https://example.com/post/firstpost/
 +    |   ├── happy
-         ├── first.md       // <- http://example.com/quote/first/
-         └── second.md      // <- http://example.com/quote/second/
++    |   |   └── ness.md  // <- https://example.com/post/happy/ness/
++    |   └── secondpost.md  // <- https://example.com/post/secondpost/
 +    └── quote
- The following demonstrates the relationships between your content organization and the output URL structure for your Hugo website when it renders. These examples assume you are [using pretty URLs][pretty], which is the default behavior for Hugo. The examples also assume a key-value of `baseurl = "http://example.com"` in your [site's configuration file][config].
++        ├── first.md       // <- https://example.com/quote/first/
++        └── second.md      // <- https://example.com/quote/second/
 +```
 +
 +## Path Breakdown in Hugo
 +
- http://example.com/posts/index.html
++The following demonstrates the relationships between your content organization and the output URL structure for your Hugo website when it renders. These examples assume you are [using pretty URLs][pretty], which is the default behavior for Hugo. The examples also assume a key-value of `baseurl = "https://example.com"` in your [site's configuration file][config].
 +
 +### Index Pages: `_index.md`
 +
 +`_index.md` has a special role in Hugo. It allows you to add front matter and content to your [list templates][lists] as of v0.18. These templates include those for [section templates][], [taxonomy templates][], [taxonomy terms templates][], and your [homepage template][]. In your templates, you can grab information from `_index.md` using the [`.Site.GetPage` function][getpage].
 +
 +You can keep one `_index.md` for your homepage and one in each of your content sections, taxonomies, and taxonomy terms. The following shows typical placement of an `_index.md` that would contain content and front matter for a `posts` section list page on a Hugo website:
 +
 +
 +```
 +.         url
 +.       ⊢--^-⊣
 +.        path    slug
 +.       ⊢--^-⊣⊢---^---⊣
 +.           filepath
 +.       ⊢------^------⊣
 +content/posts/_index.md
 +```
 +
 +At build, this will output to the following destination with the associated values:
 +
 +```
 +
 +                     url ("/posts/")
 +                    ⊢-^-⊣
 +       baseurl      section ("posts")
 +⊢--------^---------⊣⊢-^-⊣
 +        permalink
 +⊢----------^-------------⊣
- http://example.com/posts/my-first-hugo-post/index.html
++https://example.com/posts/index.html
 +```
 +
 +### Single Pages in Sections
 +
 +Single content files in each of your sections are going to be rendered as [single page templates][singles]. Here is an example of a single `post` within `posts`:
 +
 +
 +```
 +                   path ("posts/my-first-hugo-post.md")
 +.       ⊢-----------^------------⊣
 +.      section        slug
 +.       ⊢-^-⊣⊢--------^----------⊣
 +content/posts/my-first-hugo-post.md
 +```
 +
 +At the time Hugo builds your site, the content will be output to the following destination:
 +
 +```
 +
 +                               url ("/posts/my-first-hugo-post/")
 +                   ⊢------------^----------⊣
 +       baseurl     section     slug
 +⊢--------^--------⊣⊢-^--⊣⊢-------^---------⊣
 +                 permalink
 +⊢--------------------^---------------------⊣
- http://example.com/events/chicago/lollapalooza/
++https://example.com/posts/my-first-hugo-post/index.html
 +```
 +
 +### Section with Nested Directories
 +
 +To continue the example, the following demonstrates destination paths for a file located at `content/events/chicago/lollapalooza.md` in the same site:
 +
 +
 +```
 +                    section
 +                    ⊢--^--⊣
 +                               url
 +                    ⊢-------------^------------⊣
 +
 +      baseURL             path        slug
 +⊢--------^--------⊣ ⊢------^-----⊣⊢----^------⊣
 +                  permalink
 +⊢----------------------^-----------------------⊣
- <!-- ### `path`
++https://example.com/events/chicago/lollapalooza/
 +```
 +
 +{{% note %}}
 +As of v0.20, Hugo does not recognize nested sections. While you can nest as many content *directories* as you'd like, any child directory of a section will still be considered the same section as that of its parents. Therefore, in the above example, `{{.Section}}` for `lollapalooza.md` is `events` and *not* `chicago`. See the [related issue on GitHub](https://github.com/gohugoio/hugo/issues/465).
 +{{% /note %}}
 +
 +## Paths Explained
 +
 +The following concepts will provide more insight into the relationship between your project's organization and the default behaviors of Hugo when building the output website.
 +
 +### `section`
 +
 +A default content type is determined by a piece of content's section. `section` is determined by the location within the project's `content` directory. `section` *cannot* be specified or overridden in front matter.
 +
 +### `slug`
 +
 +A content's `slug` is either `name.extension` or `name/`. The value for `slug` is determined by
 +
 +* the name of the content file (e.g., `lollapalooza.md`) OR
 +* front matter overrides
 +
 +### `path`
 +
 +A content's `path` is determined by the section's path to the file. The file `path`
 +
 +* is based on the path to the content's location AND
 +* does not include the slug
 +
 +### `url`
 +
 +The `url` is the relative URL for the piece of content. The `url`
 +
 +* is based on the content's location within the directory structure OR
 +* is defined in front matter and *overrides all the above*
 +
 +## Override Destination Paths via Front Matter
 +
 +Hugo believes that you organize your content with a purpose. The same structure that works to organize your source content is used to organize the rendered site. As displayed above, the organization of the source content will be mirrored in the destination.
 +
 +There are times where you may need more control over your content. In these cases, there are fields that can be specified in the front matter to determine the destination of a specific piece of content.
 +
 +The following items are defined in this order for a specific reason: items explained further down in the list will override earlier items, and not all of these items can be defined in front matter:
 +
 +### `filename`
 +
 +This isn't in the front matter, but is the actual name of the file minus the extension. This will be the name of the file in the destination (e.g., `content/posts/my-post.md` becomes `example.com/posts/my-post/`).
 +
 +### `slug`
 +
 +When defined in the front matter, the `slug` can take the place of the filename for the destination.
 +
 +{{< code file="content/posts/old-post.md" >}}
 +---
 +title: New Post
 +slug: "new-post"
 +---
 +{{< /code >}}
 +
 +This will render to the following destination according to Hugo's default behavior:
 +
 +```
 +example.com/posts/new-post/
 +```
 +
 +### `section`
 +
 +`section` is determined by a content's location on disk and *cannot* be specified in the front matter. See [sections][] for more information.
 +
 +### `type`
 +
 +A content's `type` is also determined by its location on disk but, unlike `section`, it *can* be specified in the front matter. See [types][]. This can come in especially handy when you want a piece of content to render using a different layout. In the following example, you can create a layout at `layouts/new/mylayout.html` that Hugo will use to render this piece of content, even in the midst of many other posts.
 +
 +{{< code file="content/posts/my-post.md" >}}
 +---
 +title: My Post
 +type: new
 +layout: mylayout
 +---
 +{{< /code >}}
 +<!-- See https://discourse.gohugo.io/t/path-not-works/6387 -->
- `path` can be provided in the front matter. This will replace the actual path to the file on disk. Destination will create the destination with the same path, including the section. -->
++<!-- ### `path`-->
 +
++<!--`path` can be provided in the front matter. This will replace the actual path to the file on disk. Destination will create the destination with the same path, including the section. -->
 +
 +### `url`
 +
 +A complete URL can be provided. This will override all the above as it pertains to the end destination. This must be the path from the baseURL (starting with a `/`). `url` will be used exactly as it provided in the front matter and will ignore the `--uglyURLs` setting in your site configuration:
 +
 +{{< code file="content/posts/old-url.md" >}}
 +---
 +title: Old URL
 +url: /blog/new-url/
 +---
 +{{< /code >}}
 +
 +Assuming your `baseURL` is [configured][config] to `https://example.com`, the addition of `url` to the front matter will make `old-url.md` render to the following destination:
 +
 +```
 +https://example.com/blog/new-url/
 +```
 +
 +You can see more information on how to control output paths in [URL Management][urls].
 +
 +[config]: /getting-started/configuration/
 +[formats]: /content-management/formats/
 +[front matter]: /content-management/front-matter/
 +[getpage]: /functions/getpage/
 +[homepage template]: /templates/homepage/
 +[homepage]: /templates/homepage/
 +[lists]: /templates/lists/
 +[pretty]: /content-management/urls/#pretty-urls
 +[section templates]: /templates/section-templates/
 +[sections]: /content-management/sections/
 +[singles]: /templates/single-page-templates/
 +[taxonomy templates]: /templates/taxonomy-templates/
 +[taxonomy terms templates]: /templates/taxonomy-templates/
 +[types]: /content-management/types/
 +[urls]: /content-management/urls/
index b2f78505675f5af59b464730655a75bb01550f12,0000000000000000000000000000000000000000..542bb6cfc23fdaa454764febcc85665694a41865
mode 100644,000000..100644
--- /dev/null
@@@ -1,240 -1,0 +1,240 @@@
- #tags: ["Development", "Go", "fast", "Blogging"]
 +---
 +title: Taxonomies
 +linktitle:
 +description: Hugo includes support for user-defined taxonomies to help you  demonstrate logical relationships between content for the end users of your website.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +#tags: [taxonomies,metadata,front matter,terms]
 +categories: [content management]
 +menu:
 +  docs:
 +    parent: "content-management"
 +    weight: 80
 +weight: 80    #rem
 +draft: false
 +aliases: [/taxonomies/overview/,/taxonomies/usage/,/indexes/overview/,/doc/indexes/,/extras/indexes]
 +toc: true
 +---
 +
 +## What is a Taxonomy?
 +
 +Hugo includes support for user-defined groupings of content called **taxonomies**. Taxonomies are classifications of logical relationships between content.
 +
 +### Definitions
 +
 +Taxonomy
 +: a categorization that can be used to classify content
 +
 +Term
 +: a key within the taxonomy
 +
 +Value
 +: a piece of content assigned to a term
 +
 +{{< youtube "-np9GX6cL38" >}}
 +
 +## Example Taxonomy: Movie Website
 +
 +Let's assume you are making a website about movies. You may want to include the following taxonomies:
 +
 +* Actors
 +* Directors
 +* Studios
 +* Genre
 +* Year
 +* Awards
 +
 +Then, in each of the movies, you would specify terms for each of these taxonomies (i.e., in the [front matter][] of each of your movie content files). From these terms, Hugo would automatically create pages for each Actor, Director, Studio, Genre, Year, and Award, with each listing all of the Movies that matched that specific Actor, Director, Studio, Genre, Year, and Award.
 +
 +### Movie Taxonomy Organization
 +
 +To continue with the example of a movie site, the following demonstrates content relationships from the perspective of the taxonomy:
 +
 +```
 +Actor                    <- Taxonomy
 +    Bruce Willis         <- Term
 +        The Sixth Sense    <- Content
 +        Unbreakable      <- Content
 +        Moonrise Kingdom <- Content
 +    Samuel L. Jackson    <- Term
 +        Unbreakable      <- Content
 +        The Avengers     <- Content
 +        xXx              <- Content
 +```
 +
 +From the perspective of the content, the relationships would appear differently, although the data and labels used are the same:
 +
 +```
 +Unbreakable                 <- Content
 +    Actors                  <- Taxonomy
 +        Bruce Willis        <- Term
 +        Samuel L. Jackson   <- Term
 +    Director                <- Taxonomy
 +        M. Night Shyamalan  <- Term
 +    ...
 +Moonrise Kingdom            <- Content
 +    Actors                  <- Taxonomy
 +        Bruce Willis        <- Term
 +        Bill Murray         <- Term
 +    Director                <- Taxonomy
 +        Wes Anderson        <- Term
 +    ...
 +```
 +
 +## Hugo Taxonomy Defaults
 +
 +Hugo natively supports taxonomies. 
 +
 +Without adding a single line to your site's configuration file, Hugo will automatically create taxonomies for `tags` and `categories`. If you do not want Hugo to create any taxonomies, set `disableKinds` in your site's configuration to the following:
 +
 +```
 +disableKinds = ["taxonomy","taxonomyTerm"]
 +```
 +
 +### Default Destinations
 +
 +When taxonomies are used---and [taxonomy templates][] are provided---Hugo will automatically create both a page listing all the taxonomy's terms and individual pages with lists of content associated with each term. For example, a `categories` taxonomy declared in your configuration and used in your content front matter will create the following pages:
 +
 +* A single page at `example.com/categories/` that lists all the [terms within the taxonomy][]
 +* [Individual taxonomy list pages][taxonomy templates] (e.g., `/categories/development/`) for each of the terms that shows a listing of all pages marked as part of that taxonomy within any content file's [front matter][]
 +
 +## Configure Taxonomies
 +
 +Taxonomies must be defined in your [website configuration][config] before they can be used throughout the site. You need to provide both the plural and singular labels for each taxonomy. For example, `singular key = "plural value"` for TOML and `singular key: "plural value"` for YAML.
 +
 +### Example: TOML Taxonomy Configuration
 +
 +```
 +[taxonomies]
 +  tag = "tags"
 +  category = "categories"
 +  series = "series"
 +```
 +
 +### Example: YAML Taxonomy Configuration
 +
 +```
 +taxonomies:
 +  tag: "tags"
 +  category: "categories"
 +  series: "series"
 +```
 +
 +### Preserve Taxonomy Values
 +
 +By default, taxonomy names are normalized.
 +
 +Therefore, if you want to have a taxonomy term with special characters such as `Gérard Depardieu` instead of `Gerard Depardieu`, set the value for `preserveTaxonomyNames` to `true` in your [site configuration][config]. Hugo will then preserve special characters in taxonomy values but will still title-ize the values for titles and normalize them in URLs.
 +
 +Note that if you use `preserveTaxonomyNames` and intend to manually construct URLs to the archive pages, you will need to pass the taxonomy values through the [`urlize` template function][].
 +
 +{{% note %}}
 +You can add content and front matter to your taxonomy list and taxonomy terms pages. See [Content Organization](/content-management/organization/) for more information on how to add an `_index.md` for this purpose.
 +
 +Note also that taxonomy [permalinks](/content-management/urls/) are *not* configurable.
 +{{% /note %}}
 +
 +## Add Taxonomies to Content
 +
 +Once a taxonomy is defined at the site level, any piece of content can be assigned to it, regardless of [content type][] or [content section][].
 +
 +Assigning content to a taxonomy is done in the [front matter][]. Simply create a variable with the *plural* name of the taxonomy and assign all terms you want to apply to the instance of the content type.
 +
 +{{% note %}}
 +If you would like the ability to quickly generate content files with preconfigured taxonomies or terms, read the docs on [Hugo archetypes](/content-management/archetypes/).
 +{{% /note %}}
 +
 +### Example: TOML Front Matter with Taxonomies
 +
 +```
 ++++
 +title = "Hugo: A fast and flexible static site generator"
 +tags = [ "Development", "Go", "fast", "Blogging" ]
 +categories = [ "Development" ]
 +series = [ "Go Web Dev" ]
 +slug = "hugo"
 +project_url = "https://github.com/gohugoio/hugo"
 ++++
 +```
 +
 +### Example: YAML Front Matter with Taxonomies
 +
 +```
 +---
 +title: "Hugo: A fast and flexible static site generator"
- #tags: [ "a", "b", "c" ]
++tags: ["Development", "Go", "fast", "Blogging"]
 +categories: ["Development"]
 +series: ["Go Web Dev"]
 +slug: "hugo"
 +project_url: "https://github.com/gohugoio/hugo"
 +---
 +```
 +
 +### Example: JSON Front Matter with Taxonomies
 +
 +```
 +{
 +    "title": "Hugo: A fast and flexible static site generator",
 +    "tags": [
 +        "Development",
 +        "Go",
 +        "fast",
 +        "Blogging"
 +    ],
 +    "categories" : [
 +        "Development"
 +    ],
 +    "series" : [
 +        "Go Web Dev"
 +    ],
 +    "slug": "hugo",
 +    "project_url": "https://github.com/gohugoio/hugo"
 +}
 +```
 +
 +## Order Taxonomies
 +
 +A content file can assign weight for each of its associate taxonomies. Taxonomic weight can be used for sorting or ordering content in [taxonomy list templates][] and is declared in a content file's [front matter][]. The convention for declaring taxonomic weight is `taxonomyname_weight`.
 +
 +The following TOML and YAML examples show a piece of content that has a weight of 22, which can be used for ordering purposes when rendering the pages assigned to the "a", "b" and "c" values of the `tags` taxonomy. It has also been assigned the weight of 44 when rendering the "d" category page.
 +
 +### Example: TOML Taxonomic `weight`
 +
 +```
 ++++
 +title = "foo"
 +tags = [ "a", "b", "c" ]
 +tags_weight = 22
 +categories = ["d"]
 +categories_weight = 44
 ++++
 +```
 +
 +### Example: YAML Taxonomic `weight`
 +
 +```
 +---
 +title: foo
++tags: [ "a", "b", "c" ]
 +tags_weight: 22
 +categories: ["d"]
 +categories_weight: 44
 +---
 +```
 +
 +By using taxonomic weight, the same piece of content can appear in different positions in different taxonomies.
 +
 +{{% note "Limits to Ordering Taxonomies" %}}
 +Currently taxonomies only support the [default `weight => date` ordering of list content](/templates/lists/#default-weight-date). For more information, see the documentation on [taxonomy templates](/templates/taxonomy-templates/).
 +{{% /note %}}
 +
 +[`urlize` template function]: /functions/urlize/
 +[content section]: /content-management/sections/
 +[content type]: /content-management/types/
 +[documentation on archetypes]: /content-management/archetypes/
 +[front matter]: /content-management/front-matter/
 +[taxonomy list templates]: /templates/taxonomy-templates/#taxonomy-page-templates
 +[taxonomy templates]: /templates/taxonomy-templates/
 +[terms within the taxonomy]: /templates/taxonomy-templates/#taxonomy-terms-templates "See how to order terms associated with a taxonomy"
 +[config]: /getting-started/configuration/
index 74f2f772ed02fffa68a9410911fd9ca61bfb82e4,0000000000000000000000000000000000000000..29cd66e8425b0eb40cd7c13564f1edaa36a1cd70
mode 100644,000000..100644
--- /dev/null
@@@ -1,277 -1,0 +1,277 @@@
- Only the content under `post/` will have the new URL structure. For example, the file `content/post/sample-entry.md` with `date: 2017-02-27T19:20:00-05:00` in its front matter will render to `public/2017/02/sample-entry/index.html` at build time and therefore be reachable at `http://example.com/2013/11/sample-entry/`.
 +---
 +title: URL Management
 +linktitle: URL Management
 +description: Hugo supports permalinks, aliases, link canonicalization, and multiple options for handling relative vs absolute URLs.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-03-09
 +#tags: [aliases,redirects,permalinks,urls]
 +categories: [content management]
 +menu:
 +  docs:
 +    parent: "content-management"
 +    weight: 110
 +weight: 110   #rem
 +draft: false
 +aliases: [/extras/permalinks/,/extras/aliases/,/extras/urls/,/doc/redirects/,/doc/alias/,/doc/aliases/]
 +toc: true
 +---
 +
 +## Permalinks
 +
 +The default Hugo target directory for your built website is `public/`. However, you can change this value by specifying a different `publishDir` in your [site configuration][config]. The directories created at build time for a section reflect the position of the content's directory within the `content` folder and namespace matching its layout within the `contentdir` hierarchy.
 +
 +The `permalinks` option in your [site configuration][config] allows you to adjust the directory paths (i.e., the URLs) on a per-section basis. This will change where the files are written to and will change the page's internal "canonical" location, such that template references to `.RelPermalink` will honor the adjustments made as a result of the mappings in this option.
 +
 +{{% note "Default Publish and Content Folders" %}}
 +These examples use the default values for `publishDir` and `contentDir`; i.e., `publish` and `content`, respectively. You can override the default values in your [site's `config` file](/getting-started/configuration/).
 +{{% /note %}}
 +
 +For example, if one of your [sections][] is called `post` and you want to adjust the canonical path to be hierarchical based on the year, month, and post title, you could set up the following configurations in YAML and TOML, respectively.
 +
 +### YAML Permalinks Configuration Example
 +
 +{{< code file="config.yml" copy="false" >}}
 +permalinks:
 +  post: /:year/:month/:title/
 +{{< /code >}}
 +
 +### TOML Permalinks Configuration Example
 +
 +{{< code file="config.toml" copy="false" >}}
 +[permalinks]
 +  post = "/:year/:month/:title/"
 +{{< /code >}}
 +
-     <title>http://example.com/posts/my-intended-url</title>
-     <link rel="canonical" href="http://example.com/posts/my-intended-url"/>
++Only the content under `post/` will have the new URL structure. For example, the file `content/post/sample-entry.md` with `date: 2017-02-27T19:20:00-05:00` in its front matter will render to `public/2017/02/sample-entry/index.html` at build time and therefore be reachable at `https://example.com/2013/11/sample-entry/`.
 +
 +### Permalink Configuration Values
 +
 +The following is a list of values that can be used in a `permalink` definition in your site `config` file. All references to time are dependent on the content's date.
 +
 +`:year`
 +: the 4-digit year
 +
 +`:month`
 +: the 2-digit month
 +
 +`:monthname`
 +: the name of the month
 +
 +`:day`
 +: the 2-digit day
 +
 +`:weekday`
 +: the 1-digit day of the week (Sunday = 0)
 +
 +`:weekdayname`
 +: the name of the day of the week
 +
 +`:yearday`
 +: the 1- to 3-digit day of the year
 +
 +`:section`
 +: the content's section
 +
 +`:title`
 +: the content's title
 +
 +`:slug`
 +: the content's slug (or title if no slug is provided in the front matter)
 +
 +`:filename`
 +: the content's filename (without extension)
 +
 +## Aliases
 +
 +For people migrating existing published content to Hugo, there's a good chance you need a mechanism to handle redirecting old URLs.
 +
 +Luckily, redirects can be handled easily with **aliases** in Hugo.
 +
 +### Example: Aliases
 +
 +Let's assume you create a new piece of content at `content/posts/my-awesome-blog-post.md`. The content is a revision of your previous post at `content/posts/my-original-url.md`. You can create an `aliases` field in the front matter of your new `my-awesome-blog-post.md` where you can add previous paths. The following examples show how to create this filed in TOML and YAML front matter, respectively.
 +
 +#### TOML Front Matter
 +
 +{{< code file="content/posts/my-awesome-post.md" copy="false" >}}
 ++++
 +aliases = [
 +    "/posts/my-original-url/",
 +    "/2010/01/01/even-earlier-url.html"
 +]
 ++++
 +{{< /code >}}
 +
 +#### YAML Front Matter
 +
 +{{< code file="content/posts/my-awesome-post.md" copy="false" >}}
 +---
 +aliases:
 +    - /posts/my-original-url/
 +    - /2010/01/01/even-earlier-url.html
 +---
 +{{< /code >}}
 +
 +Now when you visit any of the locations specified in aliases---i.e., *assuming the same site domain*---you'll be redirected to the page they are specified on. For example, a visitor to `example.com/posts/my-original-url/` will be immediately redirected to `example.com/posts/my-awesome-blog-post/`.
 +
 +### Example: Aliases in Multilingual
 +
 +On [multilingual sites][multilingual], each translation of a post can have unique aliases. To use the same alias across multiple languages, prefix it with the language code.
 +
 +In `/posts/my-new-post.es.md`:
 +
 +```
 +---
 +aliases:
 +    - /es/posts/my-original-post/
 +---
 +```
 +
 +### How Hugo Aliases Work
 +
 +When aliases are specified, Hugo creates a directory to match the alias entry. Inside the directory, Hugo creates an `.html` file specifying the canonical URL for the page and the new redirect target.
 +
 +For example, a content file at `posts/my-intended-url.md` with the following in the front matter:
 +
 +```
 +---
 +title: My New post
 +aliases: [/posts/my-old-url/]
 +---
 +```
 +
 +Assuming a `baseURL` of `example.com`, the contents of the auto-generated alias `.html` found at `https://example.com/posts/my-old-url/ will contain the following:`
 +
 +```
 +<!DOCTYPE html>
 +<html>
 +  <head>
-     <meta http-equiv="refresh" content="0; url=http://example.com/posts/my-intended-url"/>
++    <title>https://example.com/posts/my-intended-url</title>
++    <link rel="canonical" href="https://example.com/posts/my-intended-url"/>
 +    <meta name=\"robots\" content=\"noindex\">
 +    <meta http-equiv="content-type" content="text/html; charset=utf-8"/>
- If you would like to have are often referred to as "ugly URLs" (e.g., example.com/urls.html), set `uglyurls = true` or `uglyurls: true` in your site's `config.toml` or `config.yaml`, respectively. You can also use the `--uglyURLs=true` [flag from the command line][usage] with `hugo` or `hugo server`..
++    <meta http-equiv="refresh" content="0; url=https://example.com/posts/my-intended-url"/>
 +  </head>
 +</html>
 +```
 +
 +The `http-equiv="refresh"` line is what performs the redirect, in 0 seconds in this case. If an end user of your website goes to `https://example.com/posts/my-old-url`, they will now be automatically redirected to the newer, correct URL. The addition of `<meta name=\"robots\" content=\"noindex\">` lets search engine bots know they they should not crawl and index your new alias page.
 +
 +### Customize 
 +You may customize this alias page by creating an `alias.html` template in the
 +layouts folder of your site (i.e., `layouts/alias.html`). In this case, the data passed to the template is
 +
 +`Permalink`
 +: the link to the page being aliased
 +
 +`Page`
 +: the Page data for the page being aliased
 +
 +### Important Behaviors of Aliases
 +
 +1. Hugo makes no assumptions about aliases. They also do not change based
 +on your UglyURLs setting. You need to provide absolute paths to your web root
 +and the complete filename or directory.
 +2. Aliases are rendered *before* any content are rendered and therefore will be overwritten by any content with the same location.
 +
 +## Pretty URLs
 +
 +Hugo's default behavior is to render your content with "pretty" URLs. No non-standard server-side configuration is required for these pretty URLs to work.
 +
 +The following demonstrates the concept:
 +
 +```
 +content/posts/_index.md
 +=> example.com/posts/index.html
 +content/posts/post-1.md
 +=> example.com/posts/post-1/
 +```
 +
 +## Ugly URLs
 +
-     |   └── _index.md  // <- http://example.com/about/
++If you would like to have what are often referred to as "ugly URLs" (e.g., example.com/urls.html), set `uglyurls = true` or `uglyurls: true` in your site's `config.toml` or `config.yaml`, respectively. You can also use the `--uglyURLs=true` [flag from the command line][usage] with `hugo` or `hugo server`..
 +
 +If you want a specific piece of content to have an exact URL, you can specify this in the [front matter][] under the `url` key. The following are examples of the same content directory and what the eventual URL structure will be when Hugo runs with its default behavior.
 +
 +See [Content Organization][contentorg] for more details on paths.
 +
 +```
 +.
 +└── content
 +    └── about
-     |   ├── firstpost.md   // <- http://example.com/post/firstpost/
++    |   └── _index.md  // <- https://example.com/about/
 +    ├── post
-     |   |   └── ness.md  // <- http://example.com/post/happy/ness/
-     |   └── secondpost.md  // <- http://example.com/post/secondpost/
++    |   ├── firstpost.md   // <- https://example.com/post/firstpost/
 +    |   ├── happy
-         ├── first.md       // <- http://example.com/quote/first/
-         └── second.md      // <- http://example.com/quote/second/
++    |   |   └── ness.md  // <- https://example.com/post/happy/ness/
++    |   └── secondpost.md  // <- https://example.com/post/secondpost/
 +    └── quote
-     |   └── _index.md  // <- http://example.com/about/index.html
++        ├── first.md       // <- https://example.com/quote/first/
++        └── second.md      // <- https://example.com/quote/second/
 +```
 +
 +Here's the same organization run with `hugo --uglyURLs`:
 +
 +```
 +.
 +└── content
 +    └── about
-     |   ├── firstpost.md   // <- http://example.com/post/firstpost.html
++    |   └── _index.md  // <- https://example.com/about/index.html
 +    ├── post
-     |   |   └── ness.md    // <- http://example.com/post/happy/ness.html
-     |   └── secondpost.md  // <- http://example.com/post/secondpost.html
++    |   ├── firstpost.md   // <- https://example.com/post/firstpost.html
 +    |   ├── happy
-         ├── first.md       // <- http://example.com/quote/first.html
-         └── second.md      // <- http://example.com/quote/second.html
++    |   |   └── ness.md    // <- https://example.com/post/happy/ness.html
++    |   └── secondpost.md  // <- https://example.com/post/secondpost.html
 +    └── quote
- By setting `canonifyURLs` to `true`, all relative URLs would instead be *canonicalized* using `baseURL`.  For example, assuming you have `baseURL = https://example.com/`, the relative URL `/css/foo.css` would be turned into the absolute URL `http://example.com/css/foo.css`.
++        ├── first.md       // <- https://example.com/quote/first.html
++        └── second.md      // <- https://example.com/quote/second.html
 +```
 +
 +
 +## Canonicalization
 +
 +By default, all relative URLs encountered in the input are left unmodified, e.g. `/css/foo.css` would stay as `/css/foo.css`. The `canonifyURLs` field in your site `config` has a default value of `false`.
 +
++By setting `canonifyURLs` to `true`, all relative URLs would instead be *canonicalized* using `baseURL`.  For example, assuming you have `baseURL = https://example.com/`, the relative URL `/css/foo.css` would be turned into the absolute URL `https://example.com/css/foo.css`.
 +
 +Benefits of canonicalization include fixing all URLs to be absolute, which may aid with some parsing tasks. Note, however, that all modern browsers handle this on the client without issue.
 +
 +Benefits of non-canonicalization include being able to have scheme-relative resource inclusion; e.g., so that `http` vs `https` can be decided according to how the page was retrieved.
 +
 +{{% note "`canonifyURLs` default change" %}}
 +In the May 2014 release of Hugo v0.11, the default value of `canonifyURLs` was switched from `true` to `false`, which we think is the better default and should continue to be the case going forward. Please verify and adjust your website accordingly if you are upgrading from v0.10 or older versions.
 +{{% /note %}}
 +
 +To find out the current value of `canonifyURLs` for your website, you may use the handy `hugo config` command added in v0.13.
 +
 +```
 +hugo config | grep -i canon
 +```
 +
 +Or, if you are on Windows and do not have `grep` installed:
 +
 +```
 +hugo config | FINDSTR /I canon
 +```
 +
 +## Override URLS with Front Matter
 +
 +In addition to specifying permalink values in your site configuration for different content sections, Hugo provides even more granular control for individual pieces of content.
 +
 +Both `slug` and `url` can be defined in individual front matter. For more information on content destinations at build time, see [Content Organization][contentorg].
 +
 +## Relative URLs
 +
 +By default, all relative URLs are left unchanged by Hugo, which can be problematic when you want to make your site browsable from a local file system.
 +
 +Setting `relativeURLs` to `true` in your [site configuration][config] will cause Hugo to rewrite all relative URLs to be relative to the current content.
 +
 +For example, if your `/post/first/` page contains a link to `/about/`, Hugo will rewrite the URL to `../../about/`.
 +
 +[config]: /getting-started/configuration/
 +[contentorg]: /content-management/organization/
 +[front matter]: /content-management/front-matter/
 +[multilingual]: /content-management/multilingual/
 +[sections]: /content-management/sections/
 +[usage]: /getting-started/usage/
index 8261c0e1b503bc9891c4303424f646778a21ceac,0000000000000000000000000000000000000000..2e5b92fbdcb421d0e09e87323391b8bd3e2e9731
mode 100644,000000..100644
--- /dev/null
@@@ -1,410 -1,0 +1,416 @@@
 +---
 +title: Contribute to Hugo Development
 +linktitle: Development
 +description: Hugo relies heavily on contributions from the open source community.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +categories: [contribute]
 +#tags: [dev,open source]
 +authors: [digitalcraftsman]
 +menu:
 +  docs:
 +    parent: "contribute"
 +    weight: 10
 +weight: 10
 +sections_weight: 10
 +draft: false
 +aliases: [/contribute/development/]
 +toc: true
 +---
 +
 +## Introduction
 +
 +Hugo is an open-source project and lives by the work of its [contributors][]. There are plenty of [open issues][issues], and we need your help to make Hugo even more awesome. You don't need to be a Go guru to contribute to the project's development.
 +
 +## Assumptions
 +
 +This contribution guide takes a step-by-step approach in hopes of helping newcomers. Therefore, we only assume the following:
 +
 +* You are new to Git or open-source projects in general
 +* You are a fan of Hugo and enthusiastic about contributing to the project
 +
 +{{% note "Additional Questions?" %}}
 +If you're struggling at any point in this contribution guide, reach out to the Hugo community in [Hugo's Discussion forum](https://discourse.gohugo.io).
 +{{% /note %}}
 +
 +## Install Go
 +
 +The installation of Go should take only a few minutes. You have more than one option to get Go up and running on your machine.
 +
 +If you are having trouble following the installation guides for go, check out [Go Bootcamp, which contains setups for every platform][gobootcamp] or reach out to the Hugo community in the [Hugo Discussion Forums][forums].
 +
 +### Install Go From Source
 +
 +[Download the latest stable version of Go][godl] and follow the official [Golang installation guide][goinstall].
 +
 +Once you're finished installing Go, let's confirm everything is working correctly. Open a terminal---or command line under Windows--and type the following:
 +
 +```
 +go version
 +```
 +
 +You should see something similar to the following written to the console. Note that the version here reflects the most recent version of Go as of the last update for this page:
 +
 +```
 +go version go1.8 darwin/amd64
 +```
 +
 +Next, make sure that you set up your `GOPATH` [as described in the installation guide][setupgopath].
 +
 +You can print the `GOPATH` with `echo $GOPATH`. You should see a non-empty string containing a valid path to your Go workspace; .e.g.:
 +
 +```
 +/Users/<yourusername>/Code/go
 +```
 +
 +### Install Go with Homebrew
 +
 +If you are a macOS user and have [Homebrew](https://brew.sh/) installed on your machine, installing Go is as simple as the following command:
 +
 +{{< code file="install-go.sh" >}}
 +brew install go
 +{{< /code >}}
 +
 +### Install Go via GVM
 +
 +More experienced users can use the [Go Version Manager][gvm] (GVM). GVM allows you to switch between different Go versions *on the same machine*. If you're a beginner, you probably don't need this feature. However, GVM makes it easy to upgrade to a new released Go version with just a few commands.
 +
 +GVM comes in especially handy if you follow the development of Hugo over a longer period of time. Future versions of Hugo will usually be compiled with the latest version of Go. Sooner or later, you will have to upgrade if you want to keep up.
 +
 +## Create a GitHub Account
 +
 +If you're going to contribute code, you'll need to have an account on GitHub. Go to [www.github.com/join](https://github.com/join) and set up a personal account.
 +
 +## Install Git on Your System
 +
 +You will need to have Git installed on your computer to contribute to Hugo development. Teaching git is outside the scope of the Hugo docs, but if you're looking for an excellent reference to learn the basics of Git, we recommend the [Git book][gitbook] if you are not sure where to begin. The used terminology will be explained with annotations.
 +
 +Git is a [version control system](https://en.wikipedia.org/wiki/Version_control) to track the changes of source code. Hugo depends on smaller third-party packages that are used to extend the functionality. We use them because we don't want to reinvent the wheel.
 +
 +Go ships with a sub-command called `get` that will download these packages for us when we setup our working environment. The source code of the packages is tracked with Git. `get` will interact with the Git servers of the package hosters in order to fetch all dependencies.
 +
 +Move back to the terminal and check if Git is already installed. Type in `git version` and press enter. You can skip the rest of this section if the command returned a version number. Otherwise [download](https://git-scm.com/downloads) the lastest version of Git and follow this [installation guide](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git).
 +
 +Finally, check again with `git version` if Git was installed successfully.
 +
 +### Git Graphical Front Ends
 +
 +There are several [GUI clients](https://git-scm.com/downloads/guis) that help you to operate Git. Not all are available for all operating systems and maybe differ in their usage. Thus, so we will use the command line since the commands are everywhere the same.
 +
 +### Install Hub on Your System (Optional)
 +
 +Hub is a great tool for working with GitHub. The main site for it is [hub.github.com](https://hub.github.com/). Feel free to install this little Git wrapper.
 +
 +On a Mac, you can install [Hub](https://github.com/github/hub) using [Homebrew](https://brew.sh):
 +
 +```
 +brew install hub
 +```
 +
 +Now we'll create an [alias in Bash](http://tldp.org/LDP/abs/html/aliases.html) so that typing `git` actually runs `Hub`:
 +
 +```
 +echo "alias git='hub'" >> ~/.bash_profile
 +```
 +
 +Confirm the installation:
 +
 +```
 +git version 2.6.3
 +hub version 2.2.2
 +```
 +
 +## Set up your working copy
 +
 +The working copy is set up locally on your computer. It's what you'll edit, compile, and end up pushing back to GitHub. The main steps are cloning the repository and creating your fork as a remote.
 +
 +### Clone the repository
 +
 +We assume that you've set up your `GOPATH` (see the section above if you're unsure about this). You should now copy the Hugo repository down to your computer. You'll hear this called "clone the repo". GitHub's [help pages](https://help.github.com/articles/cloning-a-repository/) give us a short explanation:
 +
 +> When you create a repository on GitHub, it exists as a remote repository. You can create a local clone of your repository on your computer and sync between the two locations.
 +
 +We're going to clone the [master Hugo repository](https://github.com/gohugoio/hugo). That seems counter-intuitive, since you won't have commit rights on it. But it's required for the Go workflow. You'll work on a copy of the master and push your changes to your own repository on GitHub.
 +
 +So, let's clone that master repository:
 +
 +```
 +go get -v -u github.com/gohugoio/hugo
 +```
 +
++Hugo relies on [Testify](https://github.com/stretchr/testify) for testing Go code. If you don't already have it, get the Testify testing tools:
++
++```
++go get github.com/stretchr/testify
++```
++
 +### Fork the repository
 +
 +If you're not fimiliar with this term, GitHub's [help pages](https://help.github.com/articles/fork-a-repo/) provide again a simple explanation:
 +
 +> A fork is a copy of a repository. Forking a repository allows you to freely experiment with changes without affecting the original project.
 +
 +#### Fork by hand
 +
 +Open the [Hugo repository](https://github.com/gohugoio/hugo) on GitHub and click on the "Fork" button in the top right.
 +
 +![Fork button](/images/contribute/development/forking-a-repository.png)
 +
 +Now open your fork repository on GitHub and copy the remote url of your fork. You can choose between HTTPS and SSH as protocol that Git should use for the following operations. HTTPS works always [if you're not sure](https://help.github.com/articles/which-remote-url-should-i-use/).
 +
 +![Copy remote url](/images/contribute/development/copy-remote-url.png)
 +
 +Switch back to the terminal and move into the directory of the cloned master repository from the last step.
 +
 +```
 +cd $GOPATH/src/github.com/gohugoio/hugo
 +```
 +
 +Now Git needs to know that our fork exists by adding the copied remote url:
 +
 +```
 +git remote add <YOUR-GITHUB-USERNAME> <COPIED REMOTE-URL>
 +```
 +
 +#### Fork with Hub
 +
 +Alternatively, you can use the Git wrapper Hub. Hub makes forking a repository easy:
 +
 +```
 +git fork
 +```
 +
 +That command will log in to GitHub using your account, create a fork of the repository that you're currently working in, and add it as a remote to your working copy.
 +
 +#### Trust, but verify
 +
 +Let's check if everything went right by listing all known remotes:
 +
 +```
 +git remote -v
 +```
 +
 +The output should look similar:
 +
 +```
 +digitalcraftsman    git@github.com:digitalcraftsman/hugo.git (fetch)
 +digitalcraftsman    git@github.com:digitalcraftsman/hugo.git (push)
 +origin  https://github.com/gohugoio/hugo (fetch)
 +origin  https://github.com/gohugoio/hugo (push)
 +```
 +
 +## The Hugo Git Contribution Workflow
 +
 +### Create a new branch
 +
 +You should never develop against the "master" branch. The development team will not accept a pull request against that branch. Instead, create a descriptive named branch and work on it.
 +
 +First, you should always pull the latest changes from the master repository:
 +
 +```
 +git checkout master
 +git pull
 +```
 +
 +Now we can create a new branch for your additions:
 +
 +```
 +git checkout -b <BRANCH-NAME>
 +```
 +
 +You can check on which branch your are with `git branch`. You should see a list of all local branches. The current branch is indicated with a little asterisk.
 +
 +### Contribute to Documentation
 +
 +Perhaps you want to start contributing to the Hugo docs. If so, you can ignore most of the following steps and focus on the `/docs` directory within your newly cloned repository. You can change directories into the Hugo docs using `cd docs`.
 +
 +You can start Hugo's built-in server via `hugo server`. Browse the documentation by entering [http://localhost:1313](http://localhost:1313) in the address bar of your browser. The server automatically updates the page whenever you change content.
 +
 +We have developed a [separate Hugo documentation contribution guide][docscontrib] for more information on how the Hugo docs are built, organized, and improved by the generosity of people like you.
 +
 +### Build Hugo
 +
 +While making changes in the codebase it's a good idea to build the binary to test them:
 +
 +```
 +go build -o hugo main.go
 +```
 +
 +### Test 
 +Sometimes changes on the codebase can cause unintended side effects. Or they don't work as expected. Most functions have their own test cases. You can find them in files ending with `_test.go`.
 +
 +Make sure the commands `go test ./...` passes, and `go build` completes.
 +
 +### Formatting 
 +The Go code styleguide maybe is opiniated but it ensures that the codebase looks the same, regardless who wrote the code. Go comes with its own formatting tool. Let's apply the styleguide to our addtions:
 +
 +```
 +go fmt ./...
 +```
 +
 +Once you made your additions commit your changes. Make sure that you follow our [code contribution guidelines](https://github.com/gohugoio/hugo/blob/master/CONTRIBUTING.md):
 +
 +```
 +# Add all changed files
 +git add --all
 +git commit --message "YOUR COMMIT MESSAGE"
 +```
 +
 +The commit message should describe what the commit does (e.g. add feature XYZ), not how it is done.
 +
 +### Modify commits
 +
 +You noticed some commit messages don't fulfill the code contribution guidelines or you just forget something to add some files? No problem. Git provides the necessary tools to fix such problems. The next two methods cover all common cases.
 +
 +If you are unsure what a command does leave the commit as it is. We can fix your commits later in the pull request.
 +
 +#### Modify the last commit
 +
 +Let's say you want to modify the last commit message. Run the following command and replace the current message:
 +
 +```
 +git commit --amend -m"YOUR NEW COMMIT MESSAGE"
 +```
 +
 +Take a look at the commit log to see the change:
 +
 +```
 +git log
 +# Exit with q
 +```
 +
 +After making the last commit you may forgot something. There is no need to create a new commit. Just add the latest changes and merge them into the intended commit:
 +
 +```
 +git add --all
 +git commit --amend
 +```
 +
 +#### Modify multiple commits
 +
 +{{% warning "Be Careful Modifying Multiple Commits"%}}
 +Modifications such as those described in this section can have serious unintended consequences. Skip this section if you're not sure!
 +{{% /warning %}}
 +
 +This is a bit more advanced. Git allows you to [rebase](https://git-scm.com/docs/git-rebase) commits interactively. In other words: it allows you to rewrite the commit history.
 +
 +```
 +git rebase --interactive @~6
 +```
 +
 +The `6` at the end of the command represents the number of commits that should be modified. An editor should open and present a list of last six commit messages:
 +
 +```
 +pick 80d02a1 tpl: Add hasPrefix to the template funcs' "smoke test"
 +pick aaee038 tpl: Sort the smoke tests
 +pick f0dbf2c tpl: Add the other test case for hasPrefix
 +pick 911c35b Add "How to contribute to Hugo" tutorial
 +pick 33c8973 Begin workflow
 +pick 3502f2e Refactoring and typo fixes
 +```
 +
 +In the case above we should merge the last to commits in the commit of this tutorial (`Add "How to contribute to Hugo" tutorial`). You can "squash" commits, i.e. merge two or more commits into a single one.
 +
 +All operations are written before the commit message. Replace "pick" with an operation. In this case `squash` or `s` for short:
 +
 +```
 +pick 80d02a1 tpl: Add hasPrefix to the template funcs' "smoke test"
 +pick aaee038 tpl: Sort the smoke tests
 +pick f0dbf2c tpl: Add the other test case for hasPrefix
 +pick 911c35b Add "How to contribute to Hugo" tutorial
 +squash 33c8973 Begin workflow
 +squash 3502f2e Refactoring and typo fixes
 +```
 +
 +We also want to rewrite the commits message of the third last commit. We forgot "docs:" as prefix according to the code contribution guidelines. The operation to rewrite a commit is called `reword` (or `r` as shortcut).
 +
 +You should end up with a similar setup:
 +
 +```
 +pick 80d02a1 tpl: Add hasPrefix to the template funcs' "smoke test"
 +pick aaee038 tpl: Sort the smoke tests
 +pick f0dbf2c tpl: Add the other test case for hasPrefix
 +reword 911c35b Add "How to contribute to Hugo" tutorial
 +squash 33c8973 Begin workflow
 +squash 3502f2e Refactoring and typo fixes
 +```
 +
 +Close the editor. It should open again with a new tab. A text is instructing you to define a new commit message for the last two commits that should be merged (aka "squashed"). Save the file with <kbd>CTRL</kbd>+<kbd>S</kbd> and close the editor again.
 +
 +A last time a new tab opens. Enter a new commit message and save again. Your terminal should contain a status message. Hopefully this one:
 +
 +```
 +Successfully rebased and updated refs/heads/<BRANCHNAME>.
 +```
 +
 +Check the commit log if everything looks as expected. Should an error occur you can abort this rebase with `git rebase --abort`.
 +
 +### Push commits
 +
 +To push our commits to the fork on GitHub we need to speficy a destination. A destination is defined by the remote and a branch name. Earlier, the defined that the remote url of our fork is the same as our GitHub handle, in my case `digitalcraftsman`. The branch should have the same as our local one. This makes it easy to identify corresponding branches.
 +
 +```
 +git push --set-upstream <YOUR-GITHUB-USERNAME> <BRANCHNAME>
 +```
 +
 +Now Git knows the destination. Next time when you to push commits you just need to enter `git push`.
 +
 +If you modified your commit history in the last step GitHub will reject your try to push. This is a safety-feature because the commit history isn't the same and new commits can't be appended as usual. You can enforce this push explicitly with `git push --force`.
 +
 +## Open a pull request
 +
 +We made a lot of progress. Good work. In this step we finally open a pull request to submit our additions. Open the [Hugo master repository](https://github.com/gohugoio/hugo/) on GitHub in your browser.
 +
 +You should find a green button labeld with "New pull request". But GitHub is clever and probably suggests you a pull request like in the beige box below:
 +
 +![Open a pull request](/images/contribute/development/open-pull-request.png)
 +
 +The new page summaries the most important information of your pull request. Scroll down and you find the additions of all your commits. Make sure everything looks as expected and click on "Create pull request".
 +
 +### Accept the contributor license agreement
 +
 +Last but not least you should accept the contributor license agreement (CLA). A new comment should be added automatically to your pull request. Click on the yellow badge, accept the agreement and authenticate yourself with your GitHub account. It just takes a few clicks and only needs to be done once.
 +
 +![Accept the CLA](/images/contribute/development/accept-cla.png)
 +
 +### Automatic builds
 +
 +We use the [Travis CI loop](https://travis-ci.org/gohugoio/hugo) (Linux and OS&nbsp;X) and [AppVeyor](https://ci.appveyor.com/project/gohugoio/hugo/branch/master) (Windows) to compile Hugo with your additions. This should ensure that everything works as expected before merging your pull request. This in most cases only relevant if you made changes to the codebase of Hugo.
 +
 +![Automic builds and their status](/images/contribute/development/ci-errors.png)
 +
 +Above you can see that Travis wasn't able to compile the changes in this pull request. Click on "Details" and try to investigate why the build failed. But it doesn't have to be your fault. Mostly, the `master` branch that we used as foundation for your pull request should build without problems.
 +
 +If you have questions, leave a comment in the pull request. We are willing to assist you.
 +
 +## Where to start?
 +
 +Thank you for reading through this contribution guide. Hopefully, we will see you again soon on GitHub. There are plenty of [open issues][issues] for you to help with.
 +
 +Feel free to [open an issue][newissue] if you think you found a bug or you have a new idea to improve Hugo. We are happy to hear from you.
 +
 +## Additional References for Learning Git and Golang
 +
 +* [Codecademy's Free "Learn Git" Course][codecademy] (Free)
 +* [Code School and GitHub's "Try Git" Tutorial][trygit] (Free)
 +* [The Git Book][gitbook] (Free)
 +* [Go Bootcamp][gobootcamp]
 +* [GitHub Pull Request Tutorial, Thinkful][thinkful]
 +
 +
 +[codecademy]: https://www.codecademy.com/learn/learn-git
 +[contributors]: https://github.com/gohugoio/hugo/graphs/contributors
 +[docscontrib]: /contribute/documentation/
 +[forums]: https://discourse.gohugo.io
 +[gitbook]: https://git-scm.com/
 +[gobootcamp]: http://www.golangbootcamp.com/book/get_setup
 +[godl]: https://golang.org/dl/
 +[goinstall]: https://golang.org/doc/install
 +[gvm]: https://github.com/moovweb/gvm
 +[issues]: https://github.com/gohugoio/hugo/issues
 +[newissue]: https://github.com/gohugoio/hugo/issues/new
 +[releases]: /getting-started/
 +[setupgopath]: https://golang.org/doc/code.html#Workspaces
 +[thinkful]: https://www.thinkful.com/learn/github-pull-request-tutorial/
 +[trygit]: https://try.github.io/levels/1/challenges/1
index dc8bddc3a263c370f292c38bac79be5b6f200d92,0000000000000000000000000000000000000000..7055e94e84a9c4766ce9620bed21ad92fc8a6816
mode 100644,000000..100644
--- /dev/null
@@@ -1,150 -1,0 +1,150 @@@
- homepage = "http://example.com/"
 +---
 +title: Add Your Hugo Theme to the Showcase
 +linktitle: Themes
 +description: If you've built a Hugo theme and want to contribute back to the Hugo Community, add your theme to the Hugo Showcase.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-27
 +categories: [contribute]
 +#tags: [contribute,themes,design]
 +authors: [digitalcraftsman]
 +menu:
 +  docs:
 +    parent: "contribute"
 +    weight: 30
 +weight: 30
 +sections_weight: 30
 +draft: false
 +aliases: [/contribute/theme/]
 +wip: true
 +toc: true
 +---
 +
 +A collection of all themes created by the Hugo community, including screenshots and demos, can be found at <https://themes.gohugo.io>. Every theme in this list will automatically be added to the theme site. Theme updates aren't scheduled but usually happen at least once a week.
 +
 +## tl;dr
 +
 +1. Create your theme using `hugo new theme <THEMENAME>`;
 +2. Test your theme against <https://github.com/spf13/HugoBasicExample> \*
 +3. Add a `theme.toml` file to the root of the theme with all required metadata
 +4. Add a descriptive `README.md` to the root of the theme source
 +5. Add `/images/screenshot.png` and `/images/tn.png`
 +
 +\* If your theme doesn't fit into the `Hugo Basic Example` site, we encourage theme authors to supply a self-contained Hugo site in `/exampleSite`.
 +
 +{{% note %}}
 +The folder name here---`exampleSite`---is important, as this folder will be picked up and used by the script that generates the Hugo Theme Site. It mirrors the root directory of a Hugo website and allows you to add custom content, assets, and a `config` file with preset values.
 +{{% /note %}}
 +
 +See the [Hugo Artist theme's exampleSite][artistexample] for a good example.
 +
 +{{% note %}}
 +Please make your example site's content is as neutral as possible. We hope this goes without saying.
 +{{% /note %}}
 +
 +## Theme Requirements
 +
 +In order to add your theme to the Hugo Themes Showcase, the following requirements need to be met:
 +
 +1. `theme.toml` with all required fields
 +2. Images for thumbnail and screenshot
 +3. A good README file instructions for users
 +4. Addition to the hugoThemes GitHub repository
 +
 +### Add Your Theme to the Repo
 +
 +The easiest way to add your theme is to [open up a new issue in the theme repository][themeissuenew] with a link to the theme's repository on GitHub.
 +
 +### Create a `theme.toml` File
 +
 +`theme.toml` contains metadata about the theme and its creator and should be created automatically when running the `hugo new theme`. The auto-generated file is provided here as well for easy downloading:
 +
 +{{< code file="theme.toml" download="theme.toml" >}}
 +name = ""
 +license = "MIT"
 +licenselink = "https://github.com/<YOURNAME>/<YOURTHEME>/blob/master/LICENSE.md"
 +description = ""
++homepage = "https://example.com/"
 +tags = []
 +features = []
 +min_version = 0.19
 +
 +[author]
 +  name = ""
 +  homepage = ""
 +
 +# If porting an existing theme
 +[original]
 +  name = ""
 +  homepage = ""
 +  repo = ""
 +{{< /code >}}
 +
 +The following fields are required:
 +
 +```
 +name = "Hyde"
 +license = "MIT"
 +licenselink = "https://github.com/spf13/hyde/blob/master/LICENSE.md"
 +description = "An elegant open source and mobile first theme"
 +homepage = "http://siteforthistheme.com/"
 +tags = ["blog", "company"]
 +features = ["blog"]
 +min_version = 0.13
 +
 +[author]
 +    name = "spf13"
 +    homepage = "http://spf13.com/"
 +
 +# If porting an existing theme
 +[original]
 +    author = "mdo"
 +    homepage = "http://hyde.getpoole.com/"
 +    repo = "https://www.github.com/mdo/hyde"
 +```
 +
 +{{% note %}}
 +1. This is different from the `theme.toml` file created by `hugo new theme` in Hugo versions before v0.14.
 +2. Only `theme.toml` is accepted; ie. not `theme.yaml` andnot `theme.json`.
 +{{% /note %}}
 +
 +### Images
 +
 +Screenshots are used for previews in the Hugo Theme Gallery. Make sure that they have the right dimensions:
 +
 +* Thumbnail should be 900px × 600px
 +* Screenshot should be 1500px × 1000px
 +* Media must be located in
 +    * <THEMEDIR>/images/screenshot.png</code>
 +    * <THEMEDIR>/images/tn.png</code>
 +
 +Additional media may be provided in the same directory.
 +
 +### Create a README File
 +
 +Your theme's README file should be written in markdown and saved at the root of your theme's directory structure. Your `README.md` serves as
 +
 +1. Content for your theme's details page at <https://themes.gohugo.io>
 +2. General information about the theme in your GitHub repository (i.e., it's usual purpose)
 +
 +#### Example `README.md`
 +
 +You can download the following `README.md` as an outline:
 +
 +{{< code file="README.md" download="README.md" >}}
 +
 +# Theme Title
 +
 +**Need input from @digitalcraftsman on what could be added to this file.**
 +
 +
 +
 +
 +{{< /code >}}
 +
 +{{% note "Screenshots in your `README.md`"%}}
 +If you add screenshots to the README, please make use of absolute file paths instead of relative ones like `/images/screenshot.png`. Relative paths work great on GitHub but they don't correspond to the directory structure of [themes.gohugo.io](http://themes.gohugo.io/). Therefore, browsers will not be able to display screenshots on the theme site under the given (relative) path.
 +{{% /note %}}
 +
 +[artistexample]: https://github.com/digitalcraftsman/hugo-artists-theme/tree/master/exampleSite
 +[themeissuenew]: https://github.com/gohugoio/hugoThemes/issues/new
index 41903c61d14b8d155fb45492073fde5caf65dda3,0000000000000000000000000000000000000000..8a6f49854e373ab9c3c2e31811d6186213f44c1d
mode 100644,000000..100644
--- /dev/null
@@@ -1,28 -1,0 +1,28 @@@
- So for a site  `baseURL` set to `http://example.com/hugo/` and the current language is `en`:
 +---
 +title: absLangURL
 +description: Adds the absolute URL with correct language prefix according to site configuration for multilingual.
 +godocref:
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +categories: [functions]
 +menu:
 +  docs:
 +    parent: "functions"
 +#tags: [multilingual,i18n,urls]
 +signature: ["absLangURL INPUT"]
 +workson: []
 +hugoversion:
 +relatedfuncs: [relLangURL]
 +deprecated: false
 +aliases: []
 +---
 +
 +Both `absLangURL` and [`relLangURL`](/functions/rellangurl/) are similar to their [`absURL`](/functions/absurl/) and [`relURL`](/functions/relurl) relatives but will add the correct language prefix when the site is configured with more than one language.
 +
- {{ "blog/" | absLangURL }} → "http://example.com/hugo/en/blog/"
++So for a site  `baseURL` set to `https://example.com/hugo/` and the current language is `en`:
 +
 +```
++{{ "blog/" | absLangURL }} → "https://example.com/hugo/en/blog/"
 +{{ "blog/" | relLangURL }} → "/hugo/en/blog/"
 +```
index 40cc9111c5f43f9eea1de66b5b8f261263a06265,0000000000000000000000000000000000000000..2e03ca49d12801921bfd541dca288043f84e0764
mode 100644,000000..100644
--- /dev/null
@@@ -1,51 -1,0 +1,51 @@@
- Both `absURL` and `relURL` consider the configured value of `baseURL` in your site's [`config` file][configuration]. Given a `baseURL` set to `http://example.com/hugo/`:
 +---
 +title: absURL
 +description: Creates an absolute URL based on the configured baseURL.
 +godocref:
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +categories: [functions]
 +menu:
 +  docs:
 +    parent: "functions"
 +#tags: [urls]
 +signature: ["absURL INPUT"]
 +workson: []
 +hugoversion:
 +relatedfuncs: [relURL]
 +deprecated: false
 +aliases: []
 +---
 +
- {{ "mystyle.css" | absURL }} → "http://example.com/hugo/mystyle.css"
++Both `absURL` and `relURL` consider the configured value of `baseURL` in your site's [`config` file][configuration]. Given a `baseURL` set to `https://example.com/hugo/`:
 +
 +```
++{{ "mystyle.css" | absURL }} → "https://example.com/hugo/mystyle.css"
 +{{ "mystyle.css" | relURL }} → "/hugo/mystyle.css"
 +{{ "http://gohugo.io/" | relURL }} →  "http://gohugo.io/"
 +{{ "http://gohugo.io/" | absURL }} →  "http://gohugo.io/"
 +```
 +
 +The last two examples may look strange but can be very useful. For example, the following shows how to use `absURL` in [JSON-LD structured data (SEO)][jsonld], where some of your images for a piece of content may or may not be hosted locally:
 +
 +{{< code file="layouts/partials/schemaorg-metadata.html" download="schemaorg-metadata.html" >}}
 +<script type="application/ld+json">
 +{
 +    "@context" : "http://schema.org",
 +    "@type" : "BlogPosting",
 +    "image" : {{ apply .Params.images "absURL" "." }}
 +}
 +</script>
 +{{< /code >}}
 +
 +The above uses the [apply function][] and also exposes how the Go template parser JSON-encodes objects inside `<script>` tags. See [the safeJS template function][safejs] for examples of how to tell Hugo not to escape strings inside of such tags.
 +
 +{{% note "Ending Slash" %}}
 +`absURL` and `relURL` are smart about missing slashes, but they will *not* add a closing slash to a URL if it is not present.
 +{{% /note %}}
 +
 +[apply function]: /functions/apply/
 +[configuration]: /getting-started/configuration/
 +[jsonld]: https://developers.google.com/search/docs/guides/intro-structured-data
 +[safejs]: /functions/safejs
index 60b801dfa367567fee6387a4b5720a1ca6cbbede,0000000000000000000000000000000000000000..6375ad738e72f91d3dd12634f6639ee39be4d2c1
mode 100644,000000..100644
--- /dev/null
@@@ -1,65 -1,0 +1,65 @@@
- <meta name="twitter:image" content="http://example.com/images/my-twitter-image.jpg">
 +---
 +title: Math
 +description: Hugo provides six mathematical operators in templates.
 +godocref:
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +#tags: [math, operators]
 +categories: [functions]
 +menu:
 +  docs:
 +    parent: "functions"
 +toc:
 +signature: []
 +workson: []
 +hugoversion:
 +relatedfuncs: []
 +deprecated: false
 +draft: false
 +aliases: []
 +---
 +
 +There are 6 basic mathematical operators that can be used in Hugo templates:
 +
 +| Function | Description              | Example                       |
 +| -------- | ------------------------ | ----------------------------- |
 +| `add`    | Adds two integers.       | `{{add 1 2}}` &rarr; 3        |
 +| `div`    | Divides two integers.    | `{{div 6 3}}` &rarr; 2        |
 +| `mod`    | Modulus of two integers. | `{{mod 15 3}}` &rarr; 0       |
 +| `modBool`| Boolean of modulus of two integers. Evaluates to `true` if = 0. | `{{modBool 15 3}}` &rarr; true |
 +| `mul`    | Multiplies two integers. | `{{mul 2 3}}` &rarr; 6        |
 +| `sub`    | Subtracts two integers.  | `{{sub 3 2}}` &rarr; 1        |
 +
 +## Use `add` with Strings
 +
 +You can also use the `add` function with strings. You may like this functionality in many use cases, including creating new variables by combining page- or site-level variables with other strings.
 +
 +For example, social media sharing with [Twitter Cards][cards] requires the following `meta` link in your site's `<head>` to display Twitter's ["Summary Card with Large Image"][twtsummary]:
 +
 +```
++<meta name="twitter:image" content="https://example.com/images/my-twitter-image.jpg">
 +```
 +
 +Let's assume you have an `image` field in the front matter of each of your content files:
 +
 +```
 +---
 +title: My Post
 +image: my-post-image.jpg
 +---
 +```
 +
 +You can then concatenate the `image` value (string) with the path to your `images` directory in `static` and leverage a URL-related templating function for increased flexibility:
 +
 +{{< code file="partials/head/twitter-card.html" >}}
 +{{$socialimage := add "images/" .Params.image}}
 +<meta name="twitter:image" content="{{ $socialimage | absURL }}">
 +{{< /code >}}
 +
 +{{% note %}}
 +The `add` example above makes use of the [`absURL` function](/functions/absurl/). `absURL` and its relative companion `relURL` is the recommended way to construct URLs in Hugo.
 +{{% /note %}}
 +
 +[cards]: https://dev.twitter.com/cards/overview
 +[twtsummary]: https://dev.twitter.com/cards/types/summary-large-image
index 08f4511fb7cf7d05ff07f0916df401a1a55f6cef,0000000000000000000000000000000000000000..2df271746235cc368a19adcade91b4696a9d65fa
mode 100644,000000..100644
--- /dev/null
@@@ -1,30 -1,0 +1,30 @@@
- So for a site  `baseURL` set to `http://example.com/hugo/` and the current language is `en`:
 +---
 +title: relLangURL
 +description: Adds the relative URL with correct language prefix according to site configuration for multilingual.
 +godocref:
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +#tags: [multilingual,i18n,urls]
 +categories: [functions]
 +menu:
 +  docs:
 +    parent: "functions"
 +signature: ["relLangURL INPUT"]
 +workson: []
 +hugoversion:
 +relatedfuncs: []
 +deprecated: false
 +aliases: []
 +---
 +
 +`absLangURL` and `relLangURL` functions are similar to their [`absURL`](/functions/absurl/) and [`relURL`](/functions/relurl/) relatives but will add the correct language prefix when the site is configured with more than one language. (See [Configuring Multilingual][multiliconfig].)
 +
- {{ "blog/" | absLangURL }} → "http://example.com/hugo/en/blog/"
++So for a site  `baseURL` set to `https://example.com/hugo/` and the current language is `en`:
 +
 +```
++{{ "blog/" | absLangURL }} → "https://example.com/hugo/en/blog/"
 +{{ "blog/" | relLangURL }} → "/hugo/en/blog/"
 +```
 +
 +[multiliconfig]: /content-management/multilingual/#configuring-multilingual-mode
index 2760d10c852d6cc9d2ab3e71e56f03a75f113fde,0000000000000000000000000000000000000000..085c344f51455dd48a9219b4a812f9f939f6c719
mode 100644,000000..100644
--- /dev/null
@@@ -1,51 -1,0 +1,51 @@@
- Both `absURL` and `relURL` consider the configured value of `baseURL` in your site's [`config` file][configuration]. Given a `baseURL` set to `http://example.com/hugo/`:
 +---
 +title: relURL
 +description: Given a string, prepends the relative URL according to a page's position in the project directory structure.
 +godocref:
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +categories: [functions]
 +menu:
 +  docs:
 +    parent: "functions"
 +#tags: [urls]
 +signature: ["relURL INPUT"]
 +workson: []
 +hugoversion:
 +relatedfuncs: [absURL]
 +deprecated: false
 +aliases: []
 +---
 +
- {{ "mystyle.css" | absURL }} → "http://example.com/hugo/mystyle.css"
++Both `absURL` and `relURL` consider the configured value of `baseURL` in your site's [`config` file][configuration]. Given a `baseURL` set to `https://example.com/hugo/`:
 +
 +```
++{{ "mystyle.css" | absURL }} → "https://example.com/hugo/mystyle.css"
 +{{ "mystyle.css" | relURL }} → "/hugo/mystyle.css"
 +{{ "http://gohugo.io/" | relURL }} →  "http://gohugo.io/"
 +{{ "http://gohugo.io/" | absURL }} →  "http://gohugo.io/"
 +```
 +
 +The last two examples may look strange but can be very useful. For example, the following shows how to use `absURL` in [JSON-LD structured data for SEO][jsonld] where some of your images for a piece of content may or may not be hosted locally:
 +
 +{{< code file="layouts/partials/schemaorg-metadata.html" download="schemaorg-metadata.html" >}}
 +<script type="application/ld+json">
 +{
 +    "@context" : "http://schema.org",
 +    "@type" : "BlogPosting",
 +    "image" : {{ apply .Params.images "absURL" "." }}
 +}
 +</script>
 +{{< /code >}}
 +
 +The above uses the [apply function][] and also exposes how the Go template parser JSON-encodes objects inside `<script>` tags. See [the safeJS template function][safejs] for examples of how to tell Hugo not to escape strings inside of such tags.
 +
 +{{% note "Ending Slash" %}}
 +`absURL` and `relURL` are smart about missing slashes, but they will *not* add a closing slash to a URL if it is not present.
 +{{% /note %}}
 +
 +[apply function]: /functions/apply/
 +[configuration]: /getting-started/configuration/
 +[jsonld]: https://developers.google.com/search/docs/guides/intro-structured-data
 +[safejs]: /functions/safejs
index 3ecf1ac34723560efa1be6ce703a299de9edfc00,0000000000000000000000000000000000000000..d655521785171448187dcdefda50a73e343dfe6f
mode 100644,000000..100644
--- /dev/null
@@@ -1,25 -1,0 +1,33 @@@
 +---
 +title: title
 +# linktitle:
 +description: Converts all characters in the provided string to title case.
 +godocref:
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +categories: [functions,fundamentals]
 +menu:
 +  docs:
 +    parent: "functions"
 +#tags: [strings]
 +signature: ["title INPUT"]
 +workson: []
 +hugoversion:
 +relatedfuncs: []
 +deprecated: false
 +aliases: []
 +---
 +
 +
 +```
 +{{title "BatMan"}}` → "Batman"
 +```
++
++Can be combined in pipes. In the following snippet, the link text is cleaned up using `humanize` to remove dashes and `title` to convert the value of `$name` to Intial Caps.
++
++```
++{{ range $name, $items := .Site.Taxonomies.categories }}
++    <li><a href="{{ printf "%s/%s" "categories" ($name | urlize | lower) | absURL }}">{{ $name | humanize | title }} ({{ len $items }})</a></li>
++{{ end }}
++```
index f7413ac3bdb3b732ca86719c11bedc2e76729279,0000000000000000000000000000000000000000..5683087d641910d2207411bb7c41e45f1e866988
mode 100644,000000..100644
--- /dev/null
@@@ -1,140 -1,0 +1,140 @@@
- baseURL = "http://example.org/"
 +---
 +title: Quick Start
 +linktitle: Quick Start
 +description: Create a Hugo site using the beautiful Ananke theme.
 +date: 2013-07-01
 +publishdate: 2013-07-01
 +categories: [getting started]
 +#tags: [quick start,usage]
 +authors: [Shekhar Gulati, Ryan Watters]
 +menu:
 +  docs:
 +    parent: "getting-started"
 +    weight: 10
 +weight: 10
 +sections_weight: 10
 +draft: false
 +aliases: [/quickstart/,/overview/quickstart/]
 +toc: true
 +---
 +
 +{{% note %}}
 +This quick start uses `macOS` in the examples. For instructions about how to install Hugo on other operating systems, see [install](/getting-started/installing).
 +
 +You also need [Git installed](https://git-scm.com/downloads) to run this tutorial.
 +{{% /note %}}
 +
 +
 +
 +## Step 1: Install Hugo
 +
 +{{% note %}}
 +`Homebrew`, a package manager for `macOS`,  can be installed from [brew.sh](https://brew.sh/). See [install](/getting-started/installing) if you are running Windows etc.
 +{{% /note %}}
 +
 +```bash
 +brew install hugo
 +```
 +
 +To verify your new install:
 +
 +```bash
 +hugo version
 +```
 +
 +
 +{{< asciicast HDlKrUrbfT7yiWsbd6QoxzRTN >}}
 +
 +
 +## Step 2: Create a New Site
 +
 +```bash
 +hugo new site quickstart
 +```
 +
 +The above will create a new Hugo site in a folder named `quickstart`.
 +
 +{{< asciicast 1PH9A2fs14Dnyarx5v8OMYQer >}}
 +
 +
 +## Step 3: Add a Theme
 +
 +See [themes.gohugo.io](https://themes.gohugo.io/) for a list of themes to consider. This quickstart uses the beautiful [Ananke theme](https://themes.gohugo.io/gohugo-theme-ananke/).
 +
 +```bash
 +cd quickstart;\
 +git init;\
 +git submodule add https://github.com/budparr/gohugo-theme-ananke.git themes/ananke;\
 +
 +# Edit your config.toml configuration file
 +# and add the Ananke theme.
 +echo 'theme = "ananke"' >> config.toml
 +```
 +
 +
 +{{< asciicast WJM2LEZQs8VRhNeuZ5NiGPp9I >}}
 +
 +## Step 4: Add Some Content
 +
 +```
 +hugo new posts/my-first-post.md
 +```
 +
 +
 +Edit the newly created content file if you want. Now, start the Hugo server with [drafts](/getting-started/usage/#draft-future-and-expired-content) enabled:
 +
 +```
 +▶ hugo server -D
 +
 +Started building sites ...
 +Built site for language en:
 +1 of 1 draft rendered
 +0 future content
 +0 expired content
 +1 regular pages created
 +8 other pages created
 +0 non-page files copied
 +1 paginator pages created
 +0 categories created
 +0 tags created
 +total in 18 ms
 +Watching for changes in /Users/bep/sites/quickstart/{data,content,layouts,static,themes}
 +Serving pages from memory
 +Web Server is available at http://localhost:1313/ (bind address 127.0.0.1)
 +Press Ctrl+C to stop
 +```
 +
 +
 +**Navigate to your new site at [http://localhost:1313/](http://localhost:1313/).**
 +
 +
 +
 +## Step 5: Customize the Theme
 +
 +Your new site already looks great, but you will want to tweak it a little before you release it to the public.
 +
 +### Site Configuration
 +
 +Open up `config.toml` in a text editor:
 +
 +```
++baseURL = "https://example.org/"
 +languageCode = "en-us"
 +title = "My New Hugo Site"
 +theme = "ananke"
 +```
 +
 +Replace the `title` above with something more personal. Also, if you already have a domain ready, set the `baseURL`. Note that this value is not needed when running the local development server. 
 +
 +{{% note %}}
 +**Tip:** Make the changes to the site configuration or any other file in your site while the Hugo server is running, and you will see the changes in the browser right away.
 +{{% /note %}}
 +
 +
 +For theme specific configuration options, see the [theme site](https://github.com/budparr/gohugo-theme-ananke).
 +
 +**For further theme customization, see [Customize a Theme](/themes/customizing/).**
 +
 +## Recapitulation
 +
 +{{< asciicast pWp4uvyAkdWgQllD9RCfeBL5k >}}
index cf0a6b9724a6bb7e1d6be752a040cfa298a243e3,0000000000000000000000000000000000000000..db368cbe4e97c32f6d38d82f4753cbef93c13b37
mode 100644,000000..100644
--- /dev/null
@@@ -1,211 -1,0 +1,211 @@@
- {{< datatable "media" "types" "Type" "Suffix" >}}
 +---
 +title: Custom Output Formats
 +linktitle: Custom Output Formats
 +description: Hugo can output content in multiple formats, including calendar events, e-book formats, Google AMP, and JSON search indexes, or any custom text format. 
 +date: 2017-03-22
 +publishdate: 2017-03-22
 +lastmod: 2017-03-22
 +categories: [templates]
 +#tags: ["amp","outputs","rss"]
 +menu:
 +  docs:
 +    parent: "templates"
 +    weight: 18
 +weight: 18
 +sections_weight: 18
 +draft: false
 +aliases: [/templates/outputs/,/extras/output-formats/,/content-management/custom-outputs/]
 +toc: true
 +---
 +
 +This page describes how to properly configure your site with the media types and output formats, as well as where to create your templates for your custom outputs.
 +
 +## Media Types
 +
 +A [media type][] (also known as *MIME type* and *content type*) is a two-part identifier for file formats and format contents transmitted on the Internet.
 +
 +This is the full set of built-in media types in Hugo:
 +
- {{< datatable "output" "formats" "Name" "MediaType" "Path" "BaseName" "Rel" "Protocol" "IsPlainText" "IsHTML" "NoUgly">}}
++{{< datatable "media" "types" "type" "suffix" >}}
 +
 +**Note:**
 +
 +* It is possible to add custom media types or change the defaults; e.g., if you want to change the suffix for `text/html` to `asp`.
 +* The `Suffix` is the value that will be used for URLs and filenames for that media type in Hugo.
 +* The `Type` is the identifier that must be used when defining new/custom `Output Formats` (see below).
 +* The full set of media types will be registered in Hugo's built-in development server to make sure they are recognized by the browser.
 +
 +To add or modify a media type, define it in a `mediaTypes` section in your [site configuration][config], either for all sites or for a given language.
 +
 +Example in `config.toml`:
 +
 +```
 +[mediaTypes]
 +  [mediaTypes."text/enriched"]
 +  suffix = "enr"
 +  [mediaTypes."text/html"]
 +  suffix = "asp"
 +```
 +
 +The above example adds one new media type, `text/enriched`, and changes the suffix for the built-in `text/html` media type.
 +
 +## Output Formats
 +
 +Given a media type and some additional configuration, you get an `Output Format`:
 +
 +This is the full set of Hugo's built-in output formats:
 +
- The above example is fictional, but if used for the homepage on a site with `baseURL` `http://example.org`, it will produce a plain text homepage with the URL `bep://example.org/myindex.enr`.
++{{< datatable "output" "formats" "name" "mediaType" "path" "baseName" "rel" "protocol" "isPlainText" "isHTML" "noUgly">}}
 +
 +* A page can be output in as many output formats as you want, and you can have an infinite amount of output formats defined **as long as they resolve to a unique path on the file system**. In the above table, the best example of this is `AMP` vs. `HTML`. `AMP` has the value `amp` for `Path` so it doesn't overwrite the `HTML` version; e.g. we can now have both `/index.html` and `/amp/index.html`.
 +* The `MediaType` must match the `Type` of an already defined media type.
 +* You can define new output formats or redefine built-in output formats; e.g., if you want to put `AMP` pages in a different path.
 +
 +To add or modify an output format, define it in an `outputFormats` section in your site's [configuration file](/templates/configuration/), either for all sites or for a given language.
 +
 +```
 +[outputFormats.MyEnrichedFormat]
 +mediaType = "text/enriched"
 +baseName = "myindex"
 +isPlainText = true
 +protocol = "bep://"
 +```
 +
- `Name`
++The above example is fictional, but if used for the homepage on a site with `baseURL` `https://example.org`, it will produce a plain text homepage with the URL `bep://example.org/myindex.enr`.
 +
 +### Configure Output Formats
 +
 +The following is the full list of configuration options for output formats and their default values:
 +
- `MediaType`
++`name`
 +: the output format identifier. This is used to define what output format(s) you want for your pages.
 +
- `Path`
++`mediaType`
 +: this must match the `Type` of a defined media type.
 +
- `BaseName`
++`path`
 +: sub path to save the output files.
 +
- `Rel`
++`baseName`
 +: the base filename for the list filenames (homepage, etc.). **Default:** `index`.
 +
- `Protocol`
++`rel`
 +: can be used to create `rel` values in `link` tags. **Default:** `alternate`.
 +
- `IsPlainText`
++`protocol`
 +: will replace the "http://" or "https://" in your `baseURL` for this output format.
 +
- `IsHTML`
++`isPlainText`
 +: use Go's plain text templates parser for the templates. **Default:** `false`.
 +
- `NoUgly`
++`isHTML`
 +: used in situations only relevant for `HTML`-type formats; e.g., page aliases.
 +
- `NotAlternative`
++`noUgly`
 +: used to turn off ugly URLs If `uglyURLs` is set to `true` in your site. **Default:** `false`.
 +
++`notAlternative`
 +: enable if it doesn't make sense to include this format in an `AlternativeOutputFormats` format listing on `Page` (e.g., with `CSS`). Note that we use the term *alternative* and not *alternate* here, as it does not necessarily replace the other format. **Default:** `false`.
 +
 +## Output Formats for Pages
 +
 +A `Page` in Hugo can be rendered to multiple representations on the file system. By default, all pages will render as `HTML` with some of them also as `RSS` (homepage, sections, etc.).
 +
 +This can be changed by defining an `outputs` list of output formats in either the `Page` front matter or in the site configuration (either for all sites or per language).
 +
 +Example from site `config.toml`:
 +
 +```
 +[outputs]
 +  home = ["HTML", "AMP", "RSS"]
 +  page = ["HTML"]
 +```
 +
 +Example from site `config.yml`:
 +
 +```
 +outputs:
 +  home: ["HTML", "AMP", "RSS"]
 +  page: ["HTML"]
 +```
 +
 +
 +* The output definition is per `Page` `Kind` (i.e, `page`, `home`, `section`, `taxonomy`, or `taxonomyTerm`).
 +* The names used must match the `Name` of a defined `Output Format`.
 +* Any `Kind` without a definition will default to `HTML`.
 +* These can be overridden per `Page` in the front matter of content files.
 +* Output formats are case insensitive.
 +
 +The following is an example of `YAML` front matter in a content file that defines output formats for the rendered `Page`:
 +
 +```
 +---
 +date: "2016-03-19"
 +outputs:
 +- html
 +- amp
 +- json
 +---
 +```
 +
 +## Link to Output Formats
 +
 +Each `Page` has both an `.OutputFormats` (all formats, including the current) and an `.AlternativeOutputFormats` variable, the latter of which is useful for creating a `link rel` list in your site's `<head>`:
 +
 +```
 +{{ range .AlternativeOutputFormats -}}
 +<link rel="{{ .Rel }}" type="{{ .MediaType.Type }}" href="{{ .Permalink | safeURL }}">
 +{{ end -}}
 +```
 +
 +Note that `.Permalink` and `.RelPermalink` on `Page` will return the first output format defined for that page (usually `HTML` if nothing else is defined).
 +
 +This is how you link to a given output format:
 +
 +```
 +{{ with  .OutputFormats.Get "json" -}}
 +<a href="{{ .Permalink }}">{{ .Name }}</a>
 +{{- end }}
 +```
 +
 +From content files, you can use the [`ref` or `relref` shortcodes](/content-management/shortcodes/#ref-and-relref):
 +
 +```
 +[Neat]({{</* ref "blog/neat.md" "amp" */>}})
 +[Who]({{</* relref "about.md#who" "amp" */>}})
 +```
 +
 +## Templates for Your Output Formats
 +
 +A new output format needs a corresponding template in order to render anything useful.
 +
 +{{% note %}}
 +The key distinction for Hugo versions 0.20 and newer is that Hugo looks at an output format's `Name` and MediaType's `Suffix` when choosing the template used to render a given `Page`.
 +{{% /note %}}
 +
 +The following table shows examples of different output formats, the suffix used, and Hugo's respective template [lookup order][]. All of the examples in the table can:
 +
 +* Use a [base template][base].
 +* Include [partial templates][partials]
 +
 +{{< datatable "output" "layouts" "Example" "OutputFormat" "Suffix" "Template Lookup Order" >}}
 +
 +Hugo will now also detect the media type and output format of partials, if possible, and use that information to decide if the partial should be parsed as a plain text template or not.
 +
 +Hugo will look for the name given, so you can name it whatever you want. But if you want it treated as plain text, you should use the file suffix and, if needed, the name of the Output Format. The pattern is as follows:
 +
 +```
 +[partial name].[OutputFormat].[suffix]
 +```
 +
 +The partial below is a plain text template (Outpuf Format is `CSV`, and since this is the only output format with the suffix `csv`, we don't need to include the Output Format's `Name`):
 +
 +```
 +{{ partial "mytextpartial.csv" . }}
 +```
 +
 +[base]: /templates/base/
 +[config]: /getting-started/configuration/
 +[lookup order]: /templates/lookup/
 +[media type]: https://en.wikipedia.org/wiki/Media_type
 +[partials]: /templates/partials/
index 21ba4bc9f49f26b493fd32fd22b987ac1bf40a50,0000000000000000000000000000000000000000..4d736c65e3ffabad41b9b167f26618c2bf54fd86
mode 100644,000000..100644
--- /dev/null
@@@ -1,142 -1,0 +1,144 @@@
-     <title>{{ with .Title }}{{.}} on {{ end }}{{ .Site.Title }}</title>
 +---
 +title: RSS Templates
 +linktitle: RSS Templates
 +description: Hugo ships with its own RSS 2.0 template that requires almost no configuration, or you can create your own RSS templates.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +#tags: [rss, xml]
 +categories: [templates]
 +menu:
 +  docs:
 +    parent: "templates"
 +    weight: 150
 +weight: 150
 +sections_weight: 150
 +draft: false
 +aliases: [/templates/rss/]
 +toc: true
 +---
 +
 +## RSS Template Lookup Order
 +
 +You can use a single RSS template to generate all of your RSS feeds or create a specific template for each individual feed.
 +
 +1. `/layouts/section/<section>.rss.xml`
 +2. `/layouts/_default/rss.xml`
 +3. `/themes/<theme>/layouts/section/<section>.rss.xml`
 +4. `/themes/<theme>/layouts/_default/rss.xml`
 +
 +{{% note "Hugo Ships with an RSS Template" %}}
 +Hugo ships with its own [RSS 2.0 template](#the-embedded-rss-xml). The embedded template will be sufficient for most use cases.
 +{{% /note %}}
 +
 +RSS pages are of the type `Page` and have all the [page variables](/layout/variables/) available to use in the templates.
 +
 +### Section RSS
 +
 +A [section’s][section] RSS will be rendered at `/<SECTION>/index.xml` (e.g., http://spf13.com/project/index.xml).
 +
 +Hugo provides the ability for you to define any RSS type you wish and can have different RSS files for each section and taxonomy.
 +
 +## Lookup Order for RSS Templates
 +
 +### Main RSS
 +
 +1. `/layouts/rss.xml`
 +2. `/layouts/_default/rss.xml`
 +3.  Embedded rss.xml
 +
 +### Section RSS
 +
 +1. `/layouts/section/<SECTION>.rss.xml`
 +2. `/layouts/_default/rss.xml`
 +3. `/themes/<THEME>/layouts/section/<SECTION>.rss.xml`
 +4. `/themes/<THEME>/layouts/_default/rss.xml`
 +5. Embedded rss.xml
 +
 +### Taxonomy RSS
 +
 +1. `/layouts/taxonomy/<SINGULAR>.rss.xml`
 +2. `/layouts/_default/rss.xml`
 +3. `/themes/<THEME>/layouts/taxonomy/<SINGULAR>.rss.xml`
 +4. `/themes/<THEME>/layouts/_default/rss.xml`
 +5. Embedded rss.xml
 +
 +## Configure RSS
 +
 +By default, Hugo will create an unlimited number of RSS entries. You can limit the number of articles included in the built-in RSS templates by assigning a numeric value to `rssLimit:` field in your project's [`config` file][config].
 +
 +The following values will also be included in the RSS output if specified in your site’s configuration:
 +
 +```
 +languageCode = "en-us"
 +copyright = "This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License."
 +
 +[author]
 +    name = "My Name Here"
 +```
 +
 +## The Embedded rss.xml
 +
 +This is the default RSS template that ships with Hugo. It adheres to the [RSS 2.0 Specification][RSS 2.0].
 +
 +```
 +<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
 +  <channel>
-     <description>Recent content {{ with .Title }}in {{.}} {{ end }}on {{ .Site.Title }}</description>
++    <title>{{ if eq  .Title  .Site.Title }}{{ .Site.Title }}{{ else }}{{ with .Title }}{{.}} on {{ end }}{{ .Site.Title }}{{ end }}</title>
 +    <link>{{ .Permalink }}</link>
-     <atom:link href="{{.URL}}" rel="self" type="application/rss+xml" />
-     {{ range first 15 .Data.Pages }}
++    <description>Recent content {{ if ne  .Title  .Site.Title }}{{ with .Title }}in {{.}} {{ end }}{{ end }}on {{ .Site.Title }}</description>
 +    <generator>Hugo -- gohugo.io</generator>{{ with .Site.LanguageCode }}
 +    <language>{{.}}</language>{{end}}{{ with .Site.Author.email }}
 +    <managingEditor>{{.}}{{ with $.Site.Author.name }} ({{.}}){{end}}</managingEditor>{{end}}{{ with .Site.Author.email }}
 +    <webMaster>{{.}}{{ with $.Site.Author.name }} ({{.}}){{end}}</webMaster>{{end}}{{ with .Site.Copyright }}
 +    <copyright>{{.}}</copyright>{{end}}{{ if not .Date.IsZero }}
 +    <lastBuildDate>{{ .Date.Format "Mon, 02 Jan 2006 15:04:05 -0700" | safeHTML }}</lastBuildDate>{{ end }}
-       <description>{{ .Content | html }}</description>
++    {{ with .OutputFormats.Get "RSS" }}
++        {{ printf "<atom:link href=%q rel=\"self\" type=%q />" .Permalink .MediaType | safeHTML }}
++    {{ end }}
++    {{ range .Data.Pages }}
 +    <item>
 +      <title>{{ .Title }}</title>
 +      <link>{{ .Permalink }}</link>
 +      <pubDate>{{ .Date.Format "Mon, 02 Jan 2006 15:04:05 -0700" | safeHTML }}</pubDate>
 +      {{ with .Site.Author.email }}<author>{{.}}{{ with $.Site.Author.name }} ({{.}}){{end}}</author>{{end}}
 +      <guid>{{ .Permalink }}</guid>
++      <description>{{ .Summary | html }}</description>
 +    </item>
 +    {{ end }}
 +  </channel>
 +</rss>
 +```
 +
 +{{% warning "XML Header" %}}
 +Hugo will automatically add the following header line to this file on render. Please do *not* include this in the template as it's not valid HTML.
 +```
 +<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
 +```
 +{{% /warning %}}
 +
 +## Reference your RSS Feed in `<head>`
 +
 +In your `header.html` template, you can specify your RSS feed in your `<head></head>` tag like this:
 +
 +```
 +{{ if .RSSLink }}
 +  <link href="{{ .RSSLink }}" rel="alternate" type="application/rss+xml" title="{{ .Site.Title }}" />
 +  <link href="{{ .RSSLink }}" rel="feed" type="application/rss+xml" title="{{ .Site.Title }}" />
 +{{ end }}
 +```
 +
 +...with the auto-discovery link specified by the line with `rel="alternate"`.
 +
 +The `.RSSLink` will render the appropriate RSS feed URL for the section, whether it's everything, posts in a section, or a taxonomy.
 +
 +If you reference your RSS link, be sure to specify the MIME type with `type="application/rss+xml"`.
 +
 +```
 +<a href="{{ .URL }}" type="application/rss+xml" target="_blank">{{ .SomeText }}</a>
 +```
 +
 +[config]: /getting-started/configuration/
 +[embedded]: #the-embedded-rss-xml
 +[RSS 2.0]: http://cyber.law.harvard.edu/rss/rss.html "RSS 2.0 Specification"
 +[section]: /content-management/sections/
index c8f855d6013a8adc5b4c7ba0df090157cb544fff,0000000000000000000000000000000000000000..58c4d21107dbf102f714693848e24e12cb901a79
mode 100644,000000..100644
--- /dev/null
@@@ -1,268 -1,0 +1,268 @@@
- #tags: [two,three,four]
 +---
 +title: Page Variables
 +linktitle:
 +description: Page-level variables are defined in a content file's front matter, derived from the content's file location, or extracted from the content body itself.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +categories: [variables and params]
 +#tags: [pages]
 +draft: false
 +menu:
 +  docs:
 +    parent: "variables"
 +    weight: 20
 +weight: 20
 +sections_weight: 20
 +aliases: [/variables/page/]
 +toc: true
 +---
 +
 +The following is a list of page-level variables. Many of these will be defined in the front matter, derived from file location, or extracted from the content itself.
 +
 +{{% note "`.Scratch`" %}}
 +See [`.Scratch`](/functions/scratch/) for page-scoped, writable variables.
 +{{% /note %}}
 +
 +## Page Variables
 +
 +`.AlternativeOutputFormats`
 +: contains all alternative formats for a given page; this variable is especially useful `link rel` list in your site's `<head>`. (See [Output Formats](/templates/output-formats/).)
 +
 +`.Content`
 +: the content itself, defined below the front matter.
 +
 +`.Data`
 +: the data specific to this type of page.
 +
 +`.Date`
 +: the date associated with the page; `.Date` pulls from the `date` field in a content's front matter. See also `.ExpiryDate`, `.PublishDate`, and `.Lastmod`.
 +
 +`.Description`
 +: the description for the page.
 +
 +`.Draft`
 +: a boolean, `true` if the content is marked as a draft in the front matter.
 +
 +`.ExpiryDate`
 +: the date on which the content is scheduled to expire; `.ExpiryDate` pulls from the `expirydate` field in a content's front matter. See also `.PublishDate`, `.Date`, and `.Lastmod`.
 +
 +`.FuzzyWordCount`
 +: the approximate number of words in the content.
 +
 +`.Hugo`
 +: see [Hugo Variables](/variables/hugo/).
 +
 +`.IsHome`
 +: `true` in the context of the [homepage](/templates/homepage/).
 +
 +`.IsNode`
 +: always `false` for regular content pages.
 +
 +`.IsPage`
 +: always `true` for regular content pages.
 +
 +`.IsTranslated`
 +: `true` if there are translations to display.
 +
 +`.Keywords`
 +: the meta keywords for the content.
 +
 +`.Kind`
 +: the page's *kind*. Possible return values are `page`, `home`, `section`, `taxonomy`, or `taxonomyTerm`. Note that there are also `RSS`, `sitemap`, `robotsTXT`, and `404` kinds, but these are only available during the rendering of each of these respective page's kind and therefore *not* available in any of the `Pages` collections.
 +
 +`.Lang`
 +: language taken from the language extension notation.
 +
 +`.Language`
 +: a language object that points to the language's definition in the site
 +`config`.
 +
 +`.Lastmod`
 +: the date the content was last modified; `.Lastmod` pulls from the `lastmod` field in a content's front matter. If `lastmod` is not set, Hugo will default to the `date` field. See also `.ExpiryDate`, `.Date`, and `.PublishDate`.
 +
 +`.LinkTitle`
 +: access when creating links to the content. If set, Hugo will use the `linktitle` from the front matter before `title`.
 +
 +`.Next`
 +: pointer to the following content (based on the `publishdate` field in front matter).
 +
 +`.NextInSection`
 +: pointer to the following content within the same section (based on `publishdate` field in front matter).
 +
 +`.OutputFormats`
 +: contains all formats, including the current format, for a given page. Can be combined the with [`.Get` function](/functions/get/) to grab a specific format. (See [Output Formats](/templates/output-formats/).)
 +
 +`.Pages`
 +: a collection of associated pages. This value will be `nil` for regular content pages. `.Pages` is an alias for `.Data.Pages`.
 +
 +`.Permalink`
 +: the Permanent link for this page; see [Permalinks](/content-management/urls/)
 +
 +`.Plain`
 +: the Page content stripped of HTML tags and presented as a string.
 +
 +`.PlainWords`
 +: the Page content stripped of HTML as a `[]string` using Go's [`strings.Fields`](https://golang.org/pkg/strings/#Fields) to split `.Plain` into a slice.
 +
 +`.Prev`
 +: Pointer to the previous content (based on `publishdate` in front matter).
 +
 +`.PrevInSection`
 +: Pointer to the previous content within the same section (based on `publishdate` in front matter). For example, `{{if .PrevInSection}}{{.PrevInSection.Permalink}}{{end}}`.
 +
 +`.PublishDate`
 +: the date on which the content was or will be published; `.Publishdate` pulls from the `publishdate` field in a content's front matter. See also `.ExpiryDate`, `.Date`, and `.Lastmod`.
 +
 +`.RSSLink`
 +: link to the taxonomies' RSS link.
 +
 +`.RawContent`
 +: raw markdown content without the front matter. Useful with [remarkjs.com](
 +http://remarkjs.com)
 +
 +`.ReadingTime`
 +: the estimated time, in minutes, it takes to read the content.
 +
 +`.Ref`
 +: returns the permalink for a given reference (e.g., `.Ref "sample.md"`).  `.Ref` does *not* handle in-page fragments correctly. See [Cross References](/content-management/cross-references/).
 +
 +`.RelPermalink`
 +: the relative permanent link for this page.
 +
 +`.RelRef`
 +: returns the relative permalink for a given reference (e.g., `RelRef
 +"sample.md"`). `.RelRef` does *not* handle in-page fragments correctly. See [Cross References](/content-management/cross-references/).
 +
 +`.Section`
 +: the [section](/content-management/sections/) this content belongs to.
 +
 +`.Site`
 +: see [Site Variables](/variables/site/).
 +
 +`.Summary`
 +: a generated summary of the content for easily showing a snippet in a summary view. The breakpoint can be set manually by inserting <code>&lt;!&#x2d;&#x2d;more&#x2d;&#x2d;&gt;</code> at the appropriate place in the content page. See [Content Summaries](/content-management/summaries/) for more details.
 +
 +`.TableOfContents`
 +: the rendered [table of contents](/content-management/toc/) for the page.
 +
 +`.Title`
 +: the title for this page.
 +
 +`.Translations`
 +: a list of translated versions of the current page. See [Multilingual Mode](/content-management/multilingual/) for more information.
 +
 +`.Truncated`
 +: a boolean, `true` if the `.Summary` is truncated. Useful for showing a "Read more..." link only when necessary.  See [Summaries](/content-management/summaries/) for more information.
 +
 +`.Type`
 +: the [content type](/content-management/types/) of the content (e.g., `post`).
 +
 +`.URL`
 +: the URL for the page relative to the web root. Note that a `url` set directly in front matter overrides the default relative URL for the rendered page.
 +
 +`.UniqueID`
 +: the MD5-checksum of the content file's path.
 +
 +`.Weight`
 +: assigned weight (in the front matter) to this content, used in sorting.
 +
 +`.WordCount`
 +: the number of words in the content.
 +
 +## Page-level Params
 +
 +Any other value defined in the front matter in a content file, including taxonomies, will be made available as part of the `.Params` variable.
 +
 +```
 +---
 +title: My First Post
 +date: date: 2017-02-20T15:26:23-06:00
 +categories: [one]
++tags: [two,three,four]
 +```
 +
 +With the above front matter, the `tags` and `categories` taxonomies are accessible via the following:
 +
 +* `.Params.tags`
 +* `.Params.categories`
 +
 +{{% note "Casing of Params" %}}
 +Page-level `.Params` are *only* accessible in lowercase.
 +{{% /note %}}
 +
 +The `.Params` variable is particularly useful for the introduction of user-defined front matter fields in content files. For example, a Hugo website on book reviews could have the following front matter in `/content/review/book01.md`:
 +
 +```
 +---
 +...
 +affiliatelink: "http://www.my-book-link.here"
 +recommendedby: "My Mother"
 +...
 +---
 +```
 +
 +These fields would then be accessible to the `/themes/yourtheme/layouts/review/single.html` template through `.Params.affiliatelink` and `.Params.recommendedby`, respectively.
 +
 +Two common situations where this type of front matter field could be introduced is as a value of a certain attribute like `href=""` or by itself to be displayed as text to the website's visitors.
 +
 +{{< code file="/themes/yourtheme/layouts/review/single.html" >}}
 +<h3><a href={{ printf "%s" $.Params.affiliatelink }}>Buy this book</a></h3>
 +<p>It was recommended by {{ .Params.recommendedby }}.</p>
 +{{< /code >}}
 +
 +This template would render as follows, assuming you've set [`uglyURLs`](/content-management/urls/) to `false` in your [site `config`](/getting-started/configuration/):
 +
 +{{< output file="yourbaseurl/review/book01/index.html" >}}
 +<h3><a href="http://www.my-book-link.here">Buy this book</a></h3>
 +<p>It was recommended by my Mother.</p>
 +{{< /output >}}
 +
 +{{% note %}}
 +See [Archetypes](/content-management/archetypes/) for consistency of `Params` across pieces of content.
 +{{% /note %}}
 +
 +### The `.Param` Method
 +
 +In Hugo, you can declare params in individual pages and globally for your entire website. A common use case is to have a general value for the site param and a more specific value for some of the pages (i.e., a header image):
 +
 +```
 +{{ $.Param "header_image" }}
 +```
 +
 +The `.Param` method provides a way to resolve a single value according to it's definition in a page parameter (i.e. in the content's front matter) or a site parameter (i.e., in your `config`).
 +
 +### Access Nested Fields in Front Matter
 +
 +When front matter contains nested fields like the following:
 +
 +```
 +---
 +author:
 +  given_name: John
 +  family_name: Feminella
 +  display_name: John Feminella
 +---
 +```
 +`.Param` can access these fields by concatenating the field names together with a dot:
 +
 +```
 +{{ $.Param "author.display_name" }}
 +```
 +
 +If your front matter contains a top-level key that is ambiguous with a nested key, as in the following case:
 +
 +```
 +---
 +favorites.flavor: vanilla
 +favorites:
 +  flavor: chocolate
 +---
 +```
 +
 +The top-level key will be preferred. Therefore, the following method, when applied to the previous example, will print `vanilla` and not `chocolate`:
 +
 +```
 +{{ $.Param "favorites.flavor" }}
 +=> vanilla
 +```
index 68b943388e4292392f92cccef53aec7195cd7882,0000000000000000000000000000000000000000..447a21fc39d084652284c2948ac85a9184ffef2c
mode 100644,000000..100644
--- /dev/null
@@@ -1,125 -1,0 +1,125 @@@
- baseURL = "http://yoursite.example.com/"
 +---
 +title: Site Variables
 +linktitle: Site Variables
 +description: Many, but not all, site-wide variables are defined in your site's configuration. However, Hugo provides a number of built-in variables for convenient access to global values in your templates.
 +date: 2017-02-01
 +publishdate: 2017-02-01
 +lastmod: 2017-02-01
 +categories: [variables and params]
 +#tags: [global,site]
 +draft: false
 +menu:
 +  docs:
 +    parent: "variables"
 +    weight: 10
 +weight: 10
 +sections_weight: 10
 +aliases: [/variables/site-variables/]
 +toc: true
 +---
 +
 +The following is a list of site-level (aka "global") variables. Many of these variables are defined in your site's [configuration file][config], whereas others are built into Hugo's core for convenient usage in your templates.
 +
 +## Site Variables List
 +
 +`.Site.AllPages`
 +: array of all pages, regardless of their translation.
 +
 +`.Site.Author`
 +: a map of the authors as defined in the site configuration.
 +
 +`.Site.BaseURL`
 +: the base URL for the site as defined in the site configuration.
 +
 +`.Site.BuildDrafts`
 +: a boolean (default: `false`) to indicate whether to build drafts as defined in the site configuration.
 +
 +`.Site.Copyright`
 +: a string representing the copyright of your website as defined in the site configuration.
 +
 +`.Site.Data`
 +: custom data, see [Data Templates](/templates/data-templates/).
 +
 +`.Site.DisqusShortname`
 +: a string representing the shortname of the Disqus shortcode as defined in the site configuration.
 +
 +`.Site.Files`
 +: all source files for the Hugo website.
 +
 +`.Site.GoogleAnalytics`
 +: a string representing your tracking code for Google Analytics as defined in the site configuration.
 +
 +`.Site.IsMultiLingual`
 +: whether there are more than one language in this site. See [Multilingual](/content-management/multilingual/) for more information.
 +
 +`.Site.Language.Lang`
 +: the language code of the current locale (e.g., `en`).
 +
 +`.Site.Language.LanguageName`
 +: the full language name (e.g. `English`).
 +
 +`.Site.Language.Weight`
 +: the weight that defines the order in the `.Site.Languages` list.
 +
 +`.Site.Language`
 +: indicates the language currently being used to render the website. This object's attributes are set in site configurations' language definition.
 +
 +`.Site.LanguageCode`
 +: a string representing the language as defined in the site configuration. This is mostly used to populate the RSS feeds with the right language code.
 +
 +`.Site.LanguagePrefix`
 +: this can be used to prefix URLs to point to the correct language. It will even work when only one defined language. See also the functions [absLangURL](/functions/abslangurl/) and [relLangURL](/functions/rellangurl).
 +
 +`.Site.Languages`
 +: an ordered list (ordered by defined weight) of languages.
 +
 +`.Site.LastChange`
 +: a string representing the date/time of the most recent change to your site. This string is based on the [`date` variable in the front matter](/content-management/front-matter) of your content pages.
 +
 +`.Site.Menus`
 +: all of the menus in the site.
 +
 +`.Site.Pages`
 +: array of all content ordered by Date with the newest first. This array contains only the pages in the current language.
 +
 +`.Site.Permalinks`
 +: a string to override the default [permalink](/content-management/urls/) format as defined in the site configuration.
 +
 +`.Site.RegularPages`
 +: a shortcut to the *regular* page collection. `.Site.RegularPages` is equivalent to `where .Site.Pages "Kind" "page"`.
 +
 +`.Site.RSSLink`
 +: the URL for the site RSS.
 +
 +`.Site.Sections`
 +: top-level directories of the site.
 +
 +`.Site.Taxonomies`
 +: the [taxonomies](/taxonomies/usage/) for the entire site.  Replaces the now-obsolete `.Site.Indexes` since v0.11. Also see section [Taxonomies elsewhere](#taxonomies-elsewhere).
 +
 +`.Site.Title`
 +: a string representing the title of the site.
 +
 +## The `.Site.Params` Variable
 +
 +`.Site.Params` is a container holding the values from the `params` section of your site configuration.
 +
 +### Example: `.Site.Params`
 +
 +The following `config.toml` defines a site-wide param for `description`:
 +
 +```
++baseURL = "https://yoursite.example.com/"
 +
 +[params]
 +  description = "Tesla's Awesome Hugo Site"
 +  author = "Nikola Tesla"
 +```
 +
 +You can use `.Site.Params` in a [partial template](/templates/partials/) to call the default site description:
 +
 +{{< code file="layouts/partials/head.html" >}}
 +<meta name="description" content="{{if .IsHome}}{{ $.Site.Params.description }}{{else}}{{.Description}}{{end}}" />
 +{{< /code >}}
 +
 +[config]: /getting-started/configuration/
index a230df6500d1edde2500310aff37e67f6fc1c2a2,0000000000000000000000000000000000000000..59ab282814b5a3bce84591eb6324f4d4c2fee6c8
mode 100644,000000..100644
--- /dev/null
@@@ -1,1722 -1,0 +1,1778 @@@
-         "Type": "application/javascript",
-         "String": "application/javascript+js",
-         "MainType": "application",
-         "SubType": "javascript",
-         "Suffix": "js",
-         "Delimiter": "."
 +{
 +  "media": {
 +    "types": [
 +      {
-         "Type": "application/json",
-         "String": "application/json+json",
-         "MainType": "application",
-         "SubType": "json",
-         "Suffix": "json",
-         "Delimiter": "."
++        "type": "application/javascript",
++        "string": "application/javascript+js",
++        "mainType": "application",
++        "subType": "javascript",
++        "suffix": "js",
++        "delimiter": "."
 +      },
 +      {
-         "Type": "application/rss",
-         "String": "application/rss+xml",
-         "MainType": "application",
-         "SubType": "rss",
-         "Suffix": "xml",
-         "Delimiter": "."
++        "type": "application/json",
++        "string": "application/json+json",
++        "mainType": "application",
++        "subType": "json",
++        "suffix": "json",
++        "delimiter": "."
 +      },
 +      {
-         "Type": "application/xml",
-         "String": "application/xml+xml",
-         "MainType": "application",
-         "SubType": "xml",
-         "Suffix": "xml",
-         "Delimiter": "."
++        "type": "application/rss",
++        "string": "application/rss+xml",
++        "mainType": "application",
++        "subType": "rss",
++        "suffix": "xml",
++        "delimiter": "."
 +      },
 +      {
-         "Type": "text/calendar",
-         "String": "text/calendar+ics",
-         "MainType": "text",
-         "SubType": "calendar",
-         "Suffix": "ics",
-         "Delimiter": "."
++        "type": "application/xml",
++        "string": "application/xml+xml",
++        "mainType": "application",
++        "subType": "xml",
++        "suffix": "xml",
++        "delimiter": "."
 +      },
 +      {
-         "Type": "text/css",
-         "String": "text/css+css",
-         "MainType": "text",
-         "SubType": "css",
-         "Suffix": "css",
-         "Delimiter": "."
++        "type": "text/calendar",
++        "string": "text/calendar+ics",
++        "mainType": "text",
++        "subType": "calendar",
++        "suffix": "ics",
++        "delimiter": "."
 +      },
 +      {
-         "Type": "text/csv",
-         "String": "text/csv+csv",
-         "MainType": "text",
-         "SubType": "csv",
-         "Suffix": "csv",
-         "Delimiter": "."
++        "type": "text/css",
++        "string": "text/css+css",
++        "mainType": "text",
++        "subType": "css",
++        "suffix": "css",
++        "delimiter": "."
 +      },
 +      {
-         "Type": "text/html",
-         "String": "text/html+html",
-         "MainType": "text",
-         "SubType": "html",
-         "Suffix": "html",
-         "Delimiter": "."
++        "type": "text/csv",
++        "string": "text/csv+csv",
++        "mainType": "text",
++        "subType": "csv",
++        "suffix": "csv",
++        "delimiter": "."
 +      },
 +      {
-         "Type": "text/plain",
-         "String": "text/plain+txt",
-         "MainType": "text",
-         "SubType": "plain",
-         "Suffix": "txt",
-         "Delimiter": "."
++        "type": "text/html",
++        "string": "text/html+html",
++        "mainType": "text",
++        "subType": "html",
++        "suffix": "html",
++        "delimiter": "."
 +      },
 +      {
-         "Name": "AMP",
-         "Path": "amp",
-         "BaseName": "index",
-         "Rel": "amphtml",
-         "Protocol": "",
-         "IsPlainText": false,
-         "IsHTML": true,
-         "NoUgly": false,
-         "NotAlternative": false
++        "type": "text/plain",
++        "string": "text/plain+txt",
++        "mainType": "text",
++        "subType": "plain",
++        "suffix": "txt",
++        "delimiter": "."
 +      }
 +    ]
 +  },
 +  "output": {
 +    "formats": [
 +      {
 +        "MediaType": "text/html+html",
-         "Name": "CSS",
-         "Path": "",
-         "BaseName": "styles",
-         "Rel": "stylesheet",
-         "Protocol": "",
-         "IsPlainText": true,
-         "IsHTML": false,
-         "NoUgly": false,
-         "NotAlternative": true
++        "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": "CSV",
-         "Path": "",
-         "BaseName": "index",
-         "Rel": "alternate",
-         "Protocol": "",
-         "IsPlainText": true,
-         "IsHTML": false,
-         "NoUgly": false,
-         "NotAlternative": false
++        "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": "Calendar",
-         "Path": "",
-         "BaseName": "index",
-         "Rel": "alternate",
-         "Protocol": "webcal://",
-         "IsPlainText": true,
-         "IsHTML": false,
-         "NoUgly": false,
-         "NotAlternative": false
++        "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": "HTML",
-         "Path": "",
-         "BaseName": "index",
-         "Rel": "canonical",
-         "Protocol": "",
-         "IsPlainText": false,
-         "IsHTML": true,
-         "NoUgly": false,
-         "NotAlternative": false
++        "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": "JSON",
-         "Path": "",
-         "BaseName": "index",
-         "Rel": "alternate",
-         "Protocol": "",
-         "IsPlainText": true,
-         "IsHTML": false,
-         "NoUgly": false,
-         "NotAlternative": false
++        "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": "RSS",
-         "Path": "",
-         "BaseName": "index",
-         "Rel": "alternate",
-         "Protocol": "",
-         "IsPlainText": false,
-         "IsHTML": false,
-         "NoUgly": true,
-         "NotAlternative": false
++        "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": "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
 +      }
 +    ],
 +    "layouts": [
 +      {
 +        "Example": "AMP home, with theme \"demoTheme\".",
 +        "OutputFormat": "AMP",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/index.amp.html",
 +          "layouts/index.html",
 +          "layouts/_default/list.amp.html",
 +          "layouts/_default/list.html",
 +          "demoTheme/layouts/index.amp.html",
 +          "demoTheme/layouts/index.html",
 +          "demoTheme/layouts/_default/list.amp.html",
 +          "demoTheme/layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "AMP home, French language\".",
 +        "OutputFormat": "AMP",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/index.fr.amp.html",
 +          "layouts/index.amp.html",
 +          "layouts/index.fr.html",
 +          "layouts/index.html",
 +          "layouts/_default/list.fr.amp.html",
 +          "layouts/_default/list.amp.html",
 +          "layouts/_default/list.fr.html",
 +          "layouts/_default/list.html"
 +        ]
 +      },
 +      {
 +        "Example": "RSS home, no theme.",
 +        "OutputFormat": "RSS",
 +        "Suffix": "xml",
 +        "Template Lookup Order": [
 +          "layouts/rss.xml",
 +          "layouts/_default/rss.xml",
 +          "layouts/_internal/_default/rss.xml"
 +        ]
 +      },
 +      {
 +        "Example": "JSON home, no theme.",
 +        "OutputFormat": "JSON",
 +        "Suffix": "json",
 +        "Template Lookup Order": [
 +          "layouts/index.json.json",
 +          "layouts/index.json",
 +          "layouts/_default/list.json.json",
 +          "layouts/_default/list.json"
 +        ]
 +      },
 +      {
 +        "Example": "CSV regular, \"layout: demolayout\" in front matter.",
 +        "OutputFormat": "CSV",
 +        "Suffix": "csv",
 +        "Template Lookup Order": [
 +          "layouts/_default/demolayout.csv.csv",
 +          "layouts/_default/demolayout.csv"
 +        ]
 +      },
 +      {
 +        "Example": "JSON regular, \"type: demotype\" in front matter.",
 +        "OutputFormat": "JSON",
 +        "Suffix": "json",
 +        "Template Lookup Order": [
 +          "layouts/demotype/single.json.json",
 +          "layouts/demotype/single.json",
 +          "layouts/_default/single.json.json",
 +          "layouts/_default/single.json"
 +        ]
 +      },
 +      {
 +        "Example": "HTML regular.",
 +        "OutputFormat": "HTML",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/_default/single.html.html",
 +          "layouts/_default/single.html"
 +        ]
 +      },
 +      {
 +        "Example": "AMP regular.",
 +        "OutputFormat": "AMP",
 +        "Suffix": "html",
 +        "Template Lookup Order": [
 +          "layouts/_default/single.amp.html",
 +          "layouts/_default/single.html"
 +        ]
 +      },
 +      {
 +        "Example": "Calendar blog section.",
 +        "OutputFormat": "Calendar",
 +        "Suffix": "ics",
 +        "Template Lookup Order": [
 +          "layouts/section/blog.calendar.ics",
 +          "layouts/section/blog.ics",
 +          "layouts/blog/list.calendar.ics",
 +          "layouts/blog/list.ics",
 +          "layouts/_default/section.calendar.ics",
 +          "layouts/_default/section.ics",
 +          "layouts/_default/list.calendar.ics",
 +          "layouts/_default/list.ics"
 +        ]
 +      },
 +      {
 +        "Example": "Calendar taxonomy list.",
 +        "OutputFormat": "Calendar",
 +        "Suffix": "ics",
 +        "Template Lookup Order": [
 +          "layouts/taxonomy/tag.calendar.ics",
 +          "layouts/taxonomy/tag.ics",
 +          "layouts/_default/taxonomy.calendar.ics",
 +          "layouts/_default/taxonomy.ics",
 +          "layouts/_default/list.calendar.ics",
 +          "layouts/_default/list.ics"
 +        ]
 +      },
 +      {
 +        "Example": "Calendar taxonomy term.",
 +        "OutputFormat": "Calendar",
 +        "Suffix": "ics",
 +        "Template Lookup Order": [
 +          "layouts/taxonomy/tag.terms.calendar.ics",
 +          "layouts/taxonomy/tag.terms.ics",
 +          "layouts/_default/terms.calendar.ics",
 +          "layouts/_default/terms.ics"
 +        ]
 +      }
 +    ]
 +  },
 +  "tpl": {
 +    "funcs": {
 +      "cast": {
 +        "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": {
 +        "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": []
 +        },
 +        "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": []
 +        },
 +        "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": {
 +        "Print": {
 +          "Description": "",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "print"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ print \"works!\" }}",
 +              "works!"
 +            ]
 +          ]
 +        },
 +        "Printf": {
 +          "Description": "",
 +          "Args": [
 +            "format",
 +            "a"
 +          ],
 +          "Aliases": [
 +            "printf"
 +          ],
 +          "Examples": [
 +            [
 +              "{{ printf \"%s!\" \"works\" }}",
 +              "works!"
 +            ]
 +          ]
 +        },
 +        "Println": {
 +          "Description": "",
 +          "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": {
 +        "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": "",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "add"
 +          ],
 +          "Examples": [
 +            [
 +              "{{add 1 2}}",
 +              "3"
 +            ]
 +          ]
 +        },
 +        "Div": {
 +          "Description": "",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "div"
 +          ],
 +          "Examples": [
 +            [
 +              "{{div 6 3}}",
 +              "2"
 +            ]
 +          ]
 +        },
 +        "Log": {
 +          "Description": "",
 +          "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": "",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "mul"
 +          ],
 +          "Examples": [
 +            [
 +              "{{mul 2 3}}",
 +              "6"
 +            ]
 +          ]
 +        },
 +        "Sub": {
 +          "Description": "",
 +          "Args": [
 +            "a",
 +            "b"
 +          ],
 +          "Aliases": [
 +            "sub"
 +          ],
 +          "Examples": [
 +            [
 +              "{{sub 3 2}}",
 +              "1"
 +            ]
 +          ]
 +        }
 +      },
 +      "os": {
 +        "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": "ReadFilereads the file named by filename relative to the configured\nWorkingDir.  It returns the contents as a string.  There is a upper size\nlimit 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"
 +            ]
 +          ]
 +        }
 +      },
 +      "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\" }}",
 +              "\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"
 +            ]
 +          ]
 +        },
 +        "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"
 +            ]
 +          ]
 +        },
 +        "TrimPrefix": {
 +          "Description": "",
 +          "Args": null,
 +          "Aliases": null,
 +          "Examples": null
 +        },
 +        "TrimSuffix": {
 +          "Description": "",
 +          "Args": null,
 +          "Aliases": null,
 +          "Examples": null
 +        },
 +        "Truncate": {
 +          "Description": "",
 +          "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"
 +            ]
 +          ]
 +        },
 +        "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": []
 +        }
 +      },
 +      "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!"
 +            ]
 +          ]
 +        }
 +      },
 +      "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": []
 +        },
 +        "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": "",
 +          "Args": [
 +            "a"
 +          ],
 +          "Aliases": [
 +            "urlize"
 +          ],
 +          "Examples": []
 +        }
 +      }
 +    }
 +  }
 +}