2016-09-29 03:39:19 +02:00
|
|
|
diff --git a/3rdparty/stout/include/stout/os/ls.hpp b/3rdparty/stout/include/stout/os/ls.hpp
|
|
|
|
index f8da9ef..6d549d3 100644
|
|
|
|
--- a/3rdparty/stout/include/stout/os/ls.hpp
|
|
|
|
+++ b/3rdparty/stout/include/stout/os/ls.hpp
|
|
|
|
@@ -18,6 +18,7 @@
|
2016-09-02 16:02:21 +02:00
|
|
|
#else
|
|
|
|
#include <dirent.h>
|
|
|
|
#endif // __WINDOWS__
|
|
|
|
+
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include <list>
|
2016-09-29 03:39:19 +02:00
|
|
|
@@ -26,8 +27,6 @@
|
2016-09-02 16:02:21 +02:00
|
|
|
#include <stout/error.hpp>
|
|
|
|
#include <stout/try.hpp>
|
|
|
|
|
|
|
|
-#include <stout/os/direntsize.hpp>
|
|
|
|
-
|
|
|
|
|
|
|
|
namespace os {
|
|
|
|
|
2016-09-29 03:39:19 +02:00
|
|
|
@@ -36,36 +35,32 @@ inline Try<std::list<std::string>> ls(const std::string& directory)
|
2016-09-02 16:02:21 +02:00
|
|
|
DIR* dir = opendir(directory.c_str());
|
|
|
|
|
2016-09-29 03:39:19 +02:00
|
|
|
if (dir == nullptr) {
|
2016-09-02 16:02:21 +02:00
|
|
|
- // Preserve `opendir` error.
|
|
|
|
return ErrnoError("Failed to opendir '" + directory + "'");
|
|
|
|
}
|
|
|
|
|
|
|
|
- dirent* temp = (dirent*) malloc(os::dirent_size(dir));
|
|
|
|
-
|
2016-09-29 03:39:19 +02:00
|
|
|
- if (temp == nullptr) {
|
2016-09-02 16:02:21 +02:00
|
|
|
- // Preserve `malloc` error.
|
|
|
|
- ErrnoError error("Failed to allocate directory entries");
|
|
|
|
- closedir(dir);
|
|
|
|
- return error;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
std::list<std::string> result;
|
|
|
|
struct dirent* entry;
|
|
|
|
- int error;
|
|
|
|
|
2016-09-29 03:39:19 +02:00
|
|
|
- while ((error = readdir_r(dir, temp, &entry)) == 0 && entry != nullptr) {
|
2016-09-02 16:02:21 +02:00
|
|
|
+ // Zero `errno` before starting to call `readdir`. This is necessary
|
|
|
|
+ // to allow us to determine when `readdir` returns an error.
|
|
|
|
+ errno = 0;
|
|
|
|
+
|
|
|
|
+ while ((entry = readdir(dir)) != NULL) {
|
|
|
|
if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
result.push_back(entry->d_name);
|
|
|
|
}
|
|
|
|
|
|
|
|
- free(temp);
|
|
|
|
- closedir(dir);
|
|
|
|
+ if (errno != 0) {
|
|
|
|
+ // Preserve `readdir` error.
|
|
|
|
+ Error error = ErrnoError("Failed to read directory");
|
|
|
|
+ closedir(dir);
|
|
|
|
+ return error;
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- if (error != 0) {
|
|
|
|
- // Preserve `readdir_r` error.
|
|
|
|
- return ErrnoError("Failed to read directories");
|
|
|
|
+ if (closedir(dir) == -1) {
|
|
|
|
+ return ErrnoError("Failed to close directory");
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|