2015-05-25 19:16:10 +00:00
|
|
|
---
|
|
|
|
aliases:
|
|
|
|
- /doc/debugging/
|
|
|
|
- /layout/debugging/
|
2016-01-06 22:45:19 +00:00
|
|
|
lastmod: 2015-05-25
|
2015-05-25 19:16:10 +00:00
|
|
|
date: 2015-05-22
|
|
|
|
linktitle: Debugging
|
|
|
|
menu:
|
|
|
|
main:
|
|
|
|
parent: layout
|
|
|
|
prev: /templates/404
|
|
|
|
title: Template Debugging
|
|
|
|
weight: 110
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
|
|
# Template Debugging
|
|
|
|
|
|
|
|
Here are some snippets you can add to your template to answer some common questions.
|
|
|
|
These snippets use the `printf` function available in all Go templates. This function is
|
|
|
|
an alias to the Go function, [fmt.Printf](http://golang.org/pkg/fmt/).
|
|
|
|
|
|
|
|
### What type of page is this?
|
|
|
|
|
|
|
|
Does Hugo consider this page to be a "Node" or a "Page"? (Put this snippet at
|
|
|
|
the top level of your template. Don't use it inside of a `range` loop.)
|
|
|
|
|
|
|
|
{{ printf "%T" . }}
|
|
|
|
|
|
|
|
|
|
|
|
### What variables are available in this context?
|
|
|
|
|
|
|
|
You can use the template syntax, `$.`, to get the top-level template context
|
|
|
|
from anywhere in your template. This will print out all the values under, `.Site`.
|
|
|
|
|
|
|
|
{{ printf "%#v" $.Site }}
|
|
|
|
|
|
|
|
This will print out the value of `.Permalink`, which is available on both Nodes
|
|
|
|
and Pages.
|
|
|
|
|
|
|
|
{{ printf "%#v" .Permalink }}
|
|
|
|
|
|
|
|
This will print out a list of all the variables scoped to the current context
|
|
|
|
(a.k.a. The dot, "`.`").
|
|
|
|
|
|
|
|
{{ printf "%#v" . }}
|
|
|
|
|
|
|
|
When writing a [Homepage](/templates/homepage), what does one of the pages
|
|
|
|
you're looping through look like?
|
|
|
|
|
|
|
|
```
|
|
|
|
{{ range .Data.Pages }}
|
|
|
|
{{/* The context, ".", is now a Page */}}
|
|
|
|
{{ printf "%#v" . }}
|
|
|
|
{{ end }}
|
|
|
|
```
|
2016-03-12 08:44:50 +00:00
|
|
|
|
|
|
|
### Why do I have no variables defined?
|
|
|
|
|
|
|
|
Check that you are passing variables in the `partial` function. For example
|
|
|
|
|
|
|
|
```
|
|
|
|
{{ partial "header" }}
|
|
|
|
```
|
|
|
|
|
|
|
|
will render the header partial, but the header partial will not have access to any variables. You need to pass variables explicitly. For example:
|
|
|
|
|
|
|
|
```
|
|
|
|
{{ partial "header" . }}
|
|
|
|
```
|