Adding Planner
authorNoah Campbell <noahcampbell@gmail.com>
Sun, 1 Sep 2013 04:13:04 +0000 (21:13 -0700)
committerNoah Campbell <noahcampbell@gmail.com>
Wed, 4 Sep 2013 03:00:21 +0000 (20:00 -0700)
hugolib/planner.go [new file with mode: 0644]
hugolib/site.go
hugolib/site_show_plan_test.go [new file with mode: 0644]

diff --git a/hugolib/planner.go b/hugolib/planner.go
new file mode 100644 (file)
index 0000000..5b1d423
--- /dev/null
@@ -0,0 +1,9 @@
+package hugolib
+
+import (
+       "io"
+)
+
+func (s *Site) ShowPlan(out io.Writer) (err error) {
+       return
+}
index 5bbfc45cd6d15d1231c890284d6194d709863553..4fae4ebbd893adc798554e33dc310dd9216a049b 100644 (file)
@@ -47,6 +47,23 @@ func PrintErr(str string, a ...interface{}) {
        fmt.Fprintln(os.Stderr, str, a)
 }
 
+// Site contains all the information relevent for constructing a static
+// site.  The basic flow of information is as follows:
+//
+// 1. A list of Files is parsed and then converted into Pages.
+//
+// 2. Pages contain sections (based on the file they were generated from),
+//    aliases and slugs (included in a pages frontmatter) which are the
+//             various targets that will get generated.  There will be canonical
+//             listing.
+//
+// 3. Indexes are created via configuration and will present some aspect of
+//    the final page and typically a perm url.
+//
+// 4. All Pages are passed through a template based on their desired
+//             layout based on numerous different elements.
+//
+// 5. The entire collection of files is written to disk.
 type Site struct {
        Config     Config
        Pages      Pages
@@ -85,10 +102,9 @@ func (s *Site) Build() (err error) {
                return
        }
        if err = s.Render(); err != nil {
-               fmt.Printf("Error rendering site: %s\n", err)
-               fmt.Printf("Available templates:")
-               for _, tpl := range s.Tmpl.Templates() {
-                       fmt.Printf("\t%s\n", tpl.Name())
+               fmt.Printf("Error rendering site: %s\nAvailable templates:\n", err)
+               for _, template := range s.Tmpl.Templates() {
+                       fmt.Printf("\t%s\n", template.Name())
                }
                return
        }
diff --git a/hugolib/site_show_plan_test.go b/hugolib/site_show_plan_test.go
new file mode 100644 (file)
index 0000000..de9d736
--- /dev/null
@@ -0,0 +1,14 @@
+package hugolib
+
+import (
+       "bytes"
+       "testing"
+)
+
+func TestDegenerateNoTarget(t *testing.T) {
+       s := new(Site)
+       out := new(bytes.Buffer)
+       if err := s.ShowPlan(out); err != nil {
+               t.Errorf("ShowPlan unexpectedly returned an error: %s", err)
+       }
+}