shithub: hugo

Download patch

ref: 9413cf8499e16c50520edc4392408f16185bd168
parent: 74c90553b42284eef503cdb9f81d5dc097d9d2cb
author: Steve Francia <[email protected]>
date: Mon Jan 25 09:40:44 EST 2016

Handle self rename operations gracefully

--- a/commands/hugo.go
+++ b/commands/hugo.go
@@ -483,6 +483,7 @@
 		publishDir = helpers.FilePathSeparator
 	}
 
+	// Includes both theme/static & /static
 	staticSourceFs := getStaticSourceFs()
 
 	if staticSourceFs == nil {
@@ -499,8 +500,12 @@
 	syncer.Delete = true
 	jww.INFO.Println("syncing static files to", publishDir)
 
-	// because we are using a baseFs (to get the union right). Sync from the root
-	syncer.Sync(publishDir, helpers.FilePathSeparator)
+	// because we are using a baseFs (to get the union right).
+	// set sync src to root
+	err := syncer.Sync(publishDir, helpers.FilePathSeparator)
+	if err != nil {
+		return err
+	}
 	return nil
 //
 //	themeDir, err := helpers.GetThemeStaticDirPath()
@@ -718,7 +723,6 @@
 						jww.FEEDBACK.Printf("Syncing all static files\n")
 						err := copyStatic()
 						if err != nil {
-							fmt.Println(err)
 							utils.StopOnErr(err, fmt.Sprintf("Error copying static files to %s", helpers.AbsPathify(viper.GetString("PublishDir"))))
 						}
 					} else {
--- a/hugolib/site.go
+++ b/hugolib/site.go
@@ -44,6 +44,7 @@
 	"github.com/spf13/nitro"
 	"github.com/spf13/viper"
 	"gopkg.in/fsnotify.v1"
+	"github.com/spf13/afero"
 )
 
 var _ = transform.AbsURL
@@ -500,11 +501,24 @@
 		go converterCollator(s, convertResults, errs)
 
 		for _, ev := range sourceChanged {
-			if ev.Op&fsnotify.Rename == fsnotify.Rename || ev.Op&fsnotify.Remove == fsnotify.Remove {
+
+			if  ev.Op&fsnotify.Remove == fsnotify.Remove {
 				//remove the file & a create will follow
 				path, _ := helpers.GetRelativePath(ev.Name, s.absContentDir())
 				s.RemovePageByPath(path)
 				continue
+			}
+
+			// Some editors (Vim) sometimes issue only a Rename operation when writing an existing file
+			// Sometimes a rename operation means that file has been renamed other times it means
+			// it's been updated
+			if ev.Op&fsnotify.Rename == fsnotify.Rename {
+				// If the file is still on disk, it's only been updated, if it's not, it's been moved
+				if ex, err := afero.Exists(hugofs.SourceFs, ev.Name); !ex || err != nil {
+					path, _ := helpers.GetRelativePath(ev.Name, s.absContentDir())
+					s.RemovePageByPath(path)
+					continue
+				}
 			}
 
 			file, err := s.ReReadFile(ev.Name)