mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2025-01-10 16:20:59 +00:00
Fixed issue: 265
1) Unable to mount to a non empty directory(Issue: 265) Supported "nonempty" fuse option. git-svn-id: http://s3fs.googlecode.com/svn/trunk@410 df820570-a93a-0410-bd06-b72b767a4274
This commit is contained in:
parent
cec9bc5f3a
commit
9641d07806
41
src/s3fs.cpp
41
src/s3fs.cpp
@ -91,6 +91,7 @@ static bool nomultipart = false;
|
|||||||
static bool noxmlns = false;
|
static bool noxmlns = false;
|
||||||
static bool nocopyapi = false;
|
static bool nocopyapi = false;
|
||||||
static bool norenameapi = false;
|
static bool norenameapi = false;
|
||||||
|
static bool nonempty = false;
|
||||||
|
|
||||||
// if .size()==0 then local file cache is disabled
|
// if .size()==0 then local file cache is disabled
|
||||||
static std::string use_cache;
|
static std::string use_cache;
|
||||||
@ -3833,7 +3834,8 @@ static int get_access_keys (void) {
|
|||||||
//
|
//
|
||||||
// if the key is equal to FUSE_OPT_KEY_NONOPT, it's either the bucket name
|
// if the key is equal to FUSE_OPT_KEY_NONOPT, it's either the bucket name
|
||||||
// or the mountpoint. The bucket name will always come before the mountpoint
|
// or the mountpoint. The bucket name will always come before the mountpoint
|
||||||
static int my_fuse_opt_proc(void *data, const char *arg, int key, struct fuse_args *outargs) {
|
static int my_fuse_opt_proc(void *data, const char *arg, int key, struct fuse_args *outargs)
|
||||||
|
{
|
||||||
if(key == FUSE_OPT_KEY_NONOPT) {
|
if(key == FUSE_OPT_KEY_NONOPT) {
|
||||||
// the first NONOPT option is the bucket name
|
// the first NONOPT option is the bucket name
|
||||||
if(bucket.size() == 0) {
|
if(bucket.size() == 0) {
|
||||||
@ -3873,24 +3875,25 @@ static int my_fuse_opt_proc(void *data, const char *arg, int key, struct fuse_ar
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dirent *ent;
|
if(!nonempty){
|
||||||
DIR *dp = opendir(mountpoint.c_str());
|
struct dirent *ent;
|
||||||
if(dp == NULL) {
|
DIR *dp = opendir(mountpoint.c_str());
|
||||||
fprintf(stderr, "%s: failed to open MOUNTPOINT: %s: %s\n",
|
if(dp == NULL) {
|
||||||
program_name.c_str(), mountpoint.c_str(), strerror(errno));
|
fprintf(stderr, "%s: failed to open MOUNTPOINT: %s: %s\n",
|
||||||
return -1;
|
program_name.c_str(), mountpoint.c_str(), strerror(errno));
|
||||||
}
|
|
||||||
|
|
||||||
while((ent = readdir(dp)) != NULL) {
|
|
||||||
if(strcmp(ent->d_name, ".") != 0 && strcmp(ent->d_name, "..") != 0) {
|
|
||||||
closedir(dp);
|
|
||||||
fprintf(stderr, "%s: MOUNTPOINT directory %s is not empty\n",
|
|
||||||
program_name.c_str(), mountpoint.c_str());
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
while((ent = readdir(dp)) != NULL) {
|
||||||
|
if(strcmp(ent->d_name, ".") != 0 && strcmp(ent->d_name, "..") != 0) {
|
||||||
|
closedir(dp);
|
||||||
|
fprintf(stderr, "%s: MOUNTPOINT directory %s is not empty.\n"
|
||||||
|
"%s: if you are sure this is safe, can use the 'nonempty' mount option.\n",
|
||||||
|
program_name.c_str(), mountpoint.c_str(), program_name.c_str());
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
closedir(dp);
|
||||||
}
|
}
|
||||||
|
|
||||||
closedir(dp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key == FUSE_OPT_KEY_OPT) {
|
if (key == FUSE_OPT_KEY_OPT) {
|
||||||
@ -3906,7 +3909,11 @@ static int my_fuse_opt_proc(void *data, const char *arg, int key, struct fuse_ar
|
|||||||
use_cache = strchr(arg, '=') + 1;
|
use_cache = strchr(arg, '=') + 1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
if(strstr(arg, "nonempty") != 0) {
|
||||||
|
nonempty = true;
|
||||||
|
// need to continue for fuse.
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
if(strstr(arg, "nomultipart") != 0) {
|
if(strstr(arg, "nomultipart") != 0) {
|
||||||
nomultipart = true;
|
nomultipart = true;
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user