diff options
author | Bjørn Erik Pedersen <[email protected]> | 2021-07-13 11:41:02 +0200 |
---|---|---|
committer | Bjørn Erik Pedersen <[email protected]> | 2021-07-15 17:14:26 +0200 |
commit | 022c4795510306e08a4aba31504ca382d41c7fac (patch) | |
tree | d4c29f62038d0f336d90f32f46bc5b4f5c3ddc28 /modules | |
parent | f27e542442d19436f1428cc22bb03aca398d37a7 (diff) | |
download | hugo-022c4795510306e08a4aba31504ca382d41c7fac.tar.gz hugo-022c4795510306e08a4aba31504ca382d41c7fac.zip |
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
Diffstat (limited to 'modules')
-rw-r--r-- | modules/npm/package_builder.go | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/modules/npm/package_builder.go b/modules/npm/package_builder.go index a073b3d8f..aa9ecb35b 100644 --- a/modules/npm/package_builder.go +++ b/modules/npm/package_builder.go @@ -80,12 +80,12 @@ func Pack(fs afero.Fs, fis []hugofs.FileMetaInfo) error { } meta := fi.(hugofs.FileMetaInfo).Meta() - masterFilename := meta.Filename() + masterFilename := meta.Filename f, err := meta.Open() if err != nil { return errors.Wrap(err, "npm pack: failed to open package file") } - b = newPackageBuilder(meta.Module(), f) + b = newPackageBuilder(meta.Module, f) f.Close() for _, fi := range fis { @@ -100,7 +100,7 @@ func Pack(fs afero.Fs, fis []hugofs.FileMetaInfo) error { meta := fi.(hugofs.FileMetaInfo).Meta() - if meta.Filename() == masterFilename { + if meta.Filename == masterFilename { continue } @@ -108,7 +108,7 @@ func Pack(fs afero.Fs, fis []hugofs.FileMetaInfo) error { if err != nil { return errors.Wrap(err, "npm pack: failed to open package file") } - b.Add(meta.Module(), f) + b.Add(meta.Module, f) f.Close() } |