tpl: Add a delimiter parameter to lang.NumFmt
authorCameron Moore <moorereason@gmail.com>
Tue, 2 Oct 2018 14:41:48 +0000 (09:41 -0500)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 2 Oct 2018 14:41:48 +0000 (17:41 +0300)
The original implementation of NumFmt did not take into account that the
options delimiter (a space) could be a valid option.  Adding a delim
parameter seems like the simplest, safest, and most flexible way to
solve this oversight in a backwards-compatible way.

Fixes #5260

docs/content/en/functions/NumFmt.md
tpl/lang/lang.go
tpl/lang/lang_test.go

index 795eaaea8c98a69f46bc59b27fbaaef0f6dd0fcf..1bc07abd55462987c5f6f30379692474be666e6b 100644 (file)
@@ -12,7 +12,7 @@ menu:
   docs:
     parent: "functions"
 toc: false
-signature: ["lang.NumFmt PRECISION NUMBER [OPTIONS]"]
+signature: ["lang.NumFmt PRECISION NUMBER [OPTIONS [DELIMITER]]"]
 workson: []
 hugoversion:
 relatedfuncs: []
@@ -22,7 +22,9 @@ aliases: []
 comments:
 ---
 
-The default options value is `- . ,`.
+The default options value is `- . ,`.  The default delimiter within the options
+value is a space.  If you need to use a space as one of the options, set a
+custom delimiter.
 
 Numbers greater than or equal to 5 are rounded up. For example, if precision is set to `0`, `1.5` becomes `2`, and `1.4` becomes `1`.
 
@@ -31,5 +33,6 @@ Numbers greater than or equal to 5 are rounded up. For example, if precision is
 {{ lang.NumFmt 2 12345.6789 "- , ." }} → 12.345,68
 {{ lang.NumFmt 0 -12345.6789 "- . ," }} → -12,346
 {{ lang.NumFmt 6 -12345.6789 "- ." }} → -12345.678900
+{{ lang.NumFmt 6 -12345.6789 "-|.| " "|" }} → -1 2345.678900
 {{ -98765.4321 | lang.NumFmt 2 }} → -98,765.43
 ```
index 430b5e442d59eb377ff3d4423f46cf536a9d8d4e..4c011b1ce9651a974358f221f51f053351c00946 100644 (file)
@@ -67,15 +67,27 @@ func (ns *Namespace) NumFmt(precision, number interface{}, options ...interface{
        var neg, dec, grp string
 
        if len(options) == 0 {
-               // TODO(moorereason): move to site config
+               // defaults
                neg, dec, grp = "-", ".", ","
        } else {
+               delim := " "
+
+               if len(options) == 2 {
+                       // custom delimiter
+                       s, err := cast.ToStringE(options[1])
+                       if err != nil {
+                               return "", nil
+                       }
+
+                       delim = s
+               }
+
                s, err := cast.ToStringE(options[0])
                if err != nil {
                        return "", nil
                }
 
-               rs := strings.Fields(s)
+               rs := strings.Split(s, delim)
                switch len(rs) {
                case 0:
                case 1:
index c494fd03a8a92ea08021470a7cce7f08d0f339f9..aee5675024b3888942d82f54e5ca03cc631af10f 100644 (file)
@@ -18,22 +18,27 @@ func TestNumFormat(t *testing.T) {
                prec  int
                n     float64
                runes string
+               delim string
 
                want string
        }{
-               {2, -12345.6789, "", "-12,345.68"},
-               {2, -12345.6789, "- . ,", "-12,345.68"},
-               {2, -12345.1234, "- . ,", "-12,345.12"},
+               {2, -12345.6789, "", "", "-12,345.68"},
+               {2, -12345.6789, "- . ,", "", "-12,345.68"},
+               {2, -12345.1234, "- . ,", "", "-12,345.12"},
 
-               {2, 12345.6789, "- . ,", "12,345.68"},
-               {0, 12345.6789, "- . ,", "12,346"},
-               {11, -12345.6789, "- . ,", "-12,345.67890000000"},
+               {2, 12345.6789, "- . ,", "", "12,345.68"},
+               {0, 12345.6789, "- . ,", "", "12,346"},
+               {11, -12345.6789, "- . ,", "", "-12,345.67890000000"},
 
-               {3, -12345.6789, "- ,", "-12345,679"},
-               {6, -12345.6789, "- , .", "-12.345,678900"},
+               {3, -12345.6789, "- ,", "", "-12345,679"},
+               {6, -12345.6789, "- , .", "", "-12.345,678900"},
+
+               {3, -12345.6789, "-|,| ", "|", "-12 345,679"},
+               {6, -12345.6789, "-|,| ", "|", "-12 345,678900"},
 
                // Arabic, ar_AE
-               {6, -12345.6789, "‏- ٫ ٬", "‏-12٬345٫678900"},
+               {6, -12345.6789, "‏- ٫ ٬", "", "‏-12٬345٫678900"},
+               {6, -12345.6789, "‏-|٫| ", "|", "‏-12 345٫678900"},
        }
 
        for i, c := range cases {
@@ -45,7 +50,11 @@ func TestNumFormat(t *testing.T) {
                if len(c.runes) == 0 {
                        s, err = ns.NumFmt(c.prec, c.n)
                } else {
-                       s, err = ns.NumFmt(c.prec, c.n, c.runes)
+                       if c.delim == "" {
+                               s, err = ns.NumFmt(c.prec, c.n, c.runes)
+                       } else {
+                               s, err = ns.NumFmt(c.prec, c.n, c.runes, c.delim)
+                       }
                }
 
                require.NoError(t, err, errMsg)