Squashed 'docs/' changes from 3a923e155..710856e5a
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 18 Jun 2021 15:49:54 +0000 (17:49 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 18 Jun 2021 15:49:54 +0000 (17:49 +0200)
710856e5a Release 0.84.0
362f4ea7b releaser: Add release notes to /docs for release of 0.84.0
6bb8800f7 docs: Regenerate docs helper
00a522e6a docs: Regenerate docshelper
bc171954b Merge commit '92405e5b0adc5d8c3dfde88d6a8b67eb09169190'
ef73ffc3b Misc config loading fixes
0b4117f7f docs: Regenerate docs helper
9b9452b9c Merge commit '32ba623541d74ee0b7ae4efb1b8326dc49af28b8'
9c4413dd9 tpl/fmt: Add erroridf template func
e1875742e tpl/data: Misc header improvements, tests, allow multiple headers of same key
e4560893c Add math.Max and math.Min
7dc282eaf common/maps: Add Scratch.DeleteInMap
b9cd77171 docs: Update querify function description and examples

git-subtree-dir: docs
git-subtree-split: 710856e5a6c683ce26d385960423303cc109c09e

15 files changed:
config.toml
content/en/content-management/image-processing/index.md
content/en/functions/errorf.md
content/en/functions/math.md
content/en/functions/querify.md
content/en/functions/scratch.md
content/en/getting-started/configuration.md
content/en/news/0.84.0-relnotes/featured.png [new file with mode: 0644]
content/en/news/0.84.0-relnotes/index.md [new file with mode: 0644]
content/en/templates/data-templates.md
data/docs.json
layouts/shortcodes/code-toggle.html
netlify.toml
resources/_gen/images/news/0.84.0-relnotes/featured_hu7c38afe80520529cfcae538ac032ebff_47732_480x0_resize_catmullrom_2.png [new file with mode: 0644]
resources/_gen/images/news/0.84.0-relnotes/featured_hu7c38afe80520529cfcae538ac032ebff_47732_640x0_resize_catmullrom_2.png [new file with mode: 0644]

index efa1b0573560a20cf96142d389fb1fbc4b4485c0..8c648068182bb69e58e30d4f01ebe447b939c7cc 100644 (file)
@@ -7,7 +7,7 @@ footnotereturnlinkcontents = "↩"
 languageCode = "en-us"
 title = "Hugo"
 
- ignoreErrors = ["error-remote-getjson"]
+ ignoreErrors = ["error-remote-getjson", "error-missing-instagram-accesstoken"]
 
 
 googleAnalytics = "UA-7131036-4"
index 5b3dce57fddda3ee08eab78ed21bbab44b805398..40af0d6ab1b349925802e98606c0e06a8a602c7c 100644 (file)
@@ -181,6 +181,8 @@ Only relevant for JPEG and WebP images, values 1 to 100 inclusive, higher is bet
 
  {{< new-in "0.83.0" >}}
 
+ {{< new-in "0.83.0" >}}
+
 Hint about what type of image this is. Currently only used when encoding to WebP.
 
 Default value is `photo`.
index 450e92679ad68a90f4029a08ea32a855e30b4442..a20ad4f44fbba29083b7d2ce85495557a166a07b 100644 (file)
@@ -31,3 +31,22 @@ Both functions return an empty string, so the messages are only printed to the c
 ```
 
 Note that `errorf` and `warnf` support all the formatting verbs of the [fmt](https://golang.org/pkg/fmt/) package.
+
+## Suppress errors
+
+Some times it may make sense to let the user suppress an ERROR and make the build succeed.
+
+You can do this by using the `erroridf` function. This functions takes an error ID as the first arument.
+
+
+``
+{{ erroridf "my-custom-error" "You should consider fixing this."}}
+```  
+
+This will produce:
+
+```
+ERROR 2021/06/07 17:47:38 You should consider fixing this.
+If you feel that this should not be logged as an ERROR, you can ignore it by adding this to your site config:
+ignoreErrors = ["my-custom-error"]
+```
index 58cc5d5db6ea41c5540fe362085ec2056c56b9a6..99b8cf34f8c9d740d97bb80fee3088de17d7daeb 100644 (file)
@@ -1,6 +1,6 @@
 ---
 title: Math
-description: Hugo provides nine mathematical operators in templates.
+description: Hugo provides mathematical operators in templates.
 godocref:
 date: 2017-02-01
 publishdate: 2017-02-01
@@ -35,7 +35,9 @@ aliases: []
 | `modBool`    | Boolean of modulus of two integers. Evaluates to `true` if result equals 0. | `{{modBool 15 3}}` &rarr; `true` |
 | `math.Ceil`  | Returns the least integer value greater than or equal to the given number.  | `{{math.Ceil 2.1}}` &rarr; `3`   |
 | `math.Floor` | Returns the greatest integer value less than or equal to the given number.  | `{{math.Floor 1.9}}` &rarr; `1`  |
-| `math.Round` | Returns the nearest integer, rounding half away from zero.                  | `{{math.Round 1.5}}` &rarr; `2`  |
 | `math.Log`   | Returns the natural logarithm of the given number.                          | `{{math.Log 42}}` &rarr; `3.737` |
-| `math.Sqrt`  | Returns the square root of the given number.                                | `{{math.Sqrt 81}}` &rarr; `9`    |
+| `math.Max`   | Returns the greater of two numbers.                                         | `{{math.Max 1 2}}` &rarr; `2`    |
+| `math.Min`   | Returns the smaller of two numbers.                                         | `{{math.Min 1 2}}` &rarr; `1`    |
 | `math.Pow`   | Returns the first number raised to the power of the second number.          | `{{math.Pow 2 3}}` &rarr; `8`    |
+| `math.Round` | Returns the nearest integer, rounding half away from zero.                  | `{{math.Round 1.5}}` &rarr; `2`  |
+| `math.Sqrt`  | Returns the square root of the given number.                                | `{{math.Sqrt 81}}` &rarr; `9`    |
index e90e0745005ed9511e5ce35451e203f6f68f3fcd..7c361f3260fe60efaa27fee566ba02507c1df05f 100644 (file)
@@ -1,7 +1,7 @@
 ---
 title: querify
 linktitle: querify
-description: Takes a set of key-value pairs and returns a query string to be appended to URLs.
+description: Takes a set or slice of key-value pairs and returns a query string to be appended to URLs.
 date: 2017-02-01
 publishdate: 2017-02-01
 lastmod: 2017-02-01
@@ -11,7 +11,7 @@ menu:
     parent: "functions"
 keywords: [urls]
 godocref:
-signature: ["querify KEY VALUE [KEY VALUE]..."]
+signature: ["querify KEY VALUE [KEY VALUE]...", "querify COLLECTION"]
 hugoversion:
 deprecated: false
 workson: []
@@ -19,16 +19,19 @@ relatedfuncs: []
 aliases: []
 ---
 
-`querify` takes a set of key-value pairs and returns a [query string](https://en.wikipedia.org/wiki/Query_string) that can be appended to a URL. E.g.
+`querify` takes a set or slice of key-value pairs and returns a [query string](https://en.wikipedia.org/wiki/Query_string) that can be appended to a URL.
 
-The following example creates a link to a search results page on Google.
+The following examples create a link to a search results page on Google.
 
-```
+```go-html-template
 <a href="https://www.google.com?{{ (querify "q" "test" "page" 3) | safeURL }}">Search</a>
+
+{{ $qs := slice "q" "test" "page" 3 }}
+<a href="https://www.google.com?{{ (querify $qs) | safeURL }}">Search</a>
 ```
 
-This example renders the following HTML:
+Both of these examples render the following HTML:
 
-```
+```html
 <a href="https://www.google.com?page=3&q=test">Search</a>
 ```
index cadff5aa085e684dce692307999472cf02095354..5b155aff94081cd1f263a79daa05f818f8398219 100644 (file)
@@ -114,6 +114,18 @@ Takes a `key`, `mapKey` and `value` and adds a map of `mapKey` and `value` to th
 {{ $scratch.Get "greetings" }} > map[french:Bonjour english:Hello]
 ```
 
+#### .DeleteInMap
+Takes a `key` and `mapKey` and removes the map of `mapKey` from the given `key`.
+
+```go-html-template
+{{ .Scratch.SetInMap "greetings" "english" "Hello" }}
+{{ .Scratch.SetInMap "greetings" "french" "Bonjour" }}
+----
+{{ .Scratch.DeleteInMap "greetings" "english" }}
+----
+{{ .Scratch.Get "greetings" }} > map[french:Bonjour]
+```
+
 #### .GetSortedMapValues
 
 Return an array of values from `key` sorted by `mapKey`.
index e60061bd0f5e1abf3fca9158fcc62dc0ae23e930..05383dda36213078bf0ffc9e01dd61dbf13f096d 100644 (file)
@@ -80,6 +80,26 @@ Considering the structure above, when running `hugo --environment staging`, Hugo
 {{% note %}}
 Default environments are __development__ with `hugo server` and __production__ with `hugo`.
 {{%/ note %}}
+
+## Merge Configuration from Themes
+
+{{< new-in "0.84.0" >}} The configuration merge described below was improved in Hugo 0.84.0 and made fully configurable. The big change/improvement was that we now, by default, do deep merging of `params` maps from themes.
+
+The configuration value for `_merge` can be one of:
+
+none
+: No merge.
+
+shallow
+: Only add values for new keys.
+
+shallow
+: Add values for new keys, merge existing.
+
+Note that you don't need to be so verbose as in the default setup below; a `_merge` value higher up will be inherited if not set.
+
+{{< code-toggle config="mergeStrategy" skipHeader=true />}}
+
 ## All Configuration Settings
 
 The following is the full list of Hugo-defined variables with their default
diff --git a/content/en/news/0.84.0-relnotes/featured.png b/content/en/news/0.84.0-relnotes/featured.png
new file mode 100644 (file)
index 0000000..e733669
Binary files /dev/null and b/content/en/news/0.84.0-relnotes/featured.png differ
diff --git a/content/en/news/0.84.0-relnotes/index.md b/content/en/news/0.84.0-relnotes/index.md
new file mode 100644 (file)
index 0000000..3bd7b37
--- /dev/null
@@ -0,0 +1,160 @@
+
+---
+date: 2021-06-18
+title: "Config Revamp"
+description: "Hugo 0.84.0: Deep merge of theme configuration, config dir support now also in themes/modules, HTTP header support in getJSON, and more."
+categories: ["Releases"]
+---
+
+**This release brings several configuration fixes and improvements that will be especially useful for themes.**
+
+## Deep merge of theme Params
+
+One of the most common complaint from Hugo theme owners/users has been about the configuration handling. Hugo has up until now only performed a shallow merge of theme `params` into the configuration.
+
+With that, given this example from a theme configuration:
+
+```toml
+[params]
+[params.colours]
+blue="#337DFF"
+green="#68FF33"
+red="#FF3358"
+```
+
+If you would like to use the above theme, but want a different shade of red, you earlier had to copy the entire block, even the colours you're totally happy with. This was painful even the simplest setup.
+
+Now you can just override the `params` keys you want to change, e.g.:
+
+```toml
+[params]
+[params.colours]
+red="#fc0f03"
+```
+
+For more information, and especially about the way you can opt out of the above behaviour, see [Merge Configuration from Themes](https://gohugo.io/getting-started/configuration/#merge-configuration-from-themes).
+
+## Themes now support the config directory
+
+Now both the project and themes/modules can store its configuration in both the top level config file (e.g. `config.toml`) or in the `config` directory. See [Configuration Directory](https://gohugo.io/getting-started/configuration/#configuration-directory).
+
+## HTTP headers in getJSON/getCSV
+
+`getJSON` now supports custom HTTP headers. This has been a big limitation in Hugo, especially considering the [Authorization](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Authorization) header.
+
+We have updated the internal Instagram shortcode to pass the access token in a header:
+
+```
+{{ $hideCaption := cond (eq (.Get 1) "hidecaption") "1" "0" }}
+{{ $headers := dict "Authorization" (printf "Bearer %s" $accessToken) }}
+{{ with getJSON "https://graph.facebook.com/v8.0/instagram_oembed/?url=https://instagram.com/p/" $id "/&hidecaption=" $hideCaption $headers }}
+    {{ .html | safeHTML }}
+{{ end }}
+```
+
+ Also see the discussion [this issue](https://github.com/gohugoio/hugo/issues/7879) about the access token above.
+
+## New erroridf template func
+
+Sometime, especially when creating themes, it is useful to be able to let the user decide if an error situation is critical enough to fail the build. The new `erroridf` produces `ERROR` log statements that can be toggled off:
+
+```html
+{{ erroridf "some-custom-id" "Some error message." }}
+```
+
+Will log:
+
+```
+ERROR: Some error message.
+If you feel that this should not be logged as an ERROR, you can ignore it by adding this to your site config:
+ignoreErrors = ["some-custom-id"]
+```
+## Stats
+
+This release represents **46 contributions by 11 contributors** to the main Hugo code base.[@bep](https://github.com/bep) leads the Hugo development with a significant amount of contributions, but also a big shoutout to [@jmooring](https://github.com/jmooring), [@satotake](https://github.com/satotake), and [@Seirdy](https://github.com/Seirdy) for their ongoing contributions.
+And a big thanks to [@digitalcraftsman](https://github.com/digitalcraftsman) for his relentless work on keeping the themes site in pristine condition.
+
+Many have also been busy writing and fixing the documentation in [hugoDocs](https://github.com/gohugoio/hugoDocs),
+which has received **20 contributions by 10 contributors**. A special thanks to [@salim-b](https://github.com/salim-b), [@bep](https://github.com/bep), [@thomasjsn](https://github.com/thomasjsn), and [@lucasew](https://github.com/lucasew) for their work on the documentation site.
+
+
+Hugo now has:
+
+* 52487+ [stars](https://github.com/gohugoio/hugo/stargazers)
+* 432+ [contributors](https://github.com/gohugoio/hugo/graphs/contributors)
+* 370+ [themes](http://themes.gohugo.io/)
+
+
+## Notes
+
+* We now do deep merging of `params` from theme config(s). That is you most likely what you want, but [Merge Configuration from Themes](https://gohugo.io/getting-started/configuration/#merge-configuration-from-themes) describes how you can get the old behaviour back.
+
+## Enhancements
+
+### Templates
+
+* Rename err-missing-instagram-accesstoken => error-missing-instagram-accesstoken [9096842b](https://github.com/gohugoio/hugo/commit/9096842b0494166e401cc08a70b93ae2ee19a198) [@bep](https://github.com/bep) 
+* Add a terse pagination template variant to improve performance [73483d0f](https://github.com/gohugoio/hugo/commit/73483d0f9eb46838d41640f88cc05c1d16811dc5) [@jmooring](https://github.com/jmooring) [#8599](https://github.com/gohugoio/hugo/issues/8599)
+* Add erroridf template func [f55d2f43](https://github.com/gohugoio/hugo/commit/f55d2f43769053b80b419a690554e747dc5dcede) [@bep](https://github.com/bep) [#8613](https://github.com/gohugoio/hugo/issues/8613)
+* Print response body on HTTP errors [282f1aa3](https://github.com/gohugoio/hugo/commit/282f1aa3db9f6420fdd360e46db1ffadd5b083a1) [@bep](https://github.com/bep) 
+* Misc header improvements, tests, allow multiple headers of same key [fcd63de3](https://github.com/gohugoio/hugo/commit/fcd63de3a54fadcd30972654d8eb86dc4d889784) [@bep](https://github.com/bep) [#5617](https://github.com/gohugoio/hugo/issues/5617)
+* Allows user-defined HTTP headers with getJSON and getCSV [150d7573](https://github.com/gohugoio/hugo/commit/150d75738b54acddc485d363436757189144da6a) [@chamberlainpj](https://github.com/chamberlainpj) [#5617](https://github.com/gohugoio/hugo/issues/5617)
+* Allow 'Querify' to take lone slice/interface argument [c46fc838](https://github.com/gohugoio/hugo/commit/c46fc838a9320adfc6532b1b543e903c48b3b4cb) [@importhuman](https://github.com/importhuman) [#6735](https://github.com/gohugoio/hugo/issues/6735)
+
+### Output
+
+* Make WebAppManifestFormat NotAlternative=true [643b6719](https://github.com/gohugoio/hugo/commit/643b671931ed5530855e7d4819896790bf3f6c28) [@bep](https://github.com/bep) [#8624](https://github.com/gohugoio/hugo/issues/8624)
+* Adjust  test assertion [ab4e1dfa](https://github.com/gohugoio/hugo/commit/ab4e1dfa4eebe0ac18f1d1f60a9647cbb7b41d7f) [@bep](https://github.com/bep) [#8625](https://github.com/gohugoio/hugo/issues/8625)
+* support application/manifest+json [02f31897](https://github.com/gohugoio/hugo/commit/02f31897b4f7252154850a65c900e88e0b237fa3) [@Seirdy](https://github.com/Seirdy) [#8624](https://github.com/gohugoio/hugo/issues/8624)
+
+### Other
+
+* Regenerate docs helper [be6b901c](https://github.com/gohugoio/hugo/commit/be6b901cf7d07238337334e6b6d886a7b039f5e6) [@bep](https://github.com/bep) 
+* Regenerate docshelper [402da3f8](https://github.com/gohugoio/hugo/commit/402da3f8f327f97302c4b5d69cd4832a94bd189b) [@bep](https://github.com/bep) 
+* Implement configuration in a directory for modules [bb2aa087](https://github.com/gohugoio/hugo/commit/bb2aa08709c812a5be29922a1a7f4d814e200cab) [@bep](https://github.com/bep) [#8654](https://github.com/gohugoio/hugo/issues/8654)
+* Update github.com/alecthomas/chroma v0.9.1 => v0.9.2 [3aa7f0b2](https://github.com/gohugoio/hugo/commit/3aa7f0b27fc736b4c32adbb1fc1fc7fbefd6efd9) [@bep](https://github.com/bep) [#8658](https://github.com/gohugoio/hugo/issues/8658)
+* Run go mod tidy [9b870aa7](https://github.com/gohugoio/hugo/commit/9b870aa788ab1b5159bc836fbac6e60a29bee329) [@bep](https://github.com/bep) 
+* Split out the puthe path/filepath functions into common/paths [93aad3c5](https://github.com/gohugoio/hugo/commit/93aad3c543828efca2adeb7f96cf50ae29878593) [@bep](https://github.com/bep) [#8654](https://github.com/gohugoio/hugo/issues/8654)
+* Update to Goldmark v1.3.8 [8eafe084](https://github.com/gohugoio/hugo/commit/8eafe0845d66efd3cf442a8ed89a6da5c1d3117b) [@jmooring](https://github.com/jmooring) [#8648](https://github.com/gohugoio/hugo/issues/8648)
+* Do not read config from os.Environ when running tests [31fb29fb](https://github.com/gohugoio/hugo/commit/31fb29fb3f306678f3697e05bbccefb2078d7f78) [@bep](https://github.com/bep) [#8655](https://github.com/gohugoio/hugo/issues/8655)
+* Set a dummy Instagram token [a886dd53](https://github.com/gohugoio/hugo/commit/a886dd53b80322e1edf924f2ede4d4ea037c5baf) [@bep](https://github.com/bep) 
+* Regenerate docs helper [a91cd765](https://github.com/gohugoio/hugo/commit/a91cd7652f7559492b070dbe02fe558348f3d0b6) [@bep](https://github.com/bep) 
+* Update to Go 1.16.5, Goreleaser 0.169.0 [552cef5c](https://github.com/gohugoio/hugo/commit/552cef5c576ae4dbf4626f77f3c8b15b42a9e7f3) [@bep](https://github.com/bep) [#8619](https://github.com/gohugoio/hugo/issues/8619)[#8263](https://github.com/gohugoio/hugo/issues/8263)
+* Upgrade Instagram shortcode [9b5debe4](https://github.com/gohugoio/hugo/commit/9b5debe4b820132759cfdf7bff7fe9c1ad0a6bb1) [@bep](https://github.com/bep) [#7879](https://github.com/gohugoio/hugo/issues/7879)
+* Set modTime at creation time [06d29542](https://github.com/gohugoio/hugo/commit/06d295427f798da85de469924fd10f58c0de9a58) [@bep](https://github.com/bep) [#6161](https://github.com/gohugoio/hugo/issues/6161)
+* Add math.Max and math.Min [01758f99](https://github.com/gohugoio/hugo/commit/01758f99b915f34fe7ca4621e4d1ee09efe385b1) [@jmooring](https://github.com/jmooring) [#8583](https://github.com/gohugoio/hugo/issues/8583)
+* Catch incomplete shortcode error [845a7ba4](https://github.com/gohugoio/hugo/commit/845a7ba4fc30c61842148d67d31d0fa3db8f40b9) [@satotake](https://github.com/satotake) [#6866](https://github.com/gohugoio/hugo/issues/6866)
+* Use SPDX license identifier [10f60de8](https://github.com/gohugoio/hugo/commit/10f60de89a5a53528f1e3a47a77224e5c7915e4e) [@jmooring](https://github.com/jmooring) [#8555](https://github.com/gohugoio/hugo/issues/8555)
+* Cache and copy Menu for sorting [785a31b5](https://github.com/gohugoio/hugo/commit/785a31b5b84643f4769f9bd363599cbcce86f098) [@satotake](https://github.com/satotake) [#7594](https://github.com/gohugoio/hugo/issues/7594)
+* Update to LibSASS 3.6.5 [bc1e0528](https://github.com/gohugoio/hugo/commit/bc1e05286a96d08ad02ad200d6a4076bb01c486e) [@bep](https://github.com/bep) 
+* Make the HTML element collector more robust [f518b4f7](https://github.com/gohugoio/hugo/commit/f518b4f71e1a61b09d660b5c284121ebf3b3b86b) [@bep](https://github.com/bep) [#8530](https://github.com/gohugoio/hugo/issues/8530)
+* Make the HTML element collector more robust" [dc6b7a75](https://github.com/gohugoio/hugo/commit/dc6b7a75ff5b7fcb8a0b0e3f7ed406422d847624) [@bep](https://github.com/bep) 
+* Get the collector in line with the io.Writer interface" [3f515f0e](https://github.com/gohugoio/hugo/commit/3f515f0e3395b24776ae24045b846ff2b33b8906) [@bep](https://github.com/bep) 
+* Get the collector in line with the io.Writer interface [a9bcd381](https://github.com/gohugoio/hugo/commit/a9bcd38181ceb79afba82adcd4de1aebf571e74c) [@bep](https://github.com/bep) 
+* Make the HTML element collector more robust [ef0f1a72](https://github.com/gohugoio/hugo/commit/ef0f1a726901d6c614040cfc2d7e8f9a2ca97816) [@bep](https://github.com/bep) [#8530](https://github.com/gohugoio/hugo/issues/8530)
+* Add Scratch.DeleteInMap [abbc99d4](https://github.com/gohugoio/hugo/commit/abbc99d4c60b102e2779e4362ceb433095719384) [@meehawk](https://github.com/meehawk) [#8504](https://github.com/gohugoio/hugo/issues/8504)
+* Display version when building site (#8533) [76c95f55](https://github.com/gohugoio/hugo/commit/76c95f55a5d18290baa7f23667161d4af9fb9b53) [@jmooring](https://github.com/jmooring) [#8531](https://github.com/gohugoio/hugo/issues/8531)
+* Update querify function description and examples [2c7f5b62](https://github.com/gohugoio/hugo/commit/2c7f5b62f6c1fa1c7b3cf2c1f3a1663b18e75004) [@jmooring](https://github.com/jmooring) 
+* Change SetEscapeHTML to false [504c78da](https://github.com/gohugoio/hugo/commit/504c78da4b5020e1fd13a1195ad38a9e85f8289a) [@peaceiris](https://github.com/peaceiris) [#8512](https://github.com/gohugoio/hugo/issues/8512)
+* Add a benchmark [b660ea8d](https://github.com/gohugoio/hugo/commit/b660ea8d545d6ba5479dd28a670044d57e5d196f) [@bep](https://github.com/bep) 
+* Update dependency list [64f88f30](https://github.com/gohugoio/hugo/commit/64f88f3011de5a510d8e6d6bad8ac4a091b11c0c) [@bep](https://github.com/bep) 
+
+## Fixes
+
+### Templates
+
+* Fix countwords to handle special chars [7a2c10ae](https://github.com/gohugoio/hugo/commit/7a2c10ae60f096dacee4b44e0c8ae0a1b66ae033) [@ResamVi](https://github.com/ResamVi) [#8479](https://github.com/gohugoio/hugo/issues/8479)
+
+### Other
+
+* Fix fill with smartcrop sometimes returning 0 bytes images [5af045eb](https://github.com/gohugoio/hugo/commit/5af045ebab109d3e5501b8b6d9fd448840c96c9a) [@bep](https://github.com/bep) [#7955](https://github.com/gohugoio/hugo/issues/7955)
+* Misc config loading fixes [d392893c](https://github.com/gohugoio/hugo/commit/d392893cd73dc00c927f342778f6dca9628d328e) [@bep](https://github.com/bep) [#8633](https://github.com/gohugoio/hugo/issues/8633)[#8618](https://github.com/gohugoio/hugo/issues/8618)[#8630](https://github.com/gohugoio/hugo/issues/8630)[#8591](https://github.com/gohugoio/hugo/issues/8591)[#6680](https://github.com/gohugoio/hugo/issues/6680)[#5192](https://github.com/gohugoio/hugo/issues/5192)
+* Fix nested OS env config override when parent does not exist [12530519](https://github.com/gohugoio/hugo/commit/12530519d8fb4513c9c18a6494099b7dff8e4fd4) [@bep](https://github.com/bep) [#8618](https://github.com/gohugoio/hugo/issues/8618)
+* Fix invalid timestamp of the "public" folder [26ae12c0](https://github.com/gohugoio/hugo/commit/26ae12c0c64b847d24bde60d7d710ea2efcb40d4) [@anthonyfok](https://github.com/anthonyfok) [#6161](https://github.com/gohugoio/hugo/issues/6161)
+* Fix env split to allow = character in  values [ee733085](https://github.com/gohugoio/hugo/commit/ee733085b7f5d3f2aef1667901ab6ecb8041d699) [@xqbumu](https://github.com/xqbumu) [#8589](https://github.com/gohugoio/hugo/issues/8589)
+* Fix warning regression in i18n [ececd1b1](https://github.com/gohugoio/hugo/commit/ececd1b122c741567a80acd8d60ccd6356fa5323) [@bep](https://github.com/bep) [#8492](https://github.com/gohugoio/hugo/issues/8492)
+
+
+
+
+
index 661c0bdfaec63d89df84520064e97b13338098b7..b3edf8f447d6e23aec9256944464fb4b9e767505 100644 (file)
@@ -114,19 +114,10 @@ You can use the following code to render the `Short Description` in your layout:
 
 Note the use of the [`markdownify` template function][markdownify]. This will send the description through the Blackfriday Markdown rendering engine.
 
-<!-- begin "Data-drive Content" page -->
 
-## Data-Driven Content
+## Get Remote Data
 
-In addition to the [data files](/extras/datafiles/) feature, Hugo also has a "data-driven content" feature, which lets you load any [JSON](https://www.json.org/) or [CSV](https://en.wikipedia.org/wiki/Comma-separated_values) file from nearly any resource.
-
-Data-driven content currently consists of two functions, `getJSON` and `getCSV`, which are available in all template files.
-
-## Implementation details
-
-### Call the Functions with a URL
-
-In your template, call the functions like this:
+Use `getJSON` or `getCSV` to get remote data:
 
 ```
 {{ $dataJ := getJSON "url" }}
@@ -155,19 +146,18 @@ This will resolve internally to the following:
 {{ $gistJ := getJSON "https://api.github.com/users/GITHUB_USERNAME/gists" }}
 ```
 
-Finally, you can range over an array. This example will output the
-first 5 gists for a GitHub user:
+### Add HTTP headers
+
+{{< new-in "0.84.0" >}} Both `getJSON` and `getCSV` takes an optional map as the last argument, e.g.:
 
 ```
-<ul>
-  {{ $urlPre := "https://api.github.com" }}
-  {{ $gistJ := getJSON $urlPre "/users/GITHUB_USERNAME/gists" }}
-  {{ range first 5 $gistJ }}
-    {{ if .public }}
-      <li><a href="{{ .html_url }}" target="_blank">{{ .description }}</a></li>
-    {{ end }}
-  {{ end }}
-</ul>
+{{ $data := getJSON "https://example.org/api" (dict "Authorization" "Bearer abcd")  }}
+```
+
+If you need multiple values for the same header key, use a slice:
+
+```
+{{ $data := getJSON "https://example.org/api" (dict "X-List" (slice "a" "b" "c"))  }}
 ```
 
 ### Example for CSV files
index 5e27712e361120129884e5dbf0615fc5b831dc82..d0edcb67fe1f2a5f152b4207ae03786173c508fc 100644 (file)
           "abnf"
         ]
       },
-      {
-        "Name": "AL",
-        "Aliases": [
-          "al",
-          "dal"
-        ]
-      },
-      {
-        "Name": "ANTLR",
-        "Aliases": [
-          "antlr"
-        ]
-      },
-      {
-        "Name": "APL",
-        "Aliases": [
-          "apl"
-        ]
-      },
       {
         "Name": "ActionScript",
         "Aliases": [
           "ads"
         ]
       },
+      {
+        "Name": "AL",
+        "Aliases": [
+          "al",
+          "dal"
+        ]
+      },
       {
         "Name": "Angular2",
         "Aliases": [
           "ng2"
         ]
       },
+      {
+        "Name": "ANTLR",
+        "Aliases": [
+          "antlr"
+        ]
+      },
       {
         "Name": "ApacheConf",
         "Aliases": [
           "htaccess"
         ]
       },
+      {
+        "Name": "APL",
+        "Aliases": [
+          "apl"
+        ]
+      },
       {
         "Name": "AppleScript",
         "Aliases": [
           "nawk"
         ]
       },
-      {
-        "Name": "BNF",
-        "Aliases": [
-          "bnf"
-        ]
-      },
       {
         "Name": "Ballerina",
         "Aliases": [
           "decls"
         ]
       },
+      {
+        "Name": "BNF",
+        "Aliases": [
+          "bnf"
+        ]
+      },
       {
         "Name": "Brainfuck",
         "Aliases": [
         "Aliases": [
           "c",
           "h",
-          "idc"
+          "idc",
+          "x[bp]m"
         ]
       },
       {
           "hxx"
         ]
       },
-      {
-        "Name": "CFEngine3",
-        "Aliases": [
-          "cf",
-          "cf3",
-          "cfengine3"
-        ]
-      },
-      {
-        "Name": "CMake",
-        "Aliases": [
-          "cmake",
-          "txt"
-        ]
-      },
-      {
-        "Name": "COBOL",
-        "Aliases": [
-          "COB",
-          "CPY",
-          "cob",
-          "cobol",
-          "cpy"
-        ]
-      },
-      {
-        "Name": "CSS",
-        "Aliases": [
-          "css"
-        ]
-      },
       {
         "Name": "Caddyfile",
         "Aliases": [
           "ceylon"
         ]
       },
+      {
+        "Name": "CFEngine3",
+        "Aliases": [
+          "cf",
+          "cf3",
+          "cfengine3"
+        ]
+      },
+      {
+        "Name": "cfstatement",
+        "Aliases": [
+          "cfs"
+        ]
+      },
       {
         "Name": "ChaiScript",
         "Aliases": [
           "clojure"
         ]
       },
+      {
+        "Name": "CMake",
+        "Aliases": [
+          "cmake",
+          "txt"
+        ]
+      },
+      {
+        "Name": "COBOL",
+        "Aliases": [
+          "COB",
+          "CPY",
+          "cob",
+          "cobol",
+          "cpy"
+        ]
+      },
       {
         "Name": "CoffeeScript",
         "Aliases": [
           "crystal"
         ]
       },
+      {
+        "Name": "CSS",
+        "Aliases": [
+          "css"
+        ]
+      },
       {
         "Name": "Cython",
         "Aliases": [
           "di"
         ]
       },
-      {
-        "Name": "DTD",
-        "Aliases": [
-          "dtd"
-        ]
-      },
       {
         "Name": "Dart",
         "Aliases": [
           "dockerfile"
         ]
       },
+      {
+        "Name": "DTD",
+        "Aliases": [
+          "dtd"
+        ]
+      },
       {
         "Name": "Dylan",
         "Aliases": [
           "hrl"
         ]
       },
-      {
-        "Name": "FSharp",
-        "Aliases": [
-          "fs",
-          "fsharp",
-          "fsi"
-        ]
-      },
       {
         "Name": "Factor",
         "Aliases": [
           "fortran"
         ]
       },
+      {
+        "Name": "FortranFixed",
+        "Aliases": [
+          "F",
+          "f",
+          "fortranfixed"
+        ]
+      },
+      {
+        "Name": "FSharp",
+        "Aliases": [
+          "fs",
+          "fsharp",
+          "fsi"
+        ]
+      },
       {
         "Name": "GAS",
         "Aliases": [
           "gdscript"
         ]
       },
-      {
-        "Name": "GLSL",
-        "Aliases": [
-          "frag",
-          "geo",
-          "glsl",
-          "vert"
-        ]
-      },
       {
         "Name": "Genshi",
         "Aliases": [
           "gherkin"
         ]
       },
+      {
+        "Name": "GLSL",
+        "Aliases": [
+          "frag",
+          "geo",
+          "glsl",
+          "vert"
+        ]
+      },
       {
         "Name": "Gnuplot",
         "Aliases": [
           "graphqls"
         ]
       },
+      {
+        "Name": "Groff",
+        "Aliases": [
+          "1p",
+          "3pm",
+          "[1-9]",
+          "groff",
+          "man",
+          "nroff"
+        ]
+      },
       {
         "Name": "Groovy",
         "Aliases": [
         ]
       },
       {
-        "Name": "HCL",
+        "Name": "Handlebars",
         "Aliases": [
-          "hcl"
+          "handlebars",
+          "hbs"
         ]
       },
       {
-        "Name": "HLB",
+        "Name": "Haskell",
         "Aliases": [
-          "hlb"
+          "haskell",
+          "hs"
         ]
       },
       {
-        "Name": "HTML",
+        "Name": "Haxe",
         "Aliases": [
-          "htm",
-          "html",
-          "xhtml",
-          "xslt"
+          "haxe",
+          "hx",
+          "hxsl"
         ]
       },
       {
-        "Name": "HTTP",
+        "Name": "HCL",
         "Aliases": [
-          "http"
+          "hcl"
         ]
       },
       {
-        "Name": "Handlebars",
+        "Name": "Hexdump",
         "Aliases": [
-          "handlebars",
-          "hbs"
+          "hexdump"
         ]
       },
       {
-        "Name": "Haskell",
+        "Name": "HLB",
         "Aliases": [
-          "haskell",
-          "hs"
+          "hlb"
         ]
       },
       {
-        "Name": "Haxe",
+        "Name": "HTML",
         "Aliases": [
-          "haxe",
-          "hx",
-          "hxsl"
+          "htm",
+          "html",
+          "xhtml",
+          "xslt"
         ]
       },
       {
-        "Name": "Hexdump",
+        "Name": "HTTP",
         "Aliases": [
-          "hexdump"
+          "http"
         ]
       },
       {
           "hylang"
         ]
       },
-      {
-        "Name": "INI",
-        "Aliases": [
-          "cfg",
-          "dosini",
-          "editorconfig",
-          "gitconfig",
-          "inf",
-          "ini"
-        ]
-      },
       {
         "Name": "Idris",
         "Aliases": [
           "ipf"
         ]
       },
+      {
+        "Name": "INI",
+        "Aliases": [
+          "cfg",
+          "dosini",
+          "editorconfig",
+          "gitconfig",
+          "inf",
+          "ini"
+        ]
+      },
       {
         "Name": "Io",
         "Aliases": [
           "j"
         ]
       },
-      {
-        "Name": "JSON",
-        "Aliases": [
-          "json"
-        ]
-      },
       {
         "Name": "Java",
         "Aliases": [
           "mjs"
         ]
       },
+      {
+        "Name": "JSON",
+        "Aliases": [
+          "json"
+        ]
+      },
       {
         "Name": "Julia",
         "Aliases": [
         ]
       },
       {
-        "Name": "LLVM",
+        "Name": "Lighttpd configuration file",
         "Aliases": [
-          "ll",
-          "llvm"
+          "lighttpd",
+          "lighty"
         ]
       },
       {
-        "Name": "Lighttpd configuration file",
+        "Name": "LLVM",
         "Aliases": [
-          "lighttpd",
-          "lighty"
+          "ll",
+          "llvm"
         ]
       },
       {
         ]
       },
       {
-        "Name": "MLIR",
+        "Name": "Mako",
         "Aliases": [
-          "mlir"
+          "mako",
+          "mao"
         ]
       },
       {
-        "Name": "Mako",
+        "Name": "markdown",
         "Aliases": [
-          "mako",
-          "mao"
+          "markdown",
+          "md",
+          "mkd"
         ]
       },
       {
           "matlab"
         ]
       },
+      {
+        "Name": "mcfunction",
+        "Aliases": [
+          "mcfunction"
+        ]
+      },
+      {
+        "Name": "Metal",
+        "Aliases": [
+          "metal"
+        ]
+      },
       {
         "Name": "MiniZinc",
         "Aliases": [
           "mzn"
         ]
       },
+      {
+        "Name": "MLIR",
+        "Aliases": [
+          "mlir"
+        ]
+      },
       {
         "Name": "Modula-2",
         "Aliases": [
         ]
       },
       {
-        "Name": "MySQL",
+        "Name": "Myghty",
         "Aliases": [
-          "mysql",
-          "sql"
+          "myghty",
+          "myt"
         ]
       },
       {
-        "Name": "Myghty",
+        "Name": "MySQL",
         "Aliases": [
-          "myghty",
-          "myt"
+          "mysql",
+          "sql"
         ]
       },
       {
           "nixos"
         ]
       },
-      {
-        "Name": "OCaml",
-        "Aliases": [
-          "ml",
-          "mli",
-          "mll",
-          "mly",
-          "ocaml"
-        ]
-      },
       {
         "Name": "Objective-C",
         "Aliases": [
           "objectivec"
         ]
       },
+      {
+        "Name": "OCaml",
+        "Aliases": [
+          "ml",
+          "mli",
+          "mll",
+          "mly",
+          "ocaml"
+        ]
+      },
       {
         "Name": "Octave",
         "Aliases": [
           "orgmode"
         ]
       },
+      {
+        "Name": "PacmanConf",
+        "Aliases": [
+          "conf",
+          "pacmanconf"
+        ]
+      },
+      {
+        "Name": "Perl",
+        "Aliases": [
+          "perl",
+          "pl",
+          "pm",
+          "t"
+        ]
+      },
       {
         "Name": "PHP",
         "Aliases": [
       {
         "Name": "PHTML",
         "Aliases": [
+          "inc",
+          "php",
+          "php[345]",
           "phtml"
         ]
       },
       {
-        "Name": "PL/pgSQL",
-        "Aliases": [
-          "plpgsql"
-        ]
-      },
-      {
-        "Name": "POVRay",
+        "Name": "Pig",
         "Aliases": [
-          "inc",
-          "pov"
+          "pig"
         ]
       },
       {
-        "Name": "PacmanConf",
+        "Name": "PkgConfig",
         "Aliases": [
-          "conf",
-          "pacmanconf"
+          "pc",
+          "pkgconfig"
         ]
       },
       {
-        "Name": "Perl",
+        "Name": "PL/pgSQL",
         "Aliases": [
-          "perl",
-          "pl",
-          "pm",
-          "t"
+          "plpgsql"
         ]
       },
       {
-        "Name": "Pig",
+        "Name": "plaintext",
         "Aliases": [
-          "pig"
+          "no-highlight",
+          "plain",
+          "text",
+          "txt"
         ]
       },
       {
-        "Name": "PkgConfig",
+        "Name": "Pony",
         "Aliases": [
-          "pc",
-          "pkgconfig"
+          "pony"
         ]
       },
       {
-        "Name": "Pony",
+        "Name": "PostgreSQL SQL dialect",
         "Aliases": [
-          "pony"
+          "postgres",
+          "postgresql"
         ]
       },
       {
         ]
       },
       {
-        "Name": "PostgreSQL SQL dialect",
+        "Name": "POVRay",
         "Aliases": [
-          "postgres",
-          "postgresql"
+          "inc",
+          "pov"
+        ]
+      },
+      {
+        "Name": "PowerQuery",
+        "Aliases": [
+          "powerquery",
+          "pq"
         ]
       },
       {
       {
         "Name": "Python",
         "Aliases": [
+          "bazel",
+          "bzl",
+          "jy",
           "py",
+          "py3",
+          "pyi",
           "python",
+          "python3",
           "pyw",
           "sage",
           "sc",
         ]
       },
       {
-        "Name": "Python 3",
+        "Name": "Python 2",
         "Aliases": [
-          "py3",
-          "python3"
+          "py2",
+          "python2"
         ]
       },
       {
           "ragel"
         ]
       },
+      {
+        "Name": "Raku",
+        "Aliases": [
+          "6pl",
+          "6pm",
+          "nqp",
+          "p6",
+          "p6l",
+          "p6m",
+          "perl6",
+          "pl",
+          "pl6",
+          "pm",
+          "pm6",
+          "raku",
+          "rakudoc",
+          "rakumod",
+          "rakutest",
+          "t"
+        ]
+      },
+      {
+        "Name": "react",
+        "Aliases": [
+          "jsx",
+          "react"
+        ]
+      },
       {
         "Name": "ReasonML",
         "Aliases": [
           "rei"
         ]
       },
+      {
+        "Name": "reg",
+        "Aliases": [
+          "reg",
+          "registry"
+        ]
+      },
+      {
+        "Name": "reStructuredText",
+        "Aliases": [
+          "rest",
+          "restructuredtext",
+          "rst"
+        ]
+      },
       {
         "Name": "Rexx",
         "Aliases": [
           "sas"
         ]
       },
-      {
-        "Name": "SCSS",
-        "Aliases": [
-          "scss"
-        ]
-      },
-      {
-        "Name": "SPARQL",
-        "Aliases": [
-          "rq",
-          "sparql"
-        ]
-      },
-      {
-        "Name": "SQL",
-        "Aliases": [
-          "sql"
-        ]
-      },
-      {
-        "Name": "SYSTEMD",
-        "Aliases": [
-          "service",
-          "systemd"
-        ]
-      },
       {
         "Name": "Sass",
         "Aliases": [
           "tst"
         ]
       },
+      {
+        "Name": "SCSS",
+        "Aliases": [
+          "scss"
+        ]
+      },
       {
         "Name": "Smalltalk",
         "Aliases": [
           "solidity"
         ]
       },
+      {
+        "Name": "SPARQL",
+        "Aliases": [
+          "rq",
+          "sparql"
+        ]
+      },
+      {
+        "Name": "SQL",
+        "Aliases": [
+          "sql"
+        ]
+      },
       {
         "Name": "SquidConf",
         "Aliases": [
           "stylus"
         ]
       },
+      {
+        "Name": "Svelte",
+        "Aliases": [
+          "svelte"
+        ]
+      },
       {
         "Name": "Swift",
         "Aliases": [
         ]
       },
       {
-        "Name": "TASM",
+        "Name": "SYSTEMD",
         "Aliases": [
-          "ASM",
-          "asm",
-          "tasm"
+          "automount",
+          "device",
+          "dnssd",
+          "link",
+          "mount",
+          "netdev",
+          "network",
+          "path",
+          "scope",
+          "service",
+          "slice",
+          "socket",
+          "swap",
+          "systemd",
+          "target",
+          "timer"
         ]
       },
       {
-        "Name": "TOML",
+        "Name": "systemverilog",
         "Aliases": [
-          "toml"
+          "sv",
+          "svh",
+          "systemverilog"
         ]
       },
       {
           "td"
         ]
       },
+      {
+        "Name": "TASM",
+        "Aliases": [
+          "ASM",
+          "asm",
+          "tasm"
+        ]
+      },
       {
         "Name": "Tcl",
         "Aliases": [
           "tcsh"
         ]
       },
-      {
-        "Name": "TeX",
-        "Aliases": [
-          "aux",
-          "latex",
-          "tex",
-          "toc"
-        ]
-      },
       {
         "Name": "Termcap",
         "Aliases": [
           "tf"
         ]
       },
+      {
+        "Name": "TeX",
+        "Aliases": [
+          "aux",
+          "latex",
+          "tex",
+          "toc"
+        ]
+      },
       {
         "Name": "Thrift",
         "Aliases": [
           "thrift"
         ]
       },
+      {
+        "Name": "TOML",
+        "Aliases": [
+          "toml"
+        ]
+      },
       {
         "Name": "TradingView",
         "Aliases": [
           "vbnet"
         ]
       },
+      {
+        "Name": "verilog",
+        "Aliases": [
+          "v",
+          "verilog"
+        ]
+      },
       {
         "Name": "VHDL",
         "Aliases": [
           "vimrc"
         ]
       },
+      {
+        "Name": "vue",
+        "Aliases": [
+          "vue",
+          "vuejs"
+        ]
+      },
       {
         "Name": "WDTE",
         "Aliases": [
         "Aliases": [
           "zig"
         ]
-      },
-      {
-        "Name": "cfstatement",
-        "Aliases": [
-          "cfs"
-        ]
-      },
-      {
-        "Name": "markdown",
-        "Aliases": [
-          "markdown",
-          "md",
-          "mkd"
-        ]
-      },
-      {
-        "Name": "mcfunction",
-        "Aliases": [
-          "mcfunction"
-        ]
-      },
-      {
-        "Name": "plaintext",
-        "Aliases": [
-          "no-highlight",
-          "plain",
-          "text",
-          "txt"
-        ]
-      },
-      {
-        "Name": "reStructuredText",
-        "Aliases": [
-          "rest",
-          "restructuredtext",
-          "rst"
-        ]
-      },
-      {
-        "Name": "react",
-        "Aliases": [
-          "jsx",
-          "react"
-        ]
-      },
-      {
-        "Name": "reg",
-        "Aliases": [
-          "reg",
-          "registry"
-        ]
-      },
-      {
-        "Name": "systemverilog",
-        "Aliases": [
-          "sv",
-          "svh",
-          "systemverilog"
-        ]
-      },
-      {
-        "Name": "verilog",
-        "Aliases": [
-          "v",
-          "verilog"
-        ]
-      },
-      {
-        "Name": "vue",
-        "Aliases": [
-          "vue",
-          "vuejs"
-        ]
       }
     ]
   },
         "preserveTOC": false
       }
     },
+    "mergeStrategy": {
+      "build": {
+        "_merge": "none"
+      },
+      "caches": {
+        "_merge": "none"
+      },
+      "frontmatter": {
+        "_merge": "none"
+      },
+      "imaging": {
+        "_merge": "none"
+      },
+      "languages": {
+        "_merge": "none",
+        "en": {
+          "_merge": "none",
+          "menus": {
+            "_merge": "shallow"
+          },
+          "params": {
+            "_merge": "deep"
+          }
+        }
+      },
+      "markup": {
+        "_merge": "none"
+      },
+      "mediatypes": {
+        "_merge": "shallow"
+      },
+      "menus": {
+        "_merge": "shallow"
+      },
+      "minify": {
+        "_merge": "none"
+      },
+      "module": {
+        "_merge": "none"
+      },
+      "outputformats": {
+        "_merge": "shallow"
+      },
+      "params": {
+        "_merge": "deep"
+      },
+      "permalinks": {
+        "_merge": "none"
+      },
+      "related": {
+        "_merge": "none"
+      },
+      "sitemap": {
+        "_merge": "none"
+      },
+      "taxonomies": {
+        "_merge": "none"
+      }
+    },
     "minify": {
       "minifyOutput": false,
       "disableHTML": false,
           "json"
         ]
       },
+      {
+        "mainType": "application",
+        "subType": "manifest",
+        "delimiter": ".",
+        "firstSuffix": {
+          "suffix": "webmanifest",
+          "fullSuffix": ".webmanifest"
+        },
+        "type": "application/manifest+json",
+        "string": "application/manifest+json",
+        "suffixes": [
+          "webmanifest"
+        ]
+      },
       {
         "mainType": "application",
         "subType": "octet-stream",
         "notAlternative": false,
         "permalinkable": false,
         "weight": 0
+      },
+      {
+        "mediaType": "application/manifest+json",
+        "name": "WebAppManifest",
+        "path": "",
+        "baseName": "manifest",
+        "rel": "manifest",
+        "protocol": "",
+        "isPlainText": true,
+        "isHTML": false,
+        "noUgly": false,
+        "notAlternative": true,
+        "permalinkable": false,
+        "weight": 0
       }
     ],
     "layouts": [
             [
               "\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"
+            ],
+            [
+              "{{ slice \"foo\" 1 \"bar\" 2 | querify | safeHTML }}",
+              "bar=2\u0026foo=1"
             ]
           ]
         },
           "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"
+            "args"
           ],
           "Aliases": [
             "getCSV"
         "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"
+            "args"
           ],
           "Aliases": [
             "getJSON"
             ]
           ]
         },
+        "Erroridf": {
+          "Description": "Erroridf formats according to a format specifier and logs an ERROR and\nan information text that the error with the given ID can be suppressed in config.\nIt returns an empty string.",
+          "Args": [
+            "id",
+            "format",
+            "a"
+          ],
+          "Aliases": [
+            "erroridf"
+          ],
+          "Examples": [
+            [
+              "{{ erroridf \"my-err-id\" \"%s.\" \"failed\" }}",
+              ""
+            ]
+          ]
+        },
         "Print": {
           "Description": "Print returns string representation of the passed arguments.",
           "Args": [
             ]
           ]
         },
+        "Max": {
+          "Description": "Max returns the greater of two numbers.",
+          "Args": [
+            "a",
+            "b"
+          ],
+          "Aliases": null,
+          "Examples": [
+            [
+              "{{math.Max 1 2 }}",
+              "2"
+            ]
+          ]
+        },
+        "Min": {
+          "Description": "Min returns the smaller of two numbers.",
+          "Args": [
+            "a",
+            "b"
+          ],
+          "Aliases": null,
+          "Examples": [
+            [
+              "{{math.Min 1 2 }}",
+              "1"
+            ]
+          ]
+        },
         "Mod": {
           "Description": "Mod returns a % b.",
           "Args": [
           ]
         },
         "Sqrt": {
-          "Description": "Sqrt returns the square root of a number.\nNOTE: will return for NaN for negative values of a",
+          "Description": "Sqrt returns the square root of a number.",
           "Args": [
             "a"
           ],
index da4b00719f2db385f3301a95614d23287a313723..0b92d520d924c921df98e21b50440e5f9e72ad76 100644 (file)
@@ -1,34 +1,41 @@
 {{ $file := .Get "file" }}
 {{ $code := "" }}
 {{ with .Get "config" }}
-{{ $file = $file | default "config" }}
-{{ $sections := (split . ".") }}
-{{ $configSection := index $.Site.Data.docs.config $sections }}
-{{ $code = dict $sections $configSection  }}
+  {{ $file = $file | default "config" }}
+  {{ $sections := (split . ".") }}
+  {{ $configSection := index $.Site.Data.docs.config $sections }}
+  {{ $code = dict $sections $configSection  }}
+  {{ if $.Get "skipHeader"}}
+    {{ $code = $configSection  }}
+  {{ end }}
 {{ else }}
-{{ $code = $.Inner }}
+  {{ $code = $.Inner }}
 {{ end  }}
 {{ $langs := (slice "yaml" "toml" "json") }}
 <div class="code relative" {{ with $file }}id="{{ . | urlize}}"{{ end }}>
-       <div class="code-nav flex flex-nowrap items-stretch">
-               {{- with $file -}}
-                       <div class="san-serif f6 dib lh-solid pl2 pv2 mr2">{{ . }}.</div>
-               {{- end -}}
-               {{ range $langs }}
-                       <button data-toggle-tab="{{ . }}" class="tab-button {{ cond (eq . "yaml") "active" ""}} ba san-serif f6 dib lh-solid ph2 pv2">{{ . }}</button>&nbsp;
-               {{ end }}
-       </div>
-       <div class="tab-content">
-               {{ range $langs }}
-                       <div data-pane="{{ . }}" class="code-copy-content nt3 tab-pane {{ cond (eq . "yaml") "active" ""}}">
-                               {{ highlight ($code | transform.Remarshal . | safeHTML) . ""}}
-                       </div>
-                       {{ if ne ($.Get "copy") "false" }}
-                               <button class="needs-js copy copy-toggle bg-accent-color-dark f6 absolute top-0 right-0 lh-solid hover-bg-primary-color-dark bn white ph3 pv2" title="Copy this code to your clipboard." data-clipboard-action="copy" aria-label="copy button">
-                               </button>
-                               {{/* Functionality located within filesaver.js The copy here is located in the css with .copy class so it can be replaced with JS on success */}}
-                       {{end}}
-               {{ end }}
-       </div>
-
+  <div class="code-nav flex flex-nowrap items-stretch">
+    {{- with $file -}}
+      <div class="san-serif f6 dib lh-solid pl2 pv2 mr2">
+        {{ . }}.
+      </div>
+    {{- end -}}
+    {{ range $langs }}
+      <button data-toggle-tab="{{ . }}" class="tab-button {{ cond (eq . "yaml") "active" ""}} ba san-serif f6 dib lh-solid ph2 pv2">
+        {{ . }}
+      </button>
+      &nbsp;
+    {{ end }}
+  </div>
+  <div class="tab-content">
+    {{ range $langs }}
+      <div data-pane="{{ . }}" class="code-copy-content nt3 tab-pane {{ cond (eq . "yaml") "active" ""}}">
+        {{ highlight ($code | transform.Remarshal . | safeHTML) . ""}}
+      </div>
+      {{ if ne ($.Get "copy") "false" }}
+        <button class="needs-js copy copy-toggle bg-accent-color-dark f6 absolute top-0 right-0 lh-solid hover-bg-primary-color-dark bn white ph3 pv2" title="Copy this code to your clipboard." data-clipboard-action="copy" aria-label="copy button"></button>
+        {{/* Functionality located within filesaver.js The copy here is located in the css with .copy class so it can be replaced with JS on success */}}
+      {{end}}
+    {{ end }}
+  </div>
+  
 </div>
index 696410d47901344a1a0bf792a93eb8ccfe77df76..23d321b2f140c4bdeddf81b92b93245b00961601 100644 (file)
@@ -3,7 +3,7 @@ publish = "public"
 command = "hugo --gc --minify"
 
 [context.production.environment]
-HUGO_VERSION = "0.83.1"
+HUGO_VERSION = "0.84.0"
 HUGO_ENV = "production"
 HUGO_ENABLEGITINFO = "true"
 
@@ -11,20 +11,20 @@ HUGO_ENABLEGITINFO = "true"
 command = "hugo --gc --minify --enableGitInfo"
 
 [context.split1.environment]
-HUGO_VERSION = "0.83.1"
+HUGO_VERSION = "0.84.0"
 HUGO_ENV = "production"
 
 [context.deploy-preview]
 command = "hugo --gc --minify --buildFuture -b $DEPLOY_PRIME_URL"
 
 [context.deploy-preview.environment]
-HUGO_VERSION = "0.83.1"
+HUGO_VERSION = "0.84.0"
 
 [context.branch-deploy]
 command = "hugo --gc --minify -b $DEPLOY_PRIME_URL"
 
 [context.branch-deploy.environment]
-HUGO_VERSION = "0.83.1"
+HUGO_VERSION = "0.84.0"
 
 [context.next.environment]
 HUGO_ENABLEGITINFO = "true"
diff --git a/resources/_gen/images/news/0.84.0-relnotes/featured_hu7c38afe80520529cfcae538ac032ebff_47732_480x0_resize_catmullrom_2.png b/resources/_gen/images/news/0.84.0-relnotes/featured_hu7c38afe80520529cfcae538ac032ebff_47732_480x0_resize_catmullrom_2.png
new file mode 100644 (file)
index 0000000..ca153c9
Binary files /dev/null and b/resources/_gen/images/news/0.84.0-relnotes/featured_hu7c38afe80520529cfcae538ac032ebff_47732_480x0_resize_catmullrom_2.png differ
diff --git a/resources/_gen/images/news/0.84.0-relnotes/featured_hu7c38afe80520529cfcae538ac032ebff_47732_640x0_resize_catmullrom_2.png b/resources/_gen/images/news/0.84.0-relnotes/featured_hu7c38afe80520529cfcae538ac032ebff_47732_640x0_resize_catmullrom_2.png
new file mode 100644 (file)
index 0000000..5e2dc09
Binary files /dev/null and b/resources/_gen/images/news/0.84.0-relnotes/featured_hu7c38afe80520529cfcae538ac032ebff_47732_640x0_resize_catmullrom_2.png differ