Add highlighting of code in documentation and clean up a bunch of the docs.
authorspf13 <steve.francia@gmail.com>
Sat, 11 Jan 2014 02:19:19 +0000 (21:19 -0500)
committerspf13 <steve.francia@gmail.com>
Sat, 11 Jan 2014 02:29:58 +0000 (21:29 -0500)
25 files changed:
docs/content/community/hall-of-fame.md
docs/content/community/mailing-list.md
docs/content/content/example.md
docs/content/content/front-matter.md
docs/content/content/ordering.md
docs/content/content/organization.md
docs/content/content/sections.md
docs/content/content/types.md
docs/content/extras/aliases.md
docs/content/extras/shortcodes.md
docs/content/indexes/category.md
docs/content/indexes/displaying.md
docs/content/indexes/lists.md
docs/content/indexes/ordering.md
docs/content/indexes/overview.md
docs/content/indexes/templates.md
docs/content/layout/chrome.md
docs/content/layout/homepage.md
docs/content/layout/indexes.md
docs/content/layout/rss.md
docs/content/layout/templates.md
docs/content/layout/views.md
docs/content/meta/license.md
docs/content/meta/release-notes.md
docs/content/overview/configuration.md

index 6950b5c7e3b664909d7da720d6273979d8f77374..df272a7b26822bf0249dcc435b6acf479741267b 100644 (file)
@@ -11,8 +11,8 @@ If you want to be added to this page please send a [pull request](https://github
 
 
 
-| **Site**                                     | **Source**                                            | **License**  |
-| -------------------------------------------- | ----------------------------------------------------- | -----------: |
-|  [hugo](http://hugo.spf13.com)               |  [source](http://github.com/spf13/hugo/docs)          |   SIMPL      |
-|  [spf13](http://spf13.com)                   |  [source](http://github.com/spf13/spf13.com)          |   MIT        |
-|  [Chimera Art Space](http://chimeraarts.org) |  [source](https://github.com/chimera/chimeraarts.org) |   CC-SA      |
+| **Site**                                         | **Source**                                            | **License**  |
+| ------------------------------------------------ | ----------------------------------------------------- | -----------: |
+| [hugo](http://hugo.spf13.com)                    | [source](http://github.com/spf13/hugo/docs)           | SIMPL        |
+| [spf13](http://spf13.com)                        | [source](http://github.com/spf13/spf13.com)           | MIT          |
+| [Chimera Art Space](http://chimeraarts.org)      | [source](https://github.com/chimera/chimeraarts.org)  | CC-SA        |
index 23767bb47db93ff89217eac6da96e2c396d89685..c3867b856359de333100138859eccb90b0f98ae0 100644 (file)
@@ -7,28 +7,28 @@ groups_weight: 10
 
 Hugo has two mailing lists:
 
-### Announcements
+## Announcements
 Very low traffic. Only releases will be emailed here.
 
 https://groups.google.com/forum/#!forum/hugo-announce
 
-### Discussion
+## Discussion
 For all questions and discussions:
 
 https://groups.google.com/forum/#!forum/hugo-discuss
 
 # Other Resources
 
-### GoNuts
+## GoNuts
 
 For general go questions or discussion please refer to the go mailing list.
 
 https://groups.google.com/forum/#!forum/golang-nuts
 
-### Github Issues
+## Github Issues
 
 https://github.com/spf13/hugo/issues
 
-### Twitter
+## Twitter
 
 Hugo doesn't have it's own twitter handle, but feel free to tweet [@spf13](http://twitter.com/spf13).
index 82a086f52bdfda631444a88209697afec8f7f464..01300d45c066473683bdff3b955a4bcf0156ad2f 100644 (file)
@@ -11,34 +11,36 @@ Somethings are better shown than explained. The following is a very basic exampl
 
 **mysite/project/nitro.md  <- http://mysite.com/project/nitro.html**
 
-    ---
-    Title:       "Nitro : A quick and simple profiler for golang"
-    Description: ""
-    Keywords:    [ "Development", "golang", "profiling" ]
-    Tags:        [ "Development", "golang", "profiling" ]
-    date:        "2013-06-19"
-    Topics:      [ "Development", "GoLang" ]
-    Slug:        "nitro"
-    project_url: "http://github.com/spf13/nitro"
-    ---
+{{% highlight yaml %}}
+---
+Title:       "Nitro : A quick and simple profiler for golang"
+Description: ""
+Keywords:    [ "Development", "golang", "profiling" ]
+Tags:        [ "Development", "golang", "profiling" ]
+date:        "2013-06-19"
+Topics:      [ "Development", "GoLang" ]
+Slug:        "nitro"
+project_url: "http://github.com/spf13/nitro"
+---
 
-    # Nitro
+# Nitro
 
-    Quick and easy performance analyzer library for golang.
+Quick and easy performance analyzer library for golang.
 
-    ## Overview
+## Overview
 
-    Nitro is a quick and easy performance analyzer library for golang.
-    It is useful for comparing A/B against different drafts of functions
-    or different functions.
+Nitro is a quick and easy performance analyzer library for golang.
+It is useful for comparing A/B against different drafts of functions
+or different functions.
 
-    ## Implementing Nitro
+## Implementing Nitro
 
-    Using Nitro is simple. First use go get to install the latest version
-    of the library.
+Using Nitro is simple. First use go get to install the latest version
+of the library.
 
-        $ go get github.com/spf13/nitro
+    $ go get github.com/spf13/nitro
 
-    Next include nitro in your application.
+Next include nitro in your application.
 
+{{% /highlight %}}
 
index b70cf4ad94de37ff6eb2fc89611fe542ba820d34..22b0a40df0c9de2670c823aea5bc876206b4402b 100644 (file)
@@ -17,36 +17,41 @@ Supported formats: <br>
 
 ### 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" ]
-    date: "2012-04-06"
-    categories:
-      - "Development"
-      - "VIM"
-    slug: "spf13-vim-3-0-release-and-new-website"
-    ---
-    Content of the file goes Here
+{{% highlight yaml %}}
+---
+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"
+---
+Content of the file goes Here
+{{% /highlight %}}
 
 ### 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"
-    +++
-    Content of the file goes Here
+{{% highlight yaml %}}
++++
+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"
++++
+Content of the file goes Here
+{{% /highlight %}}
 
 ### JSON Example
 
-    {
+{{% highlight json %}}
+{
     "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" ],
@@ -56,31 +61,33 @@ Supported formats: <br>
         "VIM"
     ],
     "slug": "spf13-vim-3-0-release-and-new-website",
-    }
-    Content of the file goes Here
+}
+Content of the file goes Here
+{{% /highlight %}}
 
-### Variables
+## Variables
 
 There are a few predefined variables that Hugo is aware of and utilizes. The user can also create
 any variable they want to. These will be placed into the `.Params` variable available to the templates.
 **Field names are case insensitive.**
 
-#### Required
+### Required
+
+* **title** The title for the content
+* **description** The description for the content
+* **date** The date the content will be sorted by
+* **indexes** These will use the field name of the plural form of the index (see tags and categories above)
 
-**title**  The title for the content. <br>
-**description** The description for the content.<br>
-**date** The date the content will be sorted by.<br>
-**indexes** These will use the field name of the plural form of the index (see tags and categories above)
+### Optional
 
-#### Optional
+* **redirect** Mark the post as a redirect post
+* **draft** If true the content will not be rendered unless hugo is called with --build-drafts
+* **type** The type of the content (will be derived from the directory automatically if unset)
+* **markup** (Experimental) Specify "rst" for reStructuredText (requires
+            `rst2html`,) or "md" (default) for the Markdown
+* **slug** The token to appear in the tail of the url
+   *or*<br>
+* **url** The full path to the content from the web root.<br>
 
-**redirect** Mark the post as a redirect post<br>
-**draft** If true the content will not be rendered unless `hugo` is called with -d<br>
-**type** The type of the content (will be derived from the directory automatically if unset).<br>
-**markup** (Experimental) Specify "rst" for reStructuredText (requires
-           `rst2html`,) or "md" (default) for the Markdown.<br>
-**slug** The token to appear in the tail of the url.<br>
-  *or*<br>
-**url** The full path to the content from the web root.<br>
-*If neither is present the filename will be used.*
+*If neither slug or url is present the filename will be used.*
 
index 9379c6f50b85d74819371a07107b992162b746a4..c6f48fff78fa296deaad782b6cc16b7b2d40a884 100644 (file)
@@ -10,7 +10,7 @@ In Hugo you have a good degree of control of how your content can be ordered.
 
 By default, content is ordered by weight, then by date with the most recent date first.
 
-_Both the date and weight fields are optional._ 
+_Both the date and weight fields are optional._
 
 Unweighted pages appear at the end of the list.
 If no weights are provided (or if weights are the same) date will be used to sort. If neither are provided
@@ -29,50 +29,60 @@ Alternative sorting is also available to order content by date (ignoring weight)
 
 ## Order by Weight -> Date (default)
 
-    {{ range .Data.Pages }}
-    <li>
-      <a href="{{ .Permalink }}">{{ .Title }}</a>
-      <div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
-    </li>
-    {{ end }}
+{{% highlight html %}}
+{{ range .Data.Pages }}
+<li>
+<a href="{{ .Permalink }}">{{ .Title }}</a>
+<div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
+</li>
+{{ end }}
+{{% /highlight %}}
 
 ## Order by Weight -> Date
 
-    {{ range .Data.Pages.ByWeight }}
-    <li>
-      <a href="{{ .Permalink }}">{{ .Title }}</a>
-      <div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
-    </li>
-    {{ end }}
+{{% highlight html %}}
+{{ range .Data.Pages.ByWeight }}
+<li>
+<a href="{{ .Permalink }}">{{ .Title }}</a>
+<div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
+</li>
+{{ end }}
+{{% /highlight %}}
 
 
 ## Order by Date
 
-    {{ range .Data.Pages.ByDate }}
-    <li>
-      <a href="{{ .Permalink }}">{{ .Title }}</a>
-      <div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
-    </li>
-    {{ end }}
+{{% highlight html %}}
+{{ range .Data.Pages.ByDate }}
+<li>
+<a href="{{ .Permalink }}">{{ .Title }}</a>
+<div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
+</li>
+{{ end }}
+{{% /highlight %}}
 
 ## Order by Length
 
-    {{ range .Data.Pages.ByLength }}
-    <li>
-      <a href="{{ .Permalink }}">{{ .Title }}</a>
-      <div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
-    </li>
-    {{ end }}
+{{% highlight html %}}
+{{ range .Data.Pages.ByLength }}
+<li>
+<a href="{{ .Permalink }}">{{ .Title }}</a>
+<div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
+</li>
+{{ end }}
+{{% /highlight %}}
 
 ## Reverse Order
 Can be applied to any of the above. Using Date for an example.
 
-    {{ range .Data.Pages.ByDate.Reverse }}
-    <li>
-      <a href="{{ .Permalink }}">{{ .Title }}</a>
-      <div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
-    </li>
-    {{ end }}
+{{% highlight html %}}
+{{ range .Data.Pages.ByDate.Reverse }}
+<li>
+<a href="{{ .Permalink }}">{{ .Title }}</a>
+<div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
+</li>
+{{ end }}
+{{% /highlight %}}
 
 ## Ordering Content Within Indexes
 
index eda63283e8df3af77a164a1a9f1616a7aab663de..61ea0a0a477f71d80f2b3918925df2fd017a7e56 100644 (file)
@@ -20,26 +20,26 @@ content nested at any level. The top level is special in Hugo and is used as the
     .
     └── content
         ├── post
-        |   ├── firstpost.md       // <- http://site.com/post/firstpost/
+        |   ├── firstpost.md   // <- http://1.com/post/firstpost/
         |   ├── happy
-        |   |   └── happiness.md   // <- http://site.com/post/happy/happiness/
-        |   └── secondpost.md      // <- http://site.com/post/secondpost/
+        |   |   └── ness.md    // <- http://1.com/post/happy/ness/
+        |   └── secondpost.md  // <- http://1.com/post/secondpost/
         └── quote
-            ├── first.md           // <- http://site.com/quote/first/
-            └── second.md          // <- http://site.com/quote/second/
+            ├── first.md       // <- http://1.com/quote/first/
+            └── second.md      // <- http://1.com/quote/second/
 
 **Here's the same organization run with hugo -\-uglyurls**
 
     .
     └── content
         ├── post
-        |   ├── firstpost.md       // <- http://site.com/post/firstpost.html
+        |   ├── firstpost.md   // <- http://1.com/post/firstpost.html
         |   ├── happy
-        |   |   └── happiness.md   // <- http://site.com/post/happy/happiness.html
-        |   └── secondpost.md      // <- http://site.com/post/secondpost.html
+        |   |   └── ness.md    // <- http://1.com/post/happy/ness.html
+        |   └── secondpost.md  // <- http://1.com/post/secondpost.html
         └── quote
-            ├── first.md           // <- http://site.com/quote/first.html
-            └── second.md          // <- http://site.com/quote/second.html
+            ├── first.md       // <- http://1.com/quote/first.html
+            └── second.md      // <- http://1.com/quote/second.html
 
 ## Destinations
 
@@ -55,28 +55,28 @@ determine the destination of a specific piece of content.
 The following items are defined in order, latter items in the list will override
 earlier settings.
 
-#### filename
+### 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.
 
-#### slug
+### slug
 Defined in the front matter, the slug can take the place of the filename for the
 destination.
 
-#### filepath
+### filepath
 The actual path to the file on disk. Destination will create the destination
 with the same path. Includes [section](/content/sections).
 
-#### section
+### section
 section can be provided in the front matter overriding the section derived from
 the source content location on disk. See [section](/content/sections).
 
-#### path
+### 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. Includes [section](/content/sections).
 
-#### url
+### 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 "/").
 When a url is provided it will be used exactly. Using url will ignore the
@@ -135,23 +135,23 @@ When a url is provided it will be used exactly. Using url will ignore the
 
 
 
-section = which type the content is by default
-   based on content location 
-   front matter overrides
+**section** = which type the content is by default
 
+* based on content location 
+* front matter overrides
 
-slug = name.ext or name/
-    based on content-name.md
-    front matter overrides
+**slug** = name.ext or name/
 
+* based on content-name.md 
+* front matter overrides
 
-path = section + path to file exluding slug
-    based on path to content location
+**path** = section + path to file exluding slug
 
+* based on path to content location
 
-url = relative url
-    defined in front matter
-    overrides all the above
 
+**url** = relative url
 
+* defined in front matter
+* overrides all the above
 
index a01c7b5eb096bcbafbbd8b18aaa48938dba9e791..a2fc155fa8bc55fb679e5e7443ee43734d9ebf97 100644 (file)
@@ -15,13 +15,13 @@ The following example site uses two sections, "post" and "quote".
     .
     └── content
         ├── post
-        |   ├── firstpost.md       // <- http://site.com/post/firstpost/
+        |   ├── firstpost.md       // <- http://1.com/post/firstpost/
         |   ├── happy
-        |   |   └── happiness.md   // <- http://site.com/post/happy/happiness/
-        |   └── secondpost.md      // <- http://site.com/post/secondpost/
+        |   |   └── ness.md   // <- http://1.com/post/happy/ness/
+        |   └── secondpost.md      // <- http://1.com/post/secondpost/
         └── quote
-            ├── first.md           // <- http://site.com/quote/first/
-            └── second.md          // <- http://site.com/quote/second/
+            ├── first.md           // <- http://1.com/quote/first/
+            └── second.md          // <- http://1.com/quote/second/
 
 ## Sections and Types
 
index e6f3ec50ca4a064121ba03c9eed09163c03b7412..0011a577a5f0ca415b0666d7803b544209f0335d 100644 (file)
@@ -20,16 +20,16 @@ templates that the new type will use.
 It is essential to provide the single render view template as well as a
 list view template.
 
-**Step 1:**
+### Step 1:
 Create a directory with the name of the type in layouts.Type is always singular.  *Eg /layouts/post*.
 
-**Step 2:**
+### Step 2:
 Create a file called single.html inside your directory. *Eg /layouts/post/single.html*.
 
-**Step 3:**
+### Step 3:
 Create a file with the same name as your directory in /layouts/indexes/. *Eg /layouts/indexes/post.html*.
 
-**Step 4:**
+### Step 4:
 Many sites support rendering content in a few different ways, for
 instance a single page view and a summary view to be used when displaying a list
 of contents on a single page. Hugo makes no assumptions here about how you want
index e42e4d76e801f7da7f0bb54c5043bc0c9256eb24..fc1390ba794a9846f3bcbcb5e770620052ea40ba 100644 (file)
@@ -16,12 +16,13 @@ Luckily, this can be handled easily with aliases in Hugo.
 
 ## Example
 **content/posts/my-awesome-blog-post.md**
-
-    ---
-    aliases:
-        - /posts/my-original-url/
-        - /2010/even-earlier-url.html
-    ---
+{{% highlight yaml %}}
+---
+aliases:
+    - /posts/my-original-url/
+    - /2010/even-earlier-url.html
+---
+{{% /highlight %}}
 
 Now when you go to any of the aliases locations they
 will redirect to the page.
index 6ddab408822ca0840caeaa88e35d41fed508181c..ed7384d9fd0a0d260b7051e75c2f7b4b3dcf4d46 100644 (file)
@@ -6,32 +6,72 @@ groups: ["extras"]
 groups_weight: 10
 ---
 
-Because Hugo uses markdown for its content format, it was clear that there's a lot of things that 
-markdown doesn't support well. This is good, the simple nature of markdown is exactly why we chose it.
+Because Hugo uses markdown for its simple content format, however there's a lot of things that 
+markdown doesn't support well.
 
-However we cannot accept being constrained by our simple format. Also unacceptable is writing raw
+We are unwilling to accept being constrained by our simple format. Also unacceptable is writing raw
 html in our markdown every time we want to include unsupported content such as a video. To do 
 so is in complete opposition to the intent of using a bare bones format for our content and 
 utilizing templates to apply styling for display.
 
-To avoid both of these limitations Hugo has full support for shortcodes.
+To avoid both of these limitations Hugo created shortcodes.
 
-### What is a shortcode?
-A shortcode is a simple snippet inside a markdown file that Hugo will render using a template.
+## What is a shortcode?
+A shortcode is a simple snippet inside a markdown file that Hugo will render using a predefined template.
 
-Short codes are designated by the opening and closing characters of '{{&#37;' and '%}}' respectively.
-Short codes are space delimited. The first word is always the name of the shortcode.  Following the 
-name are the parameters. The author of the shortcode can choose if the short code
-will use positional parameters or named parameters (but not both). A good rule of thumb is that if a
-short code has a single required value in the case of the youtube example below then positional
-works very well. For more complex layouts with optional parameters named parameters work best.
+An example of a shortcode would be `{{% video http://urlToVideo %}}`
+
+Shortcodes are created by placing a template file in `layouts/shortcodes/`. The
+name of the file becomes the name of the shortcode (without the extension).
+
+In your content files a shortcode can be called by using '{{&#37; name parameters
+%}}' respectively. Shortcodes are space delimited (parameters with spaces
+can be quoted). 
+
+The first word is always the name of the shortcode.  Following
+the name are the parameters.
+
+The author of the shortcode can choose if the short code will use positional
+parameters or named parameters (but not both). A good rule of thumb is that if
+a short code has a single required value in the case of the youtube example
+below then positional works very well. For more complex layouts with optional
+parameters named parameters work best.
 
 The format for named parameters models that of html with the format name="value"
 
-### Example: youtube
-*Example has an extra space so Hugo doesn't actually render it*
+Lastly like HTML, shortcodes can be singular or paired. An example of a paired
+shortcode would be:
+
+    {{% code_highlight %}} A bunch of code here {{% /code_highlight %}} 
+
+Shortcodes are paired with an opening shortcode identical to a single shortcode
+and a closing shortcode.
+
+## Creating a shortcode
+
+All that you need to do to create a shortcode is place a template in the layouts/shortcodes directory.
 
-    {{ % youtube 09jf3ow9jfw %}}
+The template name will be the name of the shortcode.
+
+**Inside the template**
+
+To access a parameter by either position or name the index method can be used.
+
+    {{ index .Params 0 }}
+    or
+    {{ index .Params "class" }}
+
+To check if a parameter has been provided use the isset method provided by Hugo.
+
+    {{ if isset .Params "class"}} class="{{ index .Params "class"}}" {{ end }}
+
+For paired shortcodes the variable .Inner is available which contains all of
+the content between the opening and closing shortcodes. **Simply using this
+variable is the only difference between single and paired shortcodes.**
+
+## Single Positional Example: youtube
+
+    {{% youtube 09jf3ow9jfw %}}
 
 Would load the template /layouts/shortcodes/youtube.html
 
@@ -50,7 +90,7 @@ This would be rendered as
     </iframe>
     </div>
 
-### Example: image with caption
+## Single Named Example: image with caption
 *Example has an extra space so Hugo doesn't actually render it*
 
     {{ % img src="/media/spf13.jpg" title="Steve Francia" %}}
@@ -85,23 +125,29 @@ Would be rendered as:
         </figcaption>
     </figure>
 
+## Paired Example: Highlight
+*Hugo already ships with the highlight shortcode*
 
-### Creating a shortcode
-
-All that you need to do to create a shortcode is place a template in the layouts/shortcodes directory.
-
-The template name will be the name of the shortcode.
+*Example has an extra space so Hugo doesn't actually render it*.
 
-**Inside the template**
+    {{% highlight html %}}
+    <html>
+        <body> This HTML </body>
+    </html>
+    {{% /highlight %}}
 
-To access a parameter by either position or name the index method can be used.
+The template for this utilizes the following code (already include in hugo)
 
-    {{ index .Params 0 }}
-    or
-    {{ index .Params "class" }}
+    {{ $lang := index .Params 0 }}{{ highlight .Inner $lang }}
 
-To check if a parameter has been provided use the isset method provided by Hugo.
+And will be rendered as:
 
-    {{ if isset .Params "class"}} class="{{ index .Params "class"}}" {{ end }}
+    <div class="highlight" style="background: #272822"><pre style="line-height: 125%"><span style="color: #f92672">&lt;html&gt;</span>
+        <span style="color: #f92672">&lt;body&gt;</span> This HTML <span style="color: #f92672">&lt;/body&gt;</span>
+    <span style="color: #f92672">&lt;/html&gt;</span>
+    </pre></div>
 
+Please notice that this template makes use of a hugo specific template function
+called highlight which uses pygments to add the highlighting code.
 
+More shortcode examples can be found at [spf13.com](https://github.com/spf13/spf13.com/tree/master/layouts/shortcodes)
index 9915989144f7c42e52caae3f43674bb6dcad860b..bfedde5720f31cf8ca5a7303480db3e4d0a55cfd 100644 (file)
@@ -15,44 +15,50 @@ First step is to define the index in your config file.
 important to provide both here. We require this, rather than using inflection in
 effort to support as many languages as possible.*
 
-    ---
-    indexes:
-        category: "categories"
-    baseurl: "http://spf13.com/"
-    title: "Steve Francia is spf13.com"
-    ---
+{{% highlight yaml %}}
+---
+indexes:
+category: "categories"
+baseurl: "http://spf13.com/"
+title: "Steve Francia is spf13.com"
+---
+{{% /highlight %}}
 
 ### /layouts/indexes/category.html
 
 For each index type a template needs to be provided to render the index page.
-In the case of categories, this will render the content for /categories/CATEGORYNAME/.
+In the case of categories, this will render the content for /categories/`CATEGORYNAME`/.
 
-    {{ template "chrome/header.html" . }}
-    {{ template "chrome/subheader.html" . }}
+{{% highlight html %}}
+{{ template "chrome/header.html" . }}
+{{ template "chrome/subheader.html" . }}
 
-    <section id="main">
-      <div>
-       <h1 id="title">{{ .Title }}</h1>
-        {{ range .Data.Pages }}
-            {{ .Render "summary"}}
-        {{ end }}
-      </div>
-    </section>
+<section id="main">
+<div>
+<h1 id="title">{{ .Title }}</h1>
+{{ range .Data.Pages }}
+{{ .Render "summary"}}
+{{ end }}
+</div>
+</section>
 
-    {{ template "chrome/footer.html" }}
+{{ template "chrome/footer.html" }}
+{{% /highlight %}}
 
 
 ### Assigning indexes to content
 
 Make sure that the index is set in the front matter:
 
-    {
-        "title": "Hugo: A fast and flexible static site generator",
-        "categories": [
-            "Development",
-            "golang",
-            "Blogging"
-        ],
-        "slug": "hugo"
-    }
+{{% highlight json %}}
+{
+    "title": "Hugo: A fast and flexible static site generator",
+    "categories": [
+        "Development",
+        "golang",
+        "Blogging"
+    ],
+    "slug": "hugo"
+}
+{{% /highlight %}}
 
index 1622cef54b86937bed5912a9ec70185ce28228d9..88596e9959c790746ed4950b766296e8d5496747 100644 (file)
@@ -5,8 +5,8 @@ linktitle: "Displaying"
 groups: ["indexes"]
 groups_weight: 20
 ---
-# For Content
-### Index values assigned to this content
+
+## Rendering index values assigned to this content
 
 Within your content templates you may wish to display 
 the indexes that that piece of content is assigned to.
@@ -16,31 +16,34 @@ define indexes for content, the indexes assigned to
 each content piece are located in the usual place 
 (.Params.`plural`)
 
-#### Example
+### Example
 
-    <ul id="tags">
-      {{ range .Params.tags }}
-        <li><a href="tags/{{ . | urlize }}">{{ . }}</a> </li>
-      {{ end }}
-    </ul>
+{{% highlight html %}}
+<ul id="tags">
+  {{ range .Params.tags }}
+    <li><a href="tags/{{ . | urlize }}">{{ . }}</a> </li>
+  {{ end }}
+</ul>
+{{% /highlight %}}
 
-# Anywhere
-### Displaying all keys for an index
+## Rendering a Site's Indexes
 
-If you wish to display the list of all keys for an index you can 
-find retrieve them from the `.Site` variable.
+If you wish to display the list of all keys for an index you can find retrieve
+them from the `.Site` variable which is available on every page.
 
 This may take the form of a tag cloud, a menu or simply a list.
 
 The following example displays all tag keys:
 
-#### Example
+### Example
 
-    <ul id="all-tags">
-      {{ range .Site.Indexes.tags }}
-        <li><a href="/tags/{{ .Name | urlize }}">{{ .Name }}</a></li>  
-      {{ end }}
-    </ul>
+{{% highlight html %}}
+<ul id="all-tags">
+  {{ range .Site.Indexes.tags }}
+    <li><a href="/tags/{{ .Name | urlize }}">{{ .Name }}</a></li>  
+  {{ end }}
+</ul>
+{{% /highlight %}}
 
 ## Creating a menu based on indexes
 
@@ -53,57 +56,64 @@ called menu.html, then include it using the
 `{{ template "chrome/menu.html" . }}` syntax.
 
 
+
+### Example complete menu.html file
 This example will list all indexes, each of their keys and all the content assigned to each key.
-#### Example complete menu.html file
-
-    <section id="menu">
-      <ul>
-        {{ range $indexname, $index := .Site.Indexes }}
-          <li><a href="/{{ $indexname | urlize }}">{{ $indexname }}</a> 
-            <ul> 
-              {{ range $key, $value := $index }}
-              <li> {{ $key }} </li>
-                    <ul>
-                    {{ range $value.Pages }}
-                        <li hugo-nav="{{ .RelPermalink}}"><a href="{{ .Permalink}}"> {{ .LinkTitle }} </a> </li>
-                    {{ end }}
-                    </ul>
-              {{ end }}
-            </ul>
-          </li> 
-        {{ end }}
-      </ul>
-    </section>
 
+{{% highlight html %}}
+<section id="menu">
+  <ul>
+    {{ range $indexname, $index := .Site.Indexes }}
+      <li><a href="/{{ $indexname | urlize }}">{{ $indexname }}</a> 
+        <ul> 
+          {{ range $key, $value := $index }}
+          <li> {{ $key }} </li>
+                <ul>
+                {{ range $value.Pages }}
+                    <li hugo-nav="{{ .RelPermalink}}"><a href="{{ .Permalink}}"> {{ .LinkTitle }} </a> </li>
+                {{ end }}
+                </ul>
+          {{ end }}
+        </ul>
+      </li> 
+    {{ end }}
+  </ul>
+</section>
+{{% /highlight %}}
 
+### menu.html using a single index
 It is more likely that you would want to use a single index for navigation.
 In this example we are using the `groups` index for our menu.
-#### Example menu.html file using a single index
 
-    <section id="menu">
+{{% highlight html %}}
+<section id="menu">
+    <ul>
+        {{ range $key, $index := .Site.Indexes.groups }}
+        <li> {{ $key }} </li>
         <ul>
-            {{ range $key, $index := .Site.Indexes.groups }}
-            <li> {{ $key }} </li>
-            <ul>
-                {{ range $index.Pages }}
-                <li hugo-nav="{{ .RelPermalink}}"><a href="{{ .Permalink}}"> {{ .LinkTitle }} </a> </li>
-                {{ end }}
-            </ul>
+            {{ range $index.Pages }}
+            <li hugo-nav="{{ .RelPermalink}}"><a href="{{ .Permalink}}"> {{ .LinkTitle }} </a> </li>
             {{ end }}
         </ul>
-    </section>
+        {{ end }}
+    </ul>
+</section>
+{{% /highlight %}}
+
+
+### menu.html using a single index ordered by Popularity
 
-Or order the keys by Popularity
-#### Example menu.html file using a single index
-    <section id="menu">
+{{% highlight html %}}
+<section id="menu">
+    <ul>
+        {{ range .Site.Indexes.groups.ByCount }}
+        <li> {{ .Name }} </li>
         <ul>
-            {{ range .Site.Indexes.groups.ByCount }}
-            <li> {{ .Name }} </li>
-            <ul>
-                {{ range .Pages }}
-                <li hugo-nav="{{ .RelPermalink}}"><a href="{{ .Permalink}}"> {{ .LinkTitle }} </a> </li>
-                {{ end }}
-            </ul>
+            {{ range .Pages }}
+            <li hugo-nav="{{ .RelPermalink}}"><a href="{{ .Permalink}}"> {{ .LinkTitle }} </a> </li>
             {{ end }}
         </ul>
-    </section>
+        {{ end }}
+    </ul>
+</section>
+{{% /highlight %}}
index c3da35102bd20ef238000e8f904dcc79c6853594..552c71fa92311542335ca1e55506d3ec6fb82e07 100644 (file)
@@ -8,7 +8,7 @@ groups_weight: 40
 ---
 
 An index list is a list of all the keys that are contained in the index. When a
-template is present, this will be rendered at /IndexPlural/
+template is present, this will be rendered at `/IndexPlural/`
 
 Hugo also supports creating pages that list your values for each index along
 with the number of content items associated with the index key. These are
@@ -22,44 +22,46 @@ Hugo can order the meta data in two different ways. It can be ordered by the
 number of content assigned to that key or alphabetically.
 
 
-#### Example indexes.html file (alphabetical)
-
-    {{ template "chrome/header.html" . }}
-    {{ template "chrome/subheader.html" . }}
-
-    <section id="main">
-      <div>
-       <h1 id="title">{{ .Title }}</h1>
-       <ul>
-       {{ $data := .Data }}
-        {{ range $key, $value := .Data.Index.Alphabetical }}
-        <li><a href="{{ $data.Plural }}/{{ $value.Name | urlize }}"> {{ $value.Name }} </a> {{ $value.Count }} </li>
-        {{ end }}
-       </ul>
-      </div>
-    </section>
-
-    {{ template "chrome/footer.html" }}
-
-
-#### Example indexes.html file (ordered)
-
-    {{ template "chrome/header.html" . }}
-    {{ template "chrome/subheader.html" . }}
-
-    <section id="main">
-      <div>
-       <h1 id="title">{{ .Title }}</h1>
-       <ul>
-       {{ $data := .Data }}
-        {{ range $key, $value := .Data.Index.ByCount }}
-        <li><a href="{{ $data.Plural }}/{{ $value.Name | urlize }}"> {{ $value.Name }} </a> {{ $value.Count }} </li>
-        {{ end }}
-       </ul>
-      </div>
-    </section>
-
-    {{ template "chrome/footer.html" }}
+### Example indexes.html file (alphabetical)
+
+{{% highlight html %}}
+{{ template "chrome/header.html" . }}
+{{ template "chrome/subheader.html" . }}
+
+<section id="main">
+  <div>
+   <h1 id="title">{{ .Title }}</h1>
+   <ul>
+   {{ $data := .Data }}
+    {{ range $key, $value := .Data.Index.Alphabetical }}
+    <li><a href="{{ $data.Plural }}/{{ $value.Name | urlize }}"> {{ $value.Name }} </a> {{ $value.Count }} </li>
+    {{ end }}
+   </ul>
+  </div>
+</section>
+{{ template "chrome/footer.html" }}
+{{% /highlight %}}
+
+### Example indexes.html file (ordered)
+
+{{% highlight html %}}
+{{ template "chrome/header.html" . }}
+{{ template "chrome/subheader.html" . }}
+
+<section id="main">
+  <div>
+   <h1 id="title">{{ .Title }}</h1>
+   <ul>
+   {{ $data := .Data }}
+    {{ range $key, $value := .Data.Index.ByCount }}
+    <li><a href="{{ $data.Plural }}/{{ $value.Name | urlize }}"> {{ $value.Name }} </a> {{ $value.Count }} </li>
+    {{ end }}
+   </ul>
+  </div>
+</section>
+
+{{ template "chrome/footer.html" }}
+{{% /highlight %}}
 
 ### Variables available to list of indexes pages.
 
index b1952b4c527fba2b41c2f28c2350871362f7a7ca..6311e68d83e0d118267d83ef5ffcd3d79a13ee82 100644 (file)
@@ -17,21 +17,25 @@ Indexes can be ordered by either alphabetical key or by the number of content pi
 
 ### Order Alphabetically Example:
 
-       <ul>
-       {{ $data := .Data }}
-        {{ range $key, $value := .Data.Index.Alphabetical }}
-        <li><a href="{{ $data.Plural }}/{{ $value.Name | urlize }}"> {{ $value.Name }} </a> {{ $value.Count }} </li>
-        {{ end }}
-       </ul>
+{{% highlight html %}}
+<ul>
+{{ $data := .Data }}
+{{ range $key, $value := .Data.Index.Alphabetical }}
+<li><a href="{{ $data.Plural }}/{{ $value.Name | urlize }}"> {{ $value.Name }} </a> {{ $value.Count }} </li>
+{{ end }}
+</ul>
+{{% /highlight %}}
 
 ### Order by Popularity Example:
 
-       <ul>
-       {{ $data := .Data }}
-        {{ range $key, $value := .Data.Index.ByCount }}
-        <li><a href="{{ $data.Plural }}/{{ $value.Name | urlize }}"> {{ $value.Name }} </a> {{ $value.Count }} </li>
-        {{ end }}
-       </ul>
+{{% highlight html %}}
+<ul>
+{{ $data := .Data }}
+{{ range $key, $value := .Data.Index.ByCount }}
+<li><a href="{{ $data.Plural }}/{{ $value.Name | urlize }}"> {{ $value.Name }} </a> {{ $value.Count }} </li>
+{{ end }}
+</ul>
+{{% /highlight %}}
 
 
 [See Also Index Lists](/indexes/lists/)
index 1c8193a01cb92536896848b6000d39b9930add28..b72c1c5b6997615700878175073280d765c5807e 100644 (file)
@@ -1,5 +1,5 @@
 ---
-title: "Index Overview"
+title: "Indexes"
 date: "2013-07-01"
 aliases: ["/doc/indexes/", "/extras/indexes"]
 linktitle: "Overview"
@@ -17,9 +17,9 @@ navigation, series and many more. Just think of an index as way to organize simi
 It's important to understand what Indexes do. At it's most basic form an index
 is simply a map of a key to a list of content values.
 
-In the hugo internals this is stored as Site.Indexes[Plural][key][]pages.
+In the hugo internals this is stored as `Site.Indexes[Plural][key][]pages`.
 For example all the content tagged with GoLang would be found at 
-Site.Indexes["tags"]["golang"].
+`Site.Indexes["tags"]["golang"]`.
 
 For a
 more complete example see the source of [this docs site](http://github.com/spf13/hugo/docs/).
@@ -35,16 +35,17 @@ we could use an inflection library to pluralize this, they currently
 support only a few languages, so instead we've opted for user defined
 pluralization.
 
-**config.yaml**
-
-    ---
-    indexes:
-        tag: "tags"
-        category: "categories"
-    baseurl: "http://spf13.com/"
-    title: "Steve Francia is spf13.com"
-    ---
+### config.yaml
 
+{{% highlight yaml %}}
+---
+indexes:
+    tag: "tags"
+    category: "categories"
+baseurl: "http://spf13.com/"
+title: "Steve Francia is spf13.com"
+---
+{{% /highlight %}}
 
 ## Assigning index values to content
 
@@ -57,19 +58,22 @@ and assign all keys you want this content to match against.
 
 **Index values are case insensitive**
 
-#### Example
-    {
-        "title": "Hugo: A fast and flexible static site generator",
-        "tags": [
-            "Development",
-            "golang",
-            "fast",
-            "Blogging"
-        ],
-        "categories" : [
-            "Development"
-        ]
-        "slug": "hugo",
-        "project_url": "http://github.com/spf13/hugo"
-    }
+### Example
+
+{{% highlight json %}}
+{
+    "title": "Hugo: A fast and flexible static site generator",
+    "tags": [
+        "Development",
+        "golang",
+        "fast",
+        "Blogging"
+    ],
+    "categories" : [
+        "Development"
+    ]
+    "slug": "hugo",
+    "project_url": "http://github.com/spf13/hugo"
+}
+{{% /highlight %}}
 
index 89cc64101cb8063b03b534cda2f0eaa685b8b815..6181efb44a6c560df4dfca311df911e32d2e4c60 100644 (file)
@@ -14,7 +14,7 @@ addresses the template used for the first type.
 
 ## Creating index templates
 For each index type a template needs to be provided to render the index page.
-In the case of tags, this will render the content for /tags/TAGNAME/.
+In the case of tags, this will render the content for `/tags/TAGNAME/`.
 
 The template must be called the singular name of the index and placed in 
 layouts/indexes
@@ -26,7 +26,7 @@ layouts/indexes
 
 The template will be provided Data about the index. 
 
-### Variables
+## Variables
 
 The following variables are available to the index template:
 
@@ -37,19 +37,19 @@ The following variables are available to the index template:
 **.Data.Pages** The content that is assigned this index.<br>
 **.Data.`singular`** The index itself.<br>
 
-#### Example
-
-    {{ template "chrome/header.html" . }}
-    {{ template "chrome/subheader.html" . }}
-
-    <section id="main">
-      <div>
-       <h1 id="title">{{ .Title }}</h1>
-        {{ range .Data.Pages }}
-            {{ .Render "summary"}}
-        {{ end }}
-      </div>
-    </section>
-
-    {{ template "chrome/footer.html" }}
-
+## Example
+{{% highlight html %}}
+{{ template "chrome/header.html" . }}
+{{ template "chrome/subheader.html" . }}
+
+<section id="main">
+  <div>
+   <h1 id="title">{{ .Title }}</h1>
+    {{ range .Data.Pages }}
+        {{ .Render "summary"}}
+    {{ end }}
+  </div>
+</section>
+
+{{ template "chrome/footer.html" }}
+{{% /highlight %}}
index 70b266bc19a2af9deb2365aff2f5e196479b4655..782e03dda207ec26771ef510d1b1e437c6e9fcbb 100644 (file)
@@ -30,53 +30,56 @@ used for both nodes and pages we can use the same chrome for both.
 ## example header.html
 This header template is used for [spf13.com](http://spf13.com).
 
-    <!DOCTYPE html>
-    <html class="no-js" lang="en-US" prefix="og: http://ogp.me/ns# fb: http://ogp.me/ns/fb#">
-    <head>
-        <meta charset="utf-8">
+{{% highlight html %}}
+<!DOCTYPE html>
+<html class="no-js" lang="en-US" prefix="og: http://ogp.me/ns# fb: http://ogp.me/ns/fb#">
+<head>
+    <meta charset="utf-8">
 
-        {{ template "chrome/meta.html" . }}
+    {{ template "chrome/meta.html" . }}
 
-        <base href="{{ .Site.BaseUrl }}">
-        <title> {{ .Title }} : spf13.com </title>
-        <link rel="canonical" href="{{ .Permalink }}">
-        {{ if .RSSlink }}<link href="{{ .RSSlink }}" rel="alternate" type="application/rss+xml" title="{{ .Title }}" />{{ end }}
-
-        {{ template "chrome/head_includes.html" . }}
-    </head>
-    <body lang="en">
+    <base href="{{ .Site.BaseUrl }}">
+    <title> {{ .Title }} : spf13.com </title>
+    <link rel="canonical" href="{{ .Permalink }}">
+    {{ if .RSSlink }}<link href="{{ .RSSlink }}" rel="alternate" type="application/rss+xml" title="{{ .Title }}" />{{ end }}
 
+    {{ template "chrome/head_includes.html" . }}
+</head>
+<body lang="en">
+{{% /highlight %}}
 
 
 ## example footer.html
 This header template is used for [spf13.com](http://spf13.com).
 
-    <footer>
-      <div>
-        <p>
-        &copy; 2013 Steve Francia.
-        <a href="http://creativecommons.org/licenses/by/3.0/" title="Creative Commons Attribution">Some rights reserved</a>; 
-        please attribute properly and link back. Hosted by <a href="http://servergrove.com">ServerGrove</a>.
-        </p>
-      </div>
-    </footer>
-    <script type="text/javascript">
-
-      var _gaq = _gaq || [];
-      _gaq.push(['_setAccount', 'UA-XYSYXYSY-X']);
-      _gaq.push(['_trackPageview']);
-
-      (function() {
-        var ga = document.createElement('script');
-        ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 
-            'http://www') + '.google-analytics.com/ga.js';
-        ga.setAttribute('async', 'true');
-        document.documentElement.firstChild.appendChild(ga);
-      })();
-
-    </script>
-    </body>
-    </html>
+{{% highlight html %}}
+<footer>
+  <div>
+    <p>
+    &copy; 2013 Steve Francia.
+    <a href="http://creativecommons.org/licenses/by/3.0/" title="Creative Commons Attribution">Some rights reserved</a>; 
+    please attribute properly and link back. Hosted by <a href="http://servergrove.com">ServerGrove</a>.
+    </p>
+  </div>
+</footer>
+<script type="text/javascript">
+
+  var _gaq = _gaq || [];
+  _gaq.push(['_setAccount', 'UA-XYSYXYSY-X']);
+  _gaq.push(['_trackPageview']);
+
+  (function() {
+    var ga = document.createElement('script');
+    ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 
+        'http://www') + '.google-analytics.com/ga.js';
+    ga.setAttribute('async', 'true');
+    document.documentElement.firstChild.appendChild(ga);
+  })();
+
+</script>
+</body>
+</html>
+{{% /highlight %}}
 
 **For examples of referencing these templates, see [content
 templates](/layout/content/) and [homepage templates](/layout/homepage/)**
index 74eb2192f467ce87418bff6607f74286bb6566c5..c3c0f9b7ab8cded437b5535dffbdcb7f08e159ca 100644 (file)
@@ -12,7 +12,8 @@ variables](/layout/variables/) available to use in the templates.
 bootstrapping a new site and template.*
 
 In addition to the standard node variables, the homepage has access to
-all site content accessible from .Data.Pages
+all site content accessible from .Data.Pages . Details on how to use this 
+list of pages can be found in [Lists](/indexes/lists/)
 
 
     ▾ layouts/
@@ -21,32 +22,35 @@ all site content accessible from .Data.Pages
 
 ## example index.html
 This content template is used for [spf13.com](http://spf13.com).
-It makes use of [chrome templates](/layout/chrome)
 
-    <!DOCTYPE html>
-    <html class="no-js" lang="en-US" prefix="og: http://ogp.me/ns# fb: http://ogp.me/ns/fb#">
-    <head>
-        <meta charset="utf-8">
+It makes use of [chrome templates](/layout/chrome) and uses a [List](/indexes/lists/)
 
-        {{ template "chrome/meta.html" . }}
+{{% highlight html %}}
+<!DOCTYPE html>
+<html class="no-js" lang="en-US" prefix="og: http://ogp.me/ns# fb: http://ogp.me/ns/fb#">
+<head>
+    <meta charset="utf-8">
 
-        <base href="{{ .Site.BaseUrl }}">
-        <title>{{ .Site.Title }}</title>
-        <link rel="canonical" href="{{ .Permalink }}">
-        <link href="{{ .RSSlink }}" rel="alternate" type="application/rss+xml" title="{{ .Site.Title }}" />
+    {{ template "chrome/meta.html" . }}
 
-        {{ template "chrome/head_includes.html" . }}
-    </head>
-    <body lang="en">
+    <base href="{{ .Site.BaseUrl }}">
+    <title>{{ .Site.Title }}</title>
+    <link rel="canonical" href="{{ .Permalink }}">
+    <link href="{{ .RSSlink }}" rel="alternate" type="application/rss+xml" title="{{ .Site.Title }}" />
 
-    {{ template "chrome/subheader.html" . }}
+    {{ template "chrome/head_includes.html" . }}
+</head>
+<body lang="en">
 
-    <section id="main">
-      <div>
-        {{ range first 10 .Data.Pages }}
-            {{ .Render "summary"}}
-        {{ end }}
-      </div>
-    </section>
+{{ template "chrome/subheader.html" . }}
 
-    {{ template "chrome/footer.html" }}
+<section id="main">
+  <div>
+    {{ range first 10 .Data.Pages }}
+        {{ .Render "summary"}}
+    {{ end }}
+  </div>
+</section>
+
+{{ template "chrome/footer.html" }}
+{{% /highlight %}}
index 0301e53e1bcec58bc84d5c7c2d198080126a0159..6f012cd036498322186f70dbbb0696d07e5467f8 100644 (file)
@@ -43,21 +43,23 @@ It makes use of [chrome templates](/layout/chrome). All examples use a
 [view](/layout/views/) called either "li" or "summary" which this example site
 defined.
 
-    {{ template "chrome/header.html" . }}
-    {{ template "chrome/subheader.html" . }}
-
-    <section id="main">
-      <div>
-       <h1 id="title">{{ .Title }}</h1>
-            <ul id="list">
-                {{ range .Data.Pages }}
-                    {{ .Render "li"}}
-                {{ end }}
-            </ul>
-      </div>
-    </section>
-
-    {{ template "chrome/footer.html" }}
+{{% highlight html %}}
+{{ template "chrome/header.html" . }}
+{{ template "chrome/subheader.html" . }}
+
+<section id="main">
+  <div>
+   <h1 id="title">{{ .Title }}</h1>
+        <ul id="list">
+            {{ range .Data.Pages }}
+                {{ .Render "li"}}
+            {{ end }}
+        </ul>
+  </div>
+</section>
+
+{{ template "chrome/footer.html" }}
+{{% /highlight %}}
 
 ## Example index template (tag.html)
 This content template is used for [spf13.com](http://spf13.com).
@@ -65,20 +67,21 @@ It makes use of [chrome templates](/layout/chrome). All examples use a
 [view](/layout/views/) called either "li" or "summary" which this example site
 defined.
 
-    {{ template "chrome/header.html" . }}
-    {{ template "chrome/subheader.html" . }}
+{{% highlight html %}}
+{{ template "chrome/header.html" . }}
+{{ template "chrome/subheader.html" . }}
 
-    <section id="main">
-      <div>
-       <h1 id="title">{{ .Title }}</h1>
-        {{ range .Data.Pages }}
-            {{ .Render "summary"}}
-        {{ end }}
-      </div>
-    </section>
-
-    {{ template "chrome/footer.html" }}
+<section id="main">
+  <div>
+   <h1 id="title">{{ .Title }}</h1>
+    {{ range .Data.Pages }}
+        {{ .Render "summary"}}
+    {{ end }}
+  </div>
+</section>
 
+{{ template "chrome/footer.html" }}
+{{% /highlight %}}
 
 ## Example listing of indexes template (indexes.html)
 This content template is used for [spf13.com](http://spf13.com).
@@ -95,29 +98,31 @@ the latter uses .Data.OrderedIndex. .Data.Index is alphabetical by key name, whi
 .Data.Orderedindex is ordered by the quantity of content assigned to that particular
 index key.  In practice you would only use one of these approaches.
 
-    {{ template "chrome/header.html" . }}
-    {{ template "chrome/subheader.html" . }}
-
-    <section id="main">
-      <div>
-       <h1 id="title">{{ .Title }}</h1>
-
-       <ul>
-       {{ $data := .Data }}
-        {{ range $key, $value := .Data.Index }}
-        <li><a href="{{ $data.Plural }}/{{ $key | urlize }}"> {{ $key }} </a> {{ len $value }} </li>
-        {{ end }}
-       </ul>
-      </div>
-
-       <ul>
-        {{ range $data.OrderedIndex }}
-        <li><a href="{{ $data.Plural }}/{{ .Name | urlize }}"> {{ .Name }} </a> {{ .Count }} </li>
-        {{ end }}
-       </ul>
-    </section>
-
-    {{ template "chrome/footer.html" }}
+{{% highlight html %}}
+{{ template "chrome/header.html" . }}
+{{ template "chrome/subheader.html" . }}
+
+<section id="main">
+  <div>
+   <h1 id="title">{{ .Title }}</h1>
+
+   <ul>
+   {{ $data := .Data }}
+    {{ range $key, $value := .Data.Index }}
+    <li><a href="{{ $data.Plural }}/{{ $key | urlize }}"> {{ $key }} </a> {{ len $value }} </li>
+    {{ end }}
+   </ul>
+  </div>
+
+   <ul>
+    {{ range $data.OrderedIndex }}
+    <li><a href="{{ $data.Plural }}/{{ .Name | urlize }}"> {{ .Name }} </a> {{ .Count }} </li>
+    {{ end }}
+   </ul>
+</section>
+
+{{ template "chrome/footer.html" }}
+{{% /highlight %}}
 
 
 
index 18330ca92eee7f8dcd8b3f8600d012c91c383930..ea6042c37f9342955b4239d0f6c82ac14ef8d4bc 100644 (file)
@@ -21,27 +21,28 @@ all site content accessible from .Data.Pages
 This rss template is used for [spf13.com](http://spf13.com). It adheres to the
 ATOM 2.0 Spec.
 
-
-    <rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
-      <channel>
-          <title>{{ .Title }} on {{ .Site.Title }} </title>
-        <link>{{ .Permalink }}</link>
-        <language>en-us</language>
-        <author>Steve Francia</author>
-        <rights>Copyright (c) 2008 - 2013, Steve Francia; all rights reserved.</rights>
-        <updated>{{ .Date }}</updated>
-        {{ range .Data.Pages }}
-        <item>
-          <title>{{ .Title }}</title>
-          <link>{{ .Permalink }}</link>
-          <pubDate>{{ .Date.Format "Mon, 02 Jan 2006 15:04:05 MST" }}</pubDate>
-          <author>Steve Francia</author>
-          <guid>{{ .Permalink }}</guid>
-          <description>{{ .Content | html }}</description>
-        </item>
-        {{ end }}
-      </channel>
-    </rss>
+{{% highlight xml %}}
+<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
+  <channel>
+      <title>{{ .Title }} on {{ .Site.Title }} </title>
+    <link>{{ .Permalink }}</link>
+    <language>en-us</language>
+    <author>Steve Francia</author>
+    <rights>Copyright (c) 2008 - 2013, Steve Francia; all rights reserved.</rights>
+    <updated>{{ .Date }}</updated>
+    {{ range .Data.Pages }}
+    <item>
+      <title>{{ .Title }}</title>
+      <link>{{ .Permalink }}</link>
+      <pubDate>{{ .Date.Format "Mon, 02 Jan 2006 15:04:05 MST" }}</pubDate>
+      <author>Steve Francia</author>
+      <guid>{{ .Permalink }}</guid>
+      <description>{{ .Content | html }}</description>
+    </item>
+    {{ end }}
+  </channel>
+</rss>
+{{% /highlight %}}
 
 *Important: Hugo will automatically add the following header line to this file
 on render...please don't include this in the template as it's not valid HTML.*
index c79a67a7f0e13882873cb2074fed5e894edf2179..400e429b9b1171273b14259b0dbab96149af57fb 100644 (file)
@@ -20,19 +20,19 @@ is a great place to start.
 There are 6 different kinds of templates that Hugo works with.
 
 ### [Homepage](/layout/homepage/)
-The homepage of your site.
+The homepage of your site
 
 ### [RSS](/layout/rss/)
-Used to render all rss documents.
+Used to render all rss documents
 
 ### [Index](/layout/indexes)
-Page that list multiple pieces of content.
+Page that list multiple pieces of content
 
 ### [Content](/layout/content)
-Templates to render a single piece of content.
+Render a single piece of content
 
 ### [Views](/layout/views)
-Different ways of rendering each content type
+Different view of a single piece of content type
 
 ### [Chrome](/layout/chrome)
-Simply the decoration of your site.
+Support for the above templates
index 67a9b42620ebd79754bc5b9b91e27de31f51bd7d..ae22211f9dee105b2f373894ec28584fdc505df7 100644 (file)
@@ -43,38 +43,44 @@ variables](/layout/variables) for a complete list.
 ## Example li.html
 This content template is used for [spf13.com](http://spf13.com).
 
-    <li>
-      <a href="{{ .Permalink }}">{{ .Title }}</a>
-      <div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
-    </li>
+{{% highlight html %}}
+<li>
+<a href="{{ .Permalink }}">{{ .Title }}</a>
+<div class="meta">{{ .Date.Format "Mon, Jan 2, 2006" }}</div>
+</li>
+{{% /highlight %}}
 
 ## Example summary.html
 This content template is used for [spf13.com](http://spf13.com).
 
-    <article class="post">
-        <header>
-          <h2><a href='{{ .Permalink }}'> {{ .Title }}</a> </h2>
-          <div class="post-meta">{{ .Date.Format "Mon, Jan 2, 2006" }} - {{ .FuzzyWordCount }} Words </div>
-        </header>
+{{% highlight html %}}
+<article class="post">
+<header>
+<h2><a href='{{ .Permalink }}'> {{ .Title }}</a> </h2>
+<div class="post-meta">{{ .Date.Format "Mon, Jan 2, 2006" }} - {{ .FuzzyWordCount }} Words </div>
+</header>
 
-        {{ .Summary }}
-        <footer>
-            <a href='{{ .Permalink }}'><nobr>Read more →</nobr></a>
-        </footer>
-    </article>
+{{ .Summary }}
+<footer>
+<a href='{{ .Permalink }}'><nobr>Read more →</nobr></a>
+</footer>
+</article>
+{{% /highlight %}}
 
 
 ## Example render of view
 Using the summary view inside of another ([index](/layout/index)) template.
 
-    <section id="main">
-      <div>
-       <h1 id="title">{{ .Title }}</h1>
-        {{ range .Data.Pages }}
-            {{ .Render "summary"}}
-        {{ end }}
-      </div>
-    </section>
+{{% highlight html %}}
+<section id="main">
+<div>
+<h1 id="title">{{ .Title }}</h1>
+{{ range .Data.Pages }}
+{{ .Render "summary"}}
+{{ end }}
+</div>
+</section>
+{{% /highlight %}}
 
 In the above example you will notice that we have called .Render and passed in
 which view to render the content with. Render is a special function available on
index 482145678cce8adf6b4862a1f796fd543292b7c6..f4bfcccbda399183a845b38aee3e9f40baba38bf 100644 (file)
@@ -8,12 +8,9 @@ groups_weight: 50
 
 Hugo is released under the Simple Public License.
 
+## Simple Public License (SimPL-2.0)
 
-Simple Public License (SimPL-2.0)
-=================================
-
-Preamble
---------
+### Preamble
 
 This Simple Public License 2.0 (SimPL-2.0 for short) is a plain language
 implementation of GPL 2.0.  The words are different, but the goal is the
@@ -22,8 +19,7 @@ software.  If anyone wonders about the meaning of the SimPL, they should
 interpret it as consistent with GPL 2.0.
 
 
-Simple Public License (SimPL) 2.0
-=================================
+## Simple Public License (SimPL) 2.0
 
 The SimPL applies to the software's source and object code and comes
 with any rights that I have in it (other than trademarks). You agree to
@@ -68,8 +64,7 @@ automatically if:
 -   Anyone prevents you from distributing the software under the terms
     of the SimPL.
 
-License for the License
------------------------
+## License for the License
 
 You may do anything that you want with the SimPL text; it's a license
 form to use in any way that you find helpful.  To avoid confusion,
index f8d835c833a7d78f508a38cf042d6e6d680070dd..5ddb5c3b3f6eeb6329d821fa829e1d884de3325d 100644 (file)
@@ -6,7 +6,7 @@ groups: ["meta"]
 groups_weight: 10
 ---
 
-* **0.9.0**
+## **0.9.0** November 15, 2013
   * New command based interface similar to git (hugo server -s ./ )
   * Amber template support
   * Aliases (redirects)
@@ -38,7 +38,8 @@ groups_weight: 10
   * Support for go 1.2
   * Support for `first` in templates
   * Support for site per-section permalink pattern specifications
-* **0.8.0** August 2, 2013
+
+## **0.8.0** August 2, 2013
   * Added support for pretty urls (filename/index.html vs filename.html)
   * Hugo supports a destination directory
   * Will efficiently sync content in static to destination directory
@@ -51,11 +52,14 @@ groups_weight: 10
   * Support for series
   * Adding verbose output
   * Loads of bugfixes
-* **0.7.0** July 4, 2013
+
+## **0.7.0** July 4, 2013
   * Hugo now includes a simple server
   * First public release
-* **0.6.0** July 2, 2013
+
+## **0.6.0** July 2, 2013
   * Hugo includes an example documentation site which it builds
-* **0.5.0** June 25, 2013
+
+## **0.5.0** June 25, 2013
   * Hugo is quite usable and able to build spf13.com
 
index 6ac0035de97da10351d4076daad69ae98336c932..5721df13301c1a254c47fea6eccf53a82a9f89af 100644 (file)
@@ -20,33 +20,34 @@ then look for a `config.json` file, followed by a `config.toml` file.
 ## Examples
 
 The following is an example of a yaml config file with the default values:
-
-    ---
-    contentdir: "content"
-    layoutdir: "layouts"
-    publishdir: "public"
-    builddrafts: false
-    indexes:
-       category: "categories"
-       tag: "tags"
-    baseurl: "http://yoursite.example.com/"
-    ...
-
+{{% highlight yaml %}}
+---
+contentdir: "content"
+layoutdir: "layouts"
+publishdir: "public"
+builddrafts: false
+indexes:
+   category: "categories"
+   tag: "tags"
+baseurl: "http://yoursite.example.com/"
+...
+{{% /highlight %}}
 
 The following is an example of a json config file with the default values:
 
-    {
-        "contentdir": "content",
-        "layoutdir": "layouts",
-        "publishdir": "public",
-        "builddrafts": false,
-        "indexes": {
-           "category": "categories",
-           "tag": "tags"
-        },
-        "baseurl": "http://yoursite.example.com/"
-    }
-
+{{% highlight json %}}
+{
+    "contentdir": "content",
+    "layoutdir": "layouts",
+    "publishdir": "public",
+    "builddrafts": false,
+    "indexes": {
+       "category": "categories",
+       "tag": "tags"
+    },
+    "baseurl": "http://yoursite.example.com/"
+}
+{{% /highlight %}}
 
 The following is an example of a toml config file with the default values:
 
@@ -61,18 +62,19 @@ The following is an example of a toml config file with the default values:
 
 Here is a yaml configuration file which sets a few more options
 
-    ---
-    baseurl: "http://yoursite.example.com/"
-    title: "Yoyodyne Widget Blogging"
-    permalinks:
-      post: /:year/:month/:title/
-    params:
-      Subtitle: "Spinning the cogs in the widgets"
-      AuthorName: "John Doe"
-      GitHubUser: "spf13"
-      ListOfFoo:
-        - "foo1"
-        - "foo2"
-      SidebarRecentLimit: 5
-    ...
-
+{{% highlight yaml %}}
+---
+baseurl: "http://yoursite.example.com/"
+title: "Yoyodyne Widget Blogging"
+permalinks:
+  post: /:year/:month/:title/
+params:
+  Subtitle: "Spinning the cogs in the widgets"
+  AuthorName: "John Doe"
+  GitHubUser: "spf13"
+  ListOfFoo:
+    - "foo1"
+    - "foo2"
+  SidebarRecentLimit: 5
+...
+{{% /highlight %}}