summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2005-03-16 00:04:59 +0000
committerNick Mathewson <nickm@torproject.org>2005-03-16 00:04:59 +0000
commitbe38e0a490c4e22759bb59b49b058b56de8838a4 (patch)
tree934b83d857fe6fdd3ac227567bb5cfd3206b26d5 /src/common
parent5faea839ee804369e85b43c2edf503ff05a3b117 (diff)
downloadtor-be38e0a490c4e22759bb59b49b058b56de8838a4.tar.gz
tor-be38e0a490c4e22759bb59b49b058b56de8838a4.zip
Fix a fun windows bug: apparently windows stat wants paths not to end with slash.
svn:r3766
Diffstat (limited to 'src/common')
-rw-r--r--src/common/util.c41
1 files changed, 37 insertions, 4 deletions
diff --git a/src/common/util.c b/src/common/util.c
index 50e81603de..7ff0869c58 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -741,13 +741,37 @@ int read_all(int fd, char *buf, size_t count, int isSocket) {
* Filesystem operations.
*/
+/** Clean up <b>name</b> so that we can use it in a call to "stat". On Unix,
+ * we do nothing. On Windows, we remove a trailing slash, unless the path is
+ * the root of a disk. */
+static void
+clean_name_for_stat(char *name)
+{
+#ifdef MS_WINDOWS
+ size_t len = strlen(name);
+ if (!len)
+ return;
+ if (name[len-1]=='\\' || name[len-1]=='/') {
+ if (len == 1 || (len==3 && name[1]==':'))
+ return;
+ name[len-1]='\0';
+ }
+#endif
+}
+
/** Return FN_ERROR if filename can't be read, FN_NOENT if it doesn't
* exist, FN_FILE if it is a regular file, or FN_DIR if it's a
* directory. */
file_status_t file_status(const char *fname)
{
struct stat st;
- if (stat(fname, &st)) {
+ char *f;
+ int r;
+ f = tor_strdup(fname);
+ clean_name_for_stat(f);
+ r = stat(f, &st);
+ tor_free(f);
+ if (r) {
if (errno == ENOENT) {
return FN_NOENT;
}
@@ -770,8 +794,13 @@ int check_private_dir(const char *dirname, cpd_check_t check)
{
int r;
struct stat st;
+ char *f;
tor_assert(dirname);
- if (stat(dirname, &st)) {
+ f = tor_strdup(dirname);
+ clean_name_for_stat(f);
+ r = stat(f, &st);
+ tor_free(f);
+ if (r) {
if (errno != ENOENT) {
log(LOG_WARN, "Directory %s cannot be read: %s", dirname,
strerror(errno));
@@ -893,12 +922,16 @@ int write_bytes_to_file(const char *fname, const char *str, size_t len,
char *read_file_to_str(const char *filename, int bin) {
int fd; /* router file */
struct stat statbuf;
- char *string;
+ char *string, *f;
int r;
tor_assert(filename);
- if (stat(filename, &statbuf) < 0) {
+ f = tor_strdup(filename);
+ clean_name_for_stat(f);
+ r = stat(f, &statbuf);
+ tor_free(f);
+ if (r < 0) {
log_fn(LOG_INFO,"Could not stat %s.",filename);
return NULL;
}