Add Scratch to shortcode
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 21 Mar 2016 10:10:57 +0000 (11:10 +0100)
committerSteve Francia <steve.francia@gmail.com>
Tue, 22 Mar 2016 01:11:20 +0000 (21:11 -0400)
Fixes #2000

docs/content/extras/scratch.md
hugolib/shortcode.go

index dce53574b141b1c68fd2b778677f55c7131bc976..0b93747ec1ee07477d5eaa6335a83330ea5baf4a 100644 (file)
@@ -14,8 +14,7 @@ weight: 80
 
 `Scratch` -- a "scratchpad" for your node- or page-scoped variables. In most cases you can do well without `Scratch`, but there are some use cases that aren't solvable with Go's templates without `Scratch`'s help, due to scoping issues.
 
-
-`Scratch` is added to both `Node` and `Page` -- with following methods:
+`Scratch` is added to both `Node` and `Page` and `Shortcode` -- with following methods:
 * `Set` and `Add` takes a `key` and the `value` to add.
 * `Get` returns the `value` for the `key` given.
 * `SetInMap` takes a `key`, `mapKey` and `value`
@@ -25,7 +24,9 @@ weight: 80
 
 For single values, `Add` accepts values that support Go's `+` operator. If the first `Add` for a key is an array or slice, the follwing adds will be appended to that list.
 
-The scope of the backing data is global for the given `Node` or `Page`, and spans partial and shortcode includes.
+The scope of the backing data is global for the given `Node`, `Page` or `Shortcode`, and spans partial and shortcode includes.
+
+Note that `.Scratch` from a shortcode will return the shortcode's `Scratch`, which in most casses is what you want. If you want to store it in the page scroped Scratch, then use `.Page.Scratch`.
 
 ## Sample usage
 
index c0993cc2b5001dc60e3d3d4e608a2691b6e1c0c4..b81c95394e3ae2c9d8c2b537be146f45402395c2 100644 (file)
@@ -36,6 +36,7 @@ type ShortcodeWithPage struct {
        Page          *Page
        Parent        *ShortcodeWithPage
        IsNamedParams bool
+       scratch       *Scratch
 }
 
 func (scp *ShortcodeWithPage) Site() *SiteInfo {
@@ -51,7 +52,10 @@ func (scp *ShortcodeWithPage) RelRef(ref string) (string, error) {
 }
 
 func (scp *ShortcodeWithPage) Scratch() *Scratch {
-       return scp.Page.Scratch()
+       if scp.scratch == nil {
+               scp.scratch = newScratch()
+       }
+       return scp.scratch
 }
 
 func (scp *ShortcodeWithPage) Get(key interface{}) interface{} {