Commit 5d6c2405 authored by Robert Haas's avatar Robert Haas

Improve pg_check_dir code and comments.

Avoid losing errno if readdir() fails and closedir() works.  Consistently
return 4 rather than 3 if both a lost+found directory and other files are
found, rather than returning one value or the other depending on the
order of the directory listing.  Update comments to match the actual
behavior.

These oversights date to commits 6f03927f
and 17f15239.

Marco Nenciarini
parent c923e82a
...@@ -22,7 +22,9 @@ ...@@ -22,7 +22,9 @@
* Returns: * Returns:
* 0 if nonexistent * 0 if nonexistent
* 1 if exists and empty * 1 if exists and empty
* 2 if exists and not empty * 2 if exists and contains _only_ dot files
* 3 if exists and contains a mount point
* 4 if exists and not empty
* -1 if trouble accessing directory (errno reflects the error) * -1 if trouble accessing directory (errno reflects the error)
*/ */
int int
...@@ -32,6 +34,8 @@ pg_check_dir(const char *dir) ...@@ -32,6 +34,8 @@ pg_check_dir(const char *dir)
DIR *chkdir; DIR *chkdir;
struct dirent *file; struct dirent *file;
bool dot_found = false; bool dot_found = false;
bool mount_found = false;
int readdir_errno;
chkdir = opendir(dir); chkdir = opendir(dir);
if (chkdir == NULL) if (chkdir == NULL)
...@@ -51,10 +55,10 @@ pg_check_dir(const char *dir) ...@@ -51,10 +55,10 @@ pg_check_dir(const char *dir)
{ {
dot_found = true; dot_found = true;
} }
/* lost+found directory */
else if (strcmp("lost+found", file->d_name) == 0) else if (strcmp("lost+found", file->d_name) == 0)
{ {
result = 3; /* not empty, mount point */ mount_found = true;
break;
} }
#endif #endif
else else
...@@ -64,9 +68,20 @@ pg_check_dir(const char *dir) ...@@ -64,9 +68,20 @@ pg_check_dir(const char *dir)
} }
} }
if (errno || closedir(chkdir)) if (errno)
result = -1; /* some kind of I/O error? */ result = -1; /* some kind of I/O error? */
/* Close chkdir and avoid overwriting the readdir errno on success */
readdir_errno = errno;
if (closedir(chkdir))
result = -1; /* error executing closedir */
else
errno = readdir_errno;
/* We report on mount point if we find a lost+found directory */
if (result == 1 && mount_found)
result = 3;
/* We report on dot-files if we _only_ find dot files */ /* We report on dot-files if we _only_ find dot files */
if (result == 1 && dot_found) if (result == 1 && dot_found)
result = 2; result = 2;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment