According to experiments and the documentation, readFile takes a path from the root of the project. Which is normally cool. But how can I refer to a file relative to the current page.
For example, if I have…
a page “t1.md” in a section “tests” that also has an md file t2.md (sorry not to good at drawing tree pictures)
-tests-t1.md
-t2.md
inside of t1.md I want to be able to write {{% include “t2.md” %}} - not the full path as {{% include “tests/t2.md” %}}
so, this (simplified) include:
{{- .Get 0 | readFile -}}
works file for the latter case (full path) - to make it work for the local case, I need to manually build the path (as far as I can tell), based on readFile assumes path relative to /content and not /, I did:
For stuff relative to the current page, shouldn’t you be using the page resources approach? (Like, with “get this resource”, print its .Content, .RawContent or whatever.)
For reference:
{{- $file := .Get 0 -}}
{{- with $.Page.Resources.GetMatch $file -}}
{{- .Content -}}
{{- end -}}
Thanks.
I am aware of this and use it extensively for other things. But, as far as I can tell, this only works with actual Hugo pages (e.g., markdown files with frontmatter). The “.Content” only works when the page is structured (as far as I can tell)
Maybe a different question is… how do I tell Hugo’s resources things to grab me files that are raw markdown. Because if I had a way to do that, I could use all of the cool resource mechanisms (e.g., the assets directory).
Assuming you were going to use assets directory and resources.GetMatch. In this case, front matter would be totally ignored (as the front matter, it would be necessary to use something like replaceRE to remove it) and markdownify would be necessary to render the content.
I still can’t think a good way to detect raw markdown files, sorry. (Oh, maybe I can do some tests with findRE or output formats, but that still would be limited.)