mirror of
https://github.com/panda3d/panda3d.git
synced 2025-10-02 09:52:27 -04:00
checking errno after readdir() is just a mistake
This commit is contained in:
parent
9778ec7a19
commit
ab68148bdd
@ -1160,8 +1160,8 @@ find_on_searchpath(const DSearchPath &searchpath) {
|
|||||||
bool Filename::
|
bool Filename::
|
||||||
scan_directory(vector_string &contents) const {
|
scan_directory(vector_string &contents) const {
|
||||||
#if defined(WIN32_VC)
|
#if defined(WIN32_VC)
|
||||||
// Use FindFirstFile()/FindNextFile() to walk through the list of
|
// Use Windows' FindFirstFile() / FindNextFile() to walk through the
|
||||||
// files in a directory.
|
// list of files in a directory.
|
||||||
size_t orig_size = contents.size();
|
size_t orig_size = contents.size();
|
||||||
|
|
||||||
string match;
|
string match;
|
||||||
@ -1194,17 +1194,61 @@ scan_directory(vector_string &contents) const {
|
|||||||
sort(contents.begin() + orig_size, contents.end());
|
sort(contents.begin() + orig_size, contents.end());
|
||||||
return scan_ok;
|
return scan_ok;
|
||||||
|
|
||||||
|
#elif defined(HAVE_DIRENT_H)
|
||||||
|
// Use Posix's opendir() / readir() to walk through the list of
|
||||||
|
// files in a directory.
|
||||||
|
size_t orig_size = contents.size();
|
||||||
|
|
||||||
|
string dirname;
|
||||||
|
if (empty()) {
|
||||||
|
dirname = ".";
|
||||||
|
} else {
|
||||||
|
dirname = _filename;
|
||||||
|
}
|
||||||
|
DIR *root = opendir(dirname.c_str());
|
||||||
|
if (root == (DIR *)NULL) {
|
||||||
|
perror(dirname.c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct dirent *d;
|
||||||
|
d = readdir(root);
|
||||||
|
while (d != (struct dirent *)NULL) {
|
||||||
|
if (d->d_name[0] != '.') {
|
||||||
|
contents.push_back(d->d_name);
|
||||||
|
}
|
||||||
|
d = readdir(root);
|
||||||
|
}
|
||||||
|
|
||||||
|
// It turns out to be a mistake to check the value of errno after
|
||||||
|
// calling readdir(), since it might have been set to non-zero
|
||||||
|
// during some internal operation of readdir(), even though there
|
||||||
|
// wasn't really a problem with scanning the directory itself.
|
||||||
|
/*
|
||||||
|
if (errno != 0 && errno != ENOENT && errno != ENOTDIR) {
|
||||||
|
cerr << "Error occurred while scanning directory " << dirname << "\n";
|
||||||
|
perror(dirname.c_str());
|
||||||
|
closedir(root);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
closedir(root);
|
||||||
|
|
||||||
|
sort(contents.begin() + orig_size, contents.end());
|
||||||
|
return true;
|
||||||
|
|
||||||
#elif defined(HAVE_GLOB_H)
|
#elif defined(HAVE_GLOB_H)
|
||||||
// In some cases, particularly with NFS, it seems that opendir()
|
// It's hard to imagine a system that provides glob.h but does not
|
||||||
// .. readdir() fails to properly read the entire directory ("Value
|
// provide openddir() .. readdir(), but this code is leftover from a
|
||||||
// too large for defined data type"), but glob() succeeds.
|
// time when there was an undetected bug in the above readdir()
|
||||||
|
// loop, and it works, so we might as well keep it around for now.
|
||||||
string dirname;
|
string dirname;
|
||||||
if (empty()) {
|
if (empty()) {
|
||||||
dirname = "*";
|
dirname = "*";
|
||||||
} else if (_filename[_filename.length() - 1] == '/') {
|
} else if (_filename[_filename.length() - 1] == '/') {
|
||||||
dirname = _filename + "*";
|
dirname = _filename + "*";
|
||||||
} else {
|
} else {
|
||||||
dirname = _filename + "/*";
|
dirname = _filename + "/*"; /* comment to fix emacs syntax hilight */
|
||||||
}
|
}
|
||||||
|
|
||||||
glob_t globbuf;
|
glob_t globbuf;
|
||||||
@ -1235,41 +1279,6 @@ scan_directory(vector_string &contents) const {
|
|||||||
globfree(&globbuf);
|
globfree(&globbuf);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
#elif defined(HAVE_DIRENT_H)
|
|
||||||
size_t orig_size = contents.size();
|
|
||||||
|
|
||||||
string dirname;
|
|
||||||
if (empty()) {
|
|
||||||
dirname = ".";
|
|
||||||
} else {
|
|
||||||
dirname = _filename;
|
|
||||||
}
|
|
||||||
DIR *root = opendir(dirname.c_str());
|
|
||||||
if (root == (DIR *)NULL) {
|
|
||||||
perror(dirname.c_str());
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
errno = 0;
|
|
||||||
struct dirent *d;
|
|
||||||
d = readdir(root);
|
|
||||||
while (d != (struct dirent *)NULL) {
|
|
||||||
if (d->d_name[0] != '.') {
|
|
||||||
contents.push_back(d->d_name);
|
|
||||||
}
|
|
||||||
d = readdir(root);
|
|
||||||
}
|
|
||||||
if (errno != 0 && errno != ENOENT && errno != ENOTDIR) {
|
|
||||||
cerr << "Error occurred while scanning directory " << dirname << "\n";
|
|
||||||
perror(dirname.c_str());
|
|
||||||
closedir(root);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
closedir(root);
|
|
||||||
|
|
||||||
sort(contents.begin() + orig_size, contents.end());
|
|
||||||
return true;
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
// Don't know how to scan directories!
|
// Don't know how to scan directories!
|
||||||
|
Loading…
x
Reference in New Issue
Block a user