Skip to content

Commit

Permalink
globwalker: avoid spurious allocations in iterator
Browse files Browse the repository at this point in the history
This tweaks the `GlobWalker` iterator logic in order to avoid
a spurious allocation for each processed directory entry (including
ignored ones).

Verified by running the current testsuite under `heaptrack` and
observing allocations stats:

```
$ heaptrack target/debug/deps/globwalk-baseline
[...]
heaptrack stats:
        allocations:            7176
[...]

$ heaptrack target/debug/deps/globwalk-patched
[...]
heaptrack stats:
        allocations:            7081
[...]
```
  • Loading branch information
lucab committed Jan 6, 2024
1 parent 96bd5ef commit 8528c5a
Showing 1 changed file with 2 additions and 6 deletions.
8 changes: 2 additions & 6 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -378,14 +378,10 @@ impl Iterator for GlobWalker {
// able to recognize the file name.
// `unwrap` here is safe, since walkdir returns the files with relation
// to the given base-dir.
let path = e
.path()
.strip_prefix(self.ignore.path())
.unwrap()
.to_owned();
let path = e.path().strip_prefix(self.ignore.path()).unwrap();

// The path might be empty after stripping if the current base-directory is matched.
if let Some("") = path.to_str() {
if path.as_os_str().is_empty() {
continue 'skipper;
}

Expand Down

0 comments on commit 8528c5a

Please sign in to comment.