Switch uses of dir_t to dir_iter_t

dir_t was a thin wrapper around readdir; switch to the new dir_iter_t API
and remove dir_t.
This commit is contained in:
ridiculousfish 2022-09-25 12:52:44 -07:00
parent b684f7b076
commit 36fbfef74c
3 changed files with 3 additions and 29 deletions

View file

@ -118,12 +118,11 @@ static void autoload_names(std::unordered_set<wcstring> &names, bool get_hidden)
for (i = 0; i < path_list.size(); i++) { for (i = 0; i < path_list.size(); i++) {
const wcstring &ndir_str = path_list.at(i); const wcstring &ndir_str = path_list.at(i);
dir_t dir(ndir_str); dir_iter_t dir(ndir_str);
if (!dir.valid()) continue; if (!dir.valid()) continue;
wcstring name; while (const auto *entry = dir.next()) {
while (dir.read(name)) { const wchar_t *fn = entry->name.c_str();
const wchar_t *fn = name.c_str();
const wchar_t *suffix; const wchar_t *suffix;
if (!get_hidden && fn[0] == L'_') continue; if (!get_hidden && fn[0] == L'_') continue;

View file

@ -328,22 +328,6 @@ const dir_iter_t::entry_t *dir_iter_t::next() {
return &entry_; return &entry_;
} }
dir_t::dir_t(const wcstring &path) {
const cstring tmp = wcs2string(path);
this->dir = opendir(tmp.c_str());
}
dir_t::~dir_t() {
if (this->dir != nullptr) {
closedir(this->dir);
this->dir = nullptr;
}
}
bool dir_t::valid() const { return this->dir != nullptr; }
bool dir_t::read(wcstring &name) const { return wreaddir(this->dir, name); }
int wstat(const wcstring &file_name, struct stat *buf) { int wstat(const wcstring &file_name, struct stat *buf) {
const cstring tmp = wcs2string(file_name); const cstring tmp = wcs2string(file_name);
return stat(tmp.c_str(), buf); return stat(tmp.c_str(), buf);

View file

@ -260,15 +260,6 @@ class dir_iter_t : noncopyable_t {
entry_t entry_; entry_t entry_;
}; };
/// RAII wrapper for DIR*
struct dir_t {
DIR *dir;
bool valid() const;
bool read(wcstring &name) const;
dir_t(const wcstring &path);
~dir_t();
};
#ifndef HASH_FILE_ID #ifndef HASH_FILE_ID
#define HASH_FILE_ID 1 #define HASH_FILE_ID 1
namespace std { namespace std {