Make sure we always create the /public folder
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Thu, 23 Dec 2021 07:57:28 +0000 (08:57 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Thu, 23 Dec 2021 14:09:27 +0000 (15:09 +0100)
* Before this commit, when you had static files in the root of /content and no /public folder, that folder would not be created unless the /static syncer had already run.
* So, with a common pattern doing `rm -rf public && hugo` would the fail now and then because /static and /content are processed in parallel (unless you have cleanDestinationDir=true)
* This was even worse before commit 0b918e131fe523188b820d1e3fa0b08251abde69 – a frozen build.

Closes #8166

hugolib/filesystems/basefs.go

index a51cc4b2702209d1cd3a149b936d36a0164463cc..aae3613f247639c6fe07240fcb60bb4c7b6395df 100644 (file)
@@ -428,6 +428,11 @@ func NewBase(p *paths.Paths, logger loggers.Logger, options ...func(*BaseFs) err
                logger = loggers.NewWarningLogger()
        }
 
+       // Make sure we always have the /public folder ready to use.
+       if err := fs.Destination.MkdirAll(p.AbsPublishDir, 0777); err != nil && !os.IsExist(err) {
+               return nil, err
+       }
+
        publishFs := hugofs.NewBaseFileDecorator(afero.NewBasePathFs(fs.Destination, p.AbsPublishDir))
        sourceFs := hugofs.NewBaseFileDecorator(afero.NewBasePathFs(fs.Source, p.WorkingDir))