docs: Improve Traversing Local Files
authorMark D. Blackwell <markdblackwell01@gmail.com>
Sat, 10 Sep 2016 22:23:23 +0000 (18:23 -0400)
committerdigitalcraftsman <digitalcraftsman@protonmail.com>
Thu, 15 Sep 2016 13:15:04 +0000 (15:15 +0200)
docs/content/extras/localfiles.md
docs/layouts/shortcodes/directoryindex.html [new file with mode: 0644]
docs/layouts/shortcodes/fileindex.html [deleted file]
docs/layouts/shortcodes/readfile.html [new file with mode: 0644]

index 2b3549a0289ff89e1007e754aa91eb8192f7039d..d89ead098371f257c2468e4239e500254b19bdc2 100644 (file)
@@ -1,7 +1,7 @@
 ---
 aliases:
 - /doc/localfiles/
-lastmod: 2015-08-07
+lastmod: 2016-09-12
 date: 2015-06-12
 menu:
   main:
@@ -12,41 +12,47 @@ prev: /extras/urls
 title: Traversing Local Files
 weight: 110
 ---
-
 ## Traversing Local Files
 
-Hugo includes a way to traverse local files.
-This is done using the 'readDir' function.
-
-## Using readDir
-
-readDir takes a single string input that is relative to the root directory of the site. It returns an array of [os.FileInfo](https://golang.org/pkg/os/#FileInfo)
-
-Let's create a shortcode to build a file index with links using readDir.
-
-'fileindex.html'
-
-    <table style="width=100%">
-    <th>Size in bytes</th>
-    <th>Name</th>
-    {{$dir := .Get "dir"}}
-    {{ $url := .Get "baseurl" }}
-    
-    {{ $files := readDir $dir }}
-        {{ range $files }}
-                       <tr>
-                    <td>{{.Size}}</td>
-                    <td>
-                        <a href="{{$url}}{{.Name | urlize }}"> {{.Name}}</a>
-                        </td>
-                </tr>
-        {{ end }}
-    </table>
-    
-Now lets use it to list the css files used on this site
-
-    {{</* fileindex dir="static/css" baseurl="/css/" */>}}
-
-Is rendered as:
-
-{{< fileindex dir="static/css/" baseurl="/css/">}}
+Using Hugo's function `readDir`,
+you can traverse your web site's files on your server.
+## Using _readDir_
+
+The `readDir` function returns an array
+of [`os.FileInfo`](https://golang.org/pkg/os/#FileInfo).
+It takes a single, string argument: a path.
+This path can be to any directory of your web site
+(as found on your server's filesystem).
+
+Whether the path is absolute or relative makes no difference,
+because&mdash;at least for `readDir`&mdash;the root of your web site (typically `./public/`)
+in effect becomes both:
+
+1. The filesystem root; and
+1. The current working directory.
+
+## New Shortcode
+
+So, let's create a new shortcode using `readDir`:
+
+**layouts/shortcodes/directoryindex.html**
+```html
+{{< readfile "layouts/shortcodes/directoryindex.html" >}}
+```
+For the files in any given directory,
+this shortcode usefully lists their basenames and sizes,
+while providing links to them.
+
+Already&mdash;actually&mdash;this shortcode
+has been included in this very web site.
+So, let's list some of its CSS files.
+(If you click on their names, you can reveal the contents.)
+{{<   directoryindex path="/static/css" pathURL="/css"   >}}
+<br />
+This is the call that rendered the above output:
+```html
+{{</* directoryindex path="/static/css" pathURL="/css" */>}}
+```
+By the way,
+regarding the pathURL argument, the initial slash `/` is important.
+Otherwise, it becomes relative to the current web page.
diff --git a/docs/layouts/shortcodes/directoryindex.html b/docs/layouts/shortcodes/directoryindex.html
new file mode 100644 (file)
index 0000000..02a4efa
--- /dev/null
@@ -0,0 +1,13 @@
+{{- $pathURL := .Get "pathURL" -}}
+{{- $path := .Get "path" -}}
+{{- $files := readDir $path -}}
+<table>
+    <th>Size in bytes</th>
+    <th>Name</th>
+{{- range $files }}
+    <tr>
+        <td>{{ .Size }}</td>
+        <td><a href="{{ $pathURL }}{{ .Name | relURL }}"> {{ .Name }}</a></td>
+    </tr>
+{{- end }}
+</table>
diff --git a/docs/layouts/shortcodes/fileindex.html b/docs/layouts/shortcodes/fileindex.html
deleted file mode 100644 (file)
index 26b903f..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-<table style="width=100%">
-<th>Size in bytes</th>
-<th>Name</th>
-{{$dir := .Get "dir"}}
-{{ $url := .Get "baseurl" }}
-
-{{ $files := readDir $dir }}
-    {{ range $files }}
-                       <tr>
-                <td>{{.Size}}</td>
-                <td>
-                    <a href="{{$url}}{{.Name | urlize }}"> {{.Name}}</a>
-                    </td>
-            </tr>
-        {{ end }}
-</table>
diff --git a/docs/layouts/shortcodes/readfile.html b/docs/layouts/shortcodes/readfile.html
new file mode 100644 (file)
index 0000000..f5b3459
--- /dev/null
@@ -0,0 +1 @@
+{{- .Get 0 | readFile -}}