mirror of
https://github.com/gohugoio/hugo.git
synced 2025-08-20 21:31:32 +02:00
hugofs: Make FileMeta a struct
This commit started out investigating a `concurrent map read write` issue, ending by replacing the map with a struct. This is easier to reason about, and it's more effective: ``` name old time/op new time/op delta SiteNew/Regular_Deep_content_tree-16 71.5ms ± 3% 69.4ms ± 5% ~ (p=0.200 n=4+4) name old alloc/op new alloc/op delta SiteNew/Regular_Deep_content_tree-16 29.7MB ± 0% 27.9MB ± 0% -5.82% (p=0.029 n=4+4) name old allocs/op new allocs/op delta SiteNew/Regular_Deep_content_tree-16 313k ± 0% 303k ± 0% -3.35% (p=0.029 n=4+4) ``` See #8749
This commit is contained in:
@@ -80,7 +80,7 @@ func (f *Filesystem) captureFiles() error {
|
||||
}
|
||||
|
||||
meta := fi.Meta()
|
||||
filename := meta.Filename()
|
||||
filename := meta.Filename
|
||||
|
||||
b, err := f.shouldRead(filename, fi)
|
||||
if err != nil {
|
||||
@@ -105,7 +105,7 @@ func (f *Filesystem) captureFiles() error {
|
||||
}
|
||||
|
||||
func (f *Filesystem) shouldRead(filename string, fi hugofs.FileMetaInfo) (bool, error) {
|
||||
ignore := f.SourceSpec.IgnoreFile(fi.Meta().Filename())
|
||||
ignore := f.SourceSpec.IgnoreFile(fi.Meta().Filename)
|
||||
|
||||
if fi.IsDir() {
|
||||
if ignore {
|
||||
|
Reference in New Issue
Block a user