tpl/time: Make it a package that stands on its own
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sun, 30 Apr 2017 21:10:46 +0000 (23:10 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 1 May 2017 13:13:41 +0000 (15:13 +0200)
See #3042

tpl/time/init.go [new file with mode: 0644]
tpl/tplimpl/templateFuncster.go
tpl/tplimpl/template_funcs.go
tpl/tplimpl/template_funcs_test.go

diff --git a/tpl/time/init.go b/tpl/time/init.go
new file mode 100644 (file)
index 0000000..dfa2cbf
--- /dev/null
@@ -0,0 +1,45 @@
+// Copyright 2017 The Hugo Authors. All rights reserved.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package time
+
+import (
+       "github.com/spf13/hugo/deps"
+       "github.com/spf13/hugo/tpl/internal"
+)
+
+const name = "time"
+
+func init() {
+       f := func(d *deps.Deps) *internal.TemplateFuncsNamespace {
+               ctx := New()
+
+               examples := [][2]string{
+                       {`{{ (time "2015-01-21").Year }}`, `2015`},
+               }
+
+               return &internal.TemplateFuncsNamespace{
+                       Name:    name,
+                       Context: func() interface{} { return ctx },
+                       Aliases: map[string]interface{}{
+                               "dateFormat": ctx.Format,
+                               "now":        ctx.Now,
+                               "time":       ctx.AsTime,
+                       },
+                       Examples: examples,
+               }
+
+       }
+
+       internal.AddTemplateFuncsNamespace(f)
+}
index b90fb01c18db76741d3e9c9663b30625ce66a1d7..c7cba5d980e97d25ef2d055f2913c6e77dd7d8d4 100644 (file)
@@ -21,7 +21,6 @@ import (
 
        bp "github.com/spf13/hugo/bufferpool"
        "github.com/spf13/hugo/deps"
-       "github.com/spf13/hugo/tpl/time"
        "github.com/spf13/hugo/tpl/transform"
        "github.com/spf13/hugo/tpl/urls"
 )
@@ -32,7 +31,6 @@ type templateFuncster struct {
        cachedPartials partialCache
 
        // Namespaces
-       time      *time.Namespace
        transform *transform.Namespace
        urls      *urls.Namespace
 
@@ -45,7 +43,6 @@ func newTemplateFuncster(deps *deps.Deps) *templateFuncster {
                cachedPartials: partialCache{p: make(map[string]interface{})},
 
                // Namespaces
-               time:      time.New(),
                transform: transform.New(deps),
                urls:      urls.New(deps),
        }
index 7ebc14c049580b50d17233af3d3165954f9ac1ad..0c2069603bf88abb7f31b6f54c0302a6b2ad8543 100644 (file)
@@ -36,6 +36,7 @@ import (
        _ "github.com/spf13/hugo/tpl/os"
        _ "github.com/spf13/hugo/tpl/safe"
        _ "github.com/spf13/hugo/tpl/strings"
+       _ "github.com/spf13/hugo/tpl/time"
 )
 
 // Get retrieves partial output from the cache based upon the partial name.
@@ -95,14 +96,12 @@ func (t *templateFuncster) initFuncMap() {
 
                "absURL":        t.urls.AbsURL,
                "absLangURL":    t.urls.AbsLangURL,
-               "dateFormat":    t.time.Format,
                "emojify":       t.transform.Emojify,
                "highlight":     t.transform.Highlight,
                "htmlEscape":    t.transform.HTMLEscape,
                "htmlUnescape":  t.transform.HTMLUnescape,
                "int":           func(v interface{}) (int, error) { return cast.ToIntE(v) },
                "markdownify":   t.transform.Markdownify,
-               "now":           t.time.Now,
                "partial":       t.partial,
                "partialCached": t.partialCached,
                "plainify":      t.transform.Plainify,
@@ -114,7 +113,6 @@ func (t *templateFuncster) initFuncMap() {
                "relLangURL":    t.urls.RelLangURL,
                "relref":        t.urls.RelRef,
                "string":        func(v interface{}) (string, error) { return cast.ToStringE(v) },
-               "time":          t.time.AsTime,
                "urlize":        t.PathSpec.URLize,
        }
 
index 539d504925e56d9a9492cf1193c582a4da6e604c..dad3d0342eef9a2e4ed1a46d285304031f55ceaf 100644 (file)
@@ -146,7 +146,6 @@ relURL 1: {{ "http://gohugo.io/" | relURL }}
 relURL 2: {{ "mystyle.css" | relURL }}
 relURL 3: {{ mul 2 21 | relURL }}
 strings.TrimPrefix: {{ strings.TrimPrefix "Goodbye,, world!" "Goodbye," }}
-time: {{ (time "2015-01-21").Year }}
 urlize: {{ "Bat Man" | urlize }}
 `
 
@@ -174,7 +173,6 @@ relURL 1: http://gohugo.io/
 relURL 2: /hugo/mystyle.css
 relURL 3: /hugo/42
 strings.TrimPrefix: , world!
-time: 2015
 urlize: bat-man
 `