Fixed issue 240 and some bugs.

1) Cannot Mount Path in Bucket(Issue 240)
    Changes man page for this issue("bucket[:path]" -> "bucket[:/path]").
    And so s3fs did not work with mount path, fixed it.

2) Fixes other bug about renaming directory
    Fixes a bug caused by r420, which fails to rename directory. 




git-svn-id: http://s3fs.googlecode.com/svn/trunk@421 df820570-a93a-0410-bd06-b72b767a4274
This commit is contained in:
ggtakec@gmail.com 2013-05-09 04:25:18 +00:00
parent 6b78bfdf4b
commit c862ee40ea
2 changed files with 11 additions and 3 deletions

View File

@ -4,7 +4,7 @@ S3FS \- FUSE-based file system backed by Amazon S3
.SH SYNOPSIS .SH SYNOPSIS
.SS mounting .SS mounting
.TP .TP
\fBs3fs bucket[:path] mountpoint \fP [options] \fBs3fs bucket[:/path] mountpoint \fP [options]
.SS unmounting .SS unmounting
.TP .TP
\fBumount mountpoint \fBumount mountpoint

View File

@ -1986,6 +1986,7 @@ static int rename_object(const char *from, const char *to) {
return result; return result;
} }
result = s3fs_unlink(from); result = s3fs_unlink(from);
StatCache::getStatCacheData()->DelStat(to);
return result; return result;
} }
@ -2104,8 +2105,10 @@ static int rename_large_object(const char *from, const char *to) {
} }
result = complete_multipart_upload(to, upload_id, parts); result = complete_multipart_upload(to, upload_id, parts);
if(result != 0) StatCache::getStatCacheData()->DelStat(to);
if(result != 0){
return -EIO; return -EIO;
}
return s3fs_unlink(from); return s3fs_unlink(from);
} }
@ -2132,6 +2135,7 @@ static int clone_directory_object(const char *from, const char *to)
uid = get_uid(meta["x-amz-meta-uid"].c_str()); uid = get_uid(meta["x-amz-meta-uid"].c_str());
gid = get_gid(meta["x-amz-meta-gid"].c_str()); gid = get_gid(meta["x-amz-meta-gid"].c_str());
result = create_directory_object(to, mode, time, uid, gid); result = create_directory_object(to, mode, time, uid, gid);
StatCache::getStatCacheData()->DelStat(to);
return result; return result;
} }
@ -3378,7 +3382,7 @@ static int remote_mountpath_exists(const char *path) {
FGPRINT("remote_mountpath_exists [path=%s]\n", path); FGPRINT("remote_mountpath_exists [path=%s]\n", path);
// getattr will prefix the path with the remote mountpoint // getattr will prefix the path with the remote mountpoint
if(0 != get_object_attribute("", &stbuf, NULL)){ if(0 != get_object_attribute("/", &stbuf, NULL)){
return -1; return -1;
} }
if(!S_ISDIR(stbuf.st_mode)){ if(!S_ISDIR(stbuf.st_mode)){
@ -4038,6 +4042,10 @@ static int my_fuse_opt_proc(void *data, const char *arg, int key, struct fuse_ar
bucket = strtok(bucket_name, ":"); bucket = strtok(bucket_name, ":");
char* pmount_prefix = strtok(NULL, ":"); char* pmount_prefix = strtok(NULL, ":");
if(pmount_prefix){ if(pmount_prefix){
if(0 == strlen(pmount_prefix) || '/' != pmount_prefix[0]){
fprintf(stderr, "%s: path(%s) must be prefix \"/\".\n", program_name.c_str(), pmount_prefix);
return -1;
}
mount_prefix = pmount_prefix; mount_prefix = pmount_prefix;
// remove trailing slash // remove trailing slash
if(mount_prefix.at(mount_prefix.size() - 1) == '/'){ if(mount_prefix.at(mount_prefix.size() - 1) == '/'){