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)