aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRoman Perepelitsa <roman.perepelitsa@gmail.com>2020-11-24 14:32:19 +0300
committerRoman Perepelitsa <roman.perepelitsa@gmail.com>2020-11-24 14:32:19 +0300
commit39cf063480f6a378dadc802c174e96112c38c0c0 (patch)
tree40638090ec42d2fbf44a307fa325b6403522aa44 /src
parent28301be914dec6da5d1bbd21cd8511cd71b419ee (diff)
Squashed 'gitstatus/' changes from 90cbb46b..ae213c54
ae213c54 add "pkg" target to makefile a208375b comments cdeb063d Give ListDir() the same semantics on BSD as on Linux git-subtree-dir: gitstatus git-subtree-split: ae213c540dd6924d3fb153a0860276897c9ba6c8
Diffstat (limited to 'src')
-rw-r--r--src/arena.h4
-rw-r--r--src/dir.cc7
2 files changed, 6 insertions, 5 deletions
diff --git a/src/arena.h b/src/arena.h
index 0bad0bfa..569833ca 100644
--- a/src/arena.h
+++ b/src/arena.h
@@ -37,7 +37,7 @@ namespace gitstatus {
//
// // Donates a block to the arena. When the time comes, it'll be freed with
// // free(p, size, userdata).
-// void Donate(void* p, size_t size, void* userdata, void(*free)(void*, void*));
+// void Donate(void* p, size_t size, void* userdata, void(*free)(void*, size_t, void*));
class Arena {
public:
struct Options {
@@ -62,7 +62,7 @@ class Arena {
//
// void* userdata;
// void (*alloc)(size_t size, size_t alignment, void* userdata);
- // void (*free)(size_t size, void* userdata);
+ // void (*free)(void* p, size_t size, void* userdata);
};
// Requires: opt.min_block_size <= opt.max_block_size.
diff --git a/src/dir.cc b/src/dir.cc
index 1817e1d3..e7ce7141 100644
--- a/src/dir.cc
+++ b/src/dir.cc
@@ -211,14 +211,15 @@ char* DirenvConvert(Arena& arena, struct dirent& ent, bool do_convert) {
bool ListDir(int dir_fd, Arena& arena, std::vector<char*>& entries, bool precompose_unicode,
bool case_sensitive) {
- VERIFY((dir_fd = dup(dir_fd)) >= 0);
+ entries.clear();
+ dir_fd = dup(dir_fd);
+ if (dir_fd < 0) return false;
DIR* dir = fdopendir(dir_fd);
if (!dir) {
CHECK(!close(dir_fd)) << Errno();
- return -1;
+ return false;
}
ON_SCOPE_EXIT(&) { CHECK(!closedir(dir)) << Errno(); };
- entries.clear();
while (struct dirent* ent = (errno = 0, readdir(dir))) {
if (Dots(ent->d_name)) continue;
entries.push_back(DirenvConvert(arena, *ent, precompose_unicode));