diff options
author | Roman Perepelitsa <roman.perepelitsa@gmail.com> | 2020-06-14 11:29:29 +0300 |
---|---|---|
committer | Roman Perepelitsa <roman.perepelitsa@gmail.com> | 2020-06-14 11:29:29 +0300 |
commit | 5e5d3f5afff5112da97b5b972a17d24411bb04c7 (patch) | |
tree | 1d26aa18a19db659558554ec306d6207b13f9194 /gitstatus/src/dir.cc | |
parent | 4c15d633ddf311d07c45f94c326ef27e19c9e7b7 (diff) | |
parent | 0717e57ff46201ff04e7d62cda8677e174a83be6 (diff) |
Merge commit '0717e57ff46201ff04e7d62cda8677e174a83be6'
Diffstat (limited to 'gitstatus/src/dir.cc')
-rw-r--r-- | gitstatus/src/dir.cc | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/gitstatus/src/dir.cc b/gitstatus/src/dir.cc index 14bc6ac4..1817e1d3 100644 --- a/gitstatus/src/dir.cc +++ b/gitstatus/src/dir.cc @@ -116,16 +116,18 @@ bool ListDir(int dir_fd, Arena& arena, std::vector<char*>& entries, bool precomp entries.clear(); return false; } - if (n == 0) break; for (int pos = 0; pos < n;) { auto* ent = reinterpret_cast<linux_dirent64*>(buf + pos); if (!Dots(ent->d_name)) entries.push_back(ent->d_name); pos += ent->d_reclen; - // It's tempting to bail here if n + sizeof(linux_dirent64) + 512 <= n. After all, there - // was enough space for another entry but SYS_getdents64 didn't write it, so this must be - // the end of the directory listing, right? Unfortuatenly, no. SYS_getdents64 is finicky. - // It sometimes writes a partial list of entries even if the full list would fit. } + if (n == 0) break; + // The following optimization relies on SYS_getdents64 always returning as many + // entries as would fit. This is not guaranteed by the specification and I don't + // know if this is true in practice. The optimization has no measurable effect on + // gitstatus performance, so it's turned off. + // + // if (n + sizeof(linux_dirent64) + 512 <= kBufSize) break; } if (case_sensitive) { |