A single file can be replaced in site.Files
authorSteve Francia <steve.francia@gmail.com>
Mon, 11 Jan 2016 15:48:23 +0000 (10:48 -0500)
committerSteve Francia <steve.francia@gmail.com>
Tue, 26 Jan 2016 19:29:37 +0000 (14:29 -0500)
hugolib/site.go

index 07a11102e0e6ac2db1cf11da9a62de327e4bd82b..0376645ca91ddcaf2939b429ab9348016d27f7f8 100644 (file)
@@ -536,6 +536,7 @@ func (s *Site) ReBuild(changed map[string]bool) error {
                s.timerStep("build taxonomies")
        }
 
+       // Once the appropriate prep step is done we render the entire site
        if err = s.Render(); err != nil {
                // Better reporting when the template is missing (commit 2bbecc7b)
                jww.ERROR.Printf("Error rendering site: %s", err)
@@ -1024,6 +1025,18 @@ func (s *Site) ReplacePage(page *Page) {
        s.AddPage(page)
 }
 
+func (s *Site) ReplaceFile(sf *source.File) {
+       for i, f := range s.Files {
+               if f.Path() == sf.Path() {
+                       s.Files[i] = sf
+                       return
+               }
+       }
+
+       // If a match isn't found, then append it
+       s.Files = append(s.Files, sf)
+}
+
 func incrementalReadCollator(s *Site, results <-chan HandledResult, pageChan chan *Page, fileConvChan chan *source.File, coordinator chan bool, errs chan<- error) {
        errMsgs := []string{}
        for r := range results {
@@ -1033,8 +1046,7 @@ func incrementalReadCollator(s *Site, results <-chan HandledResult, pageChan cha
                }
 
                if r.page == nil {
-                       // TODO(spf13): Make this incremental as well
-                       s.Files = append(s.Files, r.file)
+                       s.ReplaceFile(r.file)
                        fileConvChan <- r.file
                } else {
                        s.ReplacePage(r.page)