2020-07-02 07:04:46 +00:00
|
|
|
// Copyright 2020 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 debug provides template functions to help debugging templates.
|
|
|
|
package debug
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/sanity-io/litter"
|
2023-04-20 09:27:55 +00:00
|
|
|
"github.com/spf13/cast"
|
|
|
|
"github.com/yuin/goldmark/util"
|
2020-07-02 07:04:46 +00:00
|
|
|
|
|
|
|
"github.com/gohugoio/hugo/deps"
|
|
|
|
)
|
|
|
|
|
|
|
|
// New returns a new instance of the debug-namespaced template functions.
|
|
|
|
func New(d *deps.Deps) *Namespace {
|
|
|
|
return &Namespace{}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Namespace provides template functions for the "debug" namespace.
|
|
|
|
type Namespace struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
// Dump returns a object dump of val as a string.
|
|
|
|
// Note that not every value passed to Dump will print so nicely, but
|
2022-12-21 12:11:08 +00:00
|
|
|
// we'll improve on that.
|
|
|
|
//
|
|
|
|
// We recommend using the "go" Chroma lexer to format the output
|
2020-07-02 07:04:46 +00:00
|
|
|
// nicely.
|
2022-12-21 12:11:08 +00:00
|
|
|
//
|
2020-07-02 07:04:46 +00:00
|
|
|
// Also note that the output from Dump may change from Hugo version to the next,
|
|
|
|
// so don't depend on a specific output.
|
2022-03-17 21:03:27 +00:00
|
|
|
func (ns *Namespace) Dump(val any) string {
|
2020-07-02 07:04:46 +00:00
|
|
|
return litter.Sdump(val)
|
|
|
|
}
|
2023-04-20 09:27:55 +00:00
|
|
|
|
|
|
|
// VisualizeSpaces returns a string with spaces replaced by a visible string.
|
|
|
|
func (ns *Namespace) VisualizeSpaces(val any) string {
|
|
|
|
s := cast.ToString(val)
|
|
|
|
return string(util.VisualizeSpaces([]byte(s)))
|
|
|
|
}
|