Releases: mrmlnc/fast-glob
3.3.2
3.3.1
Full Changelog: 3.3.0...3.3.1
This release fixes a regression for cases where the ignore
option is used with a string (#403, #404).
The public interface of this package does not support a string as the value for the ignore
option since 2018 year (release).
So, in the next major release, we will reintroduce method implementations that do not involve strings in the ignore
option.
3.3.0
Full Changelog: 3.2.12...3.3.0
🚀 Improvements
Method aliases
New methods (glob
, globSync
, globStream
) have been added in addition to the current methods (default import, sync
, stream
), which eliminate the need to rename the method when importing. In addition, an async
alias has been added for the default import, which makes it possible to use this packet with ESM.
Method to convert paths to globs
A new method (convertPathToPattern
) has been added in this release to convert a path to a pattern. The primary goal is to enable users to avoid processing Windows paths in each location where this package is used by utilities from third-party packages.
See more details in the pull request.
🐛 Bug fixes
- In the past, we mishandled patterns that contained slashes when the
baseNameMatch
option was enabled, which went against the documented behavior. (#312) - Several problems with matching patterns that contain brace expansion have been resolved. The primary issue solved is when the pattern has duplicate slashes after it is expanded (#394), or the
micromatch
package does not correctly generate a regular expression (#365). - All negative patterns will now have the
dot
option enabled when matching paths. Previously, the!**/*
patterns did not exclude hidden files (start with a dot). (#343) - The issue that led to duplicates in the results when overlapping or duplicate patterns were present among the patterns has been fixed. At the moment, we are only talking about leading dot. Other cases are not included. For example, running with the patterns
['./file.md', 'file.md', '*']
will now only includefile.md
once in the results. (#190)
📖 Documentation
A clarifying note has been added for the concurrency
option, which provides more detailed information about the Thread Pool utilization.
⚙️ Infrastructure
- The benchmark in CI is now running on Node.js 20.
- The benchmark now uses the public package bencho instead of an in-house implementation. You may want to try this solution for your packages and provide feedback.
🥇 New Contributors
- @josh-hemphill made their first contribution in #383
- @mairaw made their first contribution in #401
3.2.12
Full Changelog: 3.2.11...3.2.12
🐛 Bug fixes
Fixed an issue introduced in 3.2.7
related to incorrect application of patterns to entries with a trailing slash when the entry is not a directory.
Before changes:
fg.sync('**/!(*.md)')
// ['file.md', 'a/file.md', 'a/file.txt']
After fix:
fg.sync('**/!(*.md)')
// ['a/file.txt']
Thanks @AgentEnder for the issue (#357).
🚀 Improvements
This release includes performance improvements for the asynchronous method. For this method we now use an asynchronous directory traversal interface instead of using a streaming interface. This gives up to 15% acceleration for medium and large directories. The result depends a lot on hardware.
You can find the benchmark results for this release in CI here.
Here are a few of measurements on my laptop:
===> Benchmark pattern "*" with 100 launches (regression, async)
===> Max stdev: 7 | Retries: 3 | Options: {}
Name Time, ms Time stdev, % Memory, MB Memory stdev, % Entries Errors Retries
--------------------- -------- ------------- ---------- --------------- ------- ------ -------
fast-glob-current.js 4.390 0.252 6.253 0.015 4 0 1
fast-glob-previous.js 5.653 0.633 6.051 0.056 4 0 1
===> Benchmark pattern "**" with 100 launches (regression, async)
===> Max stdev: 7 | Retries: 3 | Options: {}
Name Time, ms Time stdev, % Memory, MB Memory stdev, % Entries Errors Retries
--------------------- -------- ------------- ---------- --------------- ------- ------ -------
fast-glob-current.js 34.587 1.287 10.654 0.607 11835 0 1
fast-glob-previous.js 41.972 2.086 10.236 1.224 11835 0 1
3.2.11
Full Changelog: 3.2.10...3.2.11
🐛 Bug fixes
Yeap, this is another release aimed at fixing problems with detecting brace expansions in patterns. This time, patterns like abc/{a.txt,b.js}
was not marked as a dynamic pattern. So, now the regex has been rewritten to a generalized solution as a function to avoid future problems due to the complexity of the regular expression.
3.2.10
Full Changelog: 3.2.9...3.2.10
🐛 Bug fixes
- Fixed a regression in
3.2.8
when the{a,b,c}
pattern no longer considered a dynamic pattern (thanks @amitdahan, #347).
🥇 New Contributors
- @amitdahan made their first contribution in #348
3.2.9
3.2.8
Full Changelog: 3.2.7...3.2.8
🐛 Bug fixes
Fix directory matching with trailing slashes (#290)
Thanks @Trott for investigating the problem and the detailed description.
Previously the src/*/
pattern did not work as expected (like src/*
).
Double-slash in the middle of the pattern is not collapsed (#330)
Starting from this release, patterns like src//*
will work like similar patterns without duplicate slashes. This was done for continuity with other solutions (glob
, ls src//*
, python, golang, …).
Adjust inefficient regular expressions (#336, #342, #344)
Thanks @Trott for fixing bugs and @XhmikosR for adding the CodeQL action to CI pipeline.
📖 Documentation
- Some documentation improvements (#327, thanks @MarcelloTheArcane).
⚙️ Infrastructure
- The CodeQL action has been added to CI pipeline (#338, thanks @XhmikosR).
🥇 New Contributors
3.2.7
3.2.6
🐛 Bug fixes
// Patterns inside current directory → ['*', './*.js']
// Patterns outside current directory → ['../*', './../*.js']
// Previously you could specify a patterns outside current directory.
fg.sync(['../*.txt']) → ['../file.txt']
// But when the pattern inside current directory was added to them, the behavior broke down.
fg.sync(['*.md', '../*.txt']) → ['file.md'] // The '../file.txt' file exists
// After this fix you can mix both kinds of patterns.
fg.sync(['*.md', '../*.txt']) → ['file.md', '../file.txt']
// Right now we do not support patterns like '{.,..}/*.md'.
📖 Documentation
- Added clarifications for the
followSymbolicLinks
option.
⚙️ Infrastructure
- The
glob-parent
package has been updated to fix vulnerabilities. (#304) - The
micromatch
package has been updated to eliminate dependency on thepicomatch
package from this package. (#256) - Node.js 16 has been added to the CI configuration to run tests and benchmarks. Now benchmarks will run only on this version. (#311)
- The
tiny-glob
package has been added to the synchronous product benchmarks. (#323) - The
fdir
package has been added to synchronous and asynchronous product benchmarks. The latest launch. (#322) - The
.npmignore
file has been replaced by thefiles
field in thepackage.json
file. (#321)