|
@ -490,19 +490,20 @@ namespace fs |
|
|
|
|
|
|
|
|
namespace find |
|
|
namespace find |
|
|
{ |
|
|
{ |
|
|
void |
|
|
|
|
|
|
|
|
int |
|
|
invalid(const vector<string> &basepaths, |
|
|
invalid(const vector<string> &basepaths, |
|
|
const string fusepath, |
|
|
const string fusepath, |
|
|
PathVector &paths) |
|
|
PathVector &paths) |
|
|
{ |
|
|
{ |
|
|
return; |
|
|
|
|
|
|
|
|
return (errno = EINVAL,-1); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void |
|
|
|
|
|
|
|
|
int |
|
|
ff(const vector<string> &basepaths, |
|
|
ff(const vector<string> &basepaths, |
|
|
const string fusepath, |
|
|
const string fusepath, |
|
|
PathVector &paths) |
|
|
PathVector &paths) |
|
|
{ |
|
|
{ |
|
|
|
|
|
errno = ENOENT; |
|
|
for(vector<string>::const_iterator |
|
|
for(vector<string>::const_iterator |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter != eiter; |
|
|
iter != eiter; |
|
@ -515,22 +516,20 @@ namespace fs |
|
|
path = fs::make_path(*iter,fusepath); |
|
|
path = fs::make_path(*iter,fusepath); |
|
|
rv = ::lstat(path.c_str(),&st); |
|
|
rv = ::lstat(path.c_str(),&st); |
|
|
if(rv == 0) |
|
|
if(rv == 0) |
|
|
{ |
|
|
|
|
|
paths.push_back(Path(*iter,path)); |
|
|
|
|
|
return; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
return (paths.push_back(Path(*iter,path)),0); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
|
return -1; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void |
|
|
|
|
|
|
|
|
int |
|
|
ffwp(const vector<string> &basepaths, |
|
|
ffwp(const vector<string> &basepaths, |
|
|
const string fusepath, |
|
|
const string fusepath, |
|
|
PathVector &paths) |
|
|
PathVector &paths) |
|
|
{ |
|
|
{ |
|
|
Path fallback; |
|
|
Path fallback; |
|
|
|
|
|
|
|
|
|
|
|
errno = ENOENT; |
|
|
for(vector<string>::const_iterator |
|
|
for(vector<string>::const_iterator |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter != eiter; |
|
|
iter != eiter; |
|
@ -544,8 +543,7 @@ namespace fs |
|
|
rv = ::lstat(path.c_str(),&st); |
|
|
rv = ::lstat(path.c_str(),&st); |
|
|
if(rv == 0) |
|
|
if(rv == 0) |
|
|
{ |
|
|
{ |
|
|
paths.push_back(Path(*iter,path)); |
|
|
|
|
|
return; |
|
|
|
|
|
|
|
|
return (paths.push_back(Path(*iter,path)),0); |
|
|
} |
|
|
} |
|
|
else if(errno == EACCES) |
|
|
else if(errno == EACCES) |
|
|
{ |
|
|
{ |
|
@ -555,12 +553,12 @@ namespace fs |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if(!fallback.base.empty()) |
|
|
if(!fallback.base.empty()) |
|
|
paths.push_back(fallback); |
|
|
|
|
|
|
|
|
return (paths.push_back(fallback),0); |
|
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
|
return -1; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void |
|
|
|
|
|
|
|
|
int |
|
|
newest(const vector<string> &basepaths, |
|
|
newest(const vector<string> &basepaths, |
|
|
const string fusepath, |
|
|
const string fusepath, |
|
|
PathVector &paths) |
|
|
PathVector &paths) |
|
@ -570,6 +568,7 @@ namespace fs |
|
|
vector<string>::const_iterator niter; |
|
|
vector<string>::const_iterator niter; |
|
|
|
|
|
|
|
|
newest = 0; |
|
|
newest = 0; |
|
|
|
|
|
errno = ENOENT; |
|
|
for(vector<string>::const_iterator |
|
|
for(vector<string>::const_iterator |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter != eiter; |
|
|
iter != eiter; |
|
@ -589,16 +588,17 @@ namespace fs |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if(newest) |
|
|
if(newest) |
|
|
paths.push_back(Path(*niter,npath)); |
|
|
|
|
|
|
|
|
return (paths.push_back(Path(*niter,npath)),0); |
|
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
|
return -1; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void |
|
|
|
|
|
|
|
|
int |
|
|
all(const vector<string> &basepaths, |
|
|
all(const vector<string> &basepaths, |
|
|
const string fusepath, |
|
|
const string fusepath, |
|
|
PathVector &paths) |
|
|
PathVector &paths) |
|
|
{ |
|
|
{ |
|
|
|
|
|
errno = ENOENT; |
|
|
for(vector<string>::const_iterator |
|
|
for(vector<string>::const_iterator |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter != eiter; |
|
|
iter != eiter; |
|
@ -614,18 +614,20 @@ namespace fs |
|
|
paths.push_back(Path(*iter,path)); |
|
|
paths.push_back(Path(*iter,path)); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
|
return paths.empty() ? -1 : 0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void |
|
|
|
|
|
|
|
|
int |
|
|
mfs(const vector<string> &basepaths, |
|
|
mfs(const vector<string> &basepaths, |
|
|
const string fusepath, |
|
|
const string fusepath, |
|
|
PathVector &paths) |
|
|
PathVector &paths) |
|
|
{ |
|
|
{ |
|
|
fsblkcnt_t mfs = 0; |
|
|
|
|
|
|
|
|
fsblkcnt_t mfs; |
|
|
string mfspath; |
|
|
string mfspath; |
|
|
string fullmfspath; |
|
|
string fullmfspath; |
|
|
|
|
|
|
|
|
|
|
|
mfs = 0; |
|
|
|
|
|
errno = ENOENT; |
|
|
for(vector<string>::const_iterator |
|
|
for(vector<string>::const_iterator |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter = basepaths.begin(), eiter = basepaths.end(); |
|
|
iter != eiter; |
|
|
iter != eiter; |
|
@ -649,14 +651,17 @@ namespace fs |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if(mfs == 0) |
|
|
|
|
|
return -1; |
|
|
|
|
|
|
|
|
fullmfspath = fs::make_path(mfspath,fusepath); |
|
|
fullmfspath = fs::make_path(mfspath,fusepath); |
|
|
|
|
|
|
|
|
paths.push_back(Path(mfspath,fullmfspath)); |
|
|
paths.push_back(Path(mfspath,fullmfspath)); |
|
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
|
return 0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void |
|
|
|
|
|
|
|
|
int |
|
|
epmfs(const vector<string> &basepaths, |
|
|
epmfs(const vector<string> &basepaths, |
|
|
const string fusepath, |
|
|
const string fusepath, |
|
|
PathVector &paths) |
|
|
PathVector &paths) |
|
@ -669,6 +674,9 @@ namespace fs |
|
|
vector<string>::const_iterator iter = basepaths.begin(); |
|
|
vector<string>::const_iterator iter = basepaths.begin(); |
|
|
vector<string>::const_iterator eiter = basepaths.end(); |
|
|
vector<string>::const_iterator eiter = basepaths.end(); |
|
|
|
|
|
|
|
|
|
|
|
if(iter == eiter) |
|
|
|
|
|
return (errno = ENOENT,-1); |
|
|
|
|
|
|
|
|
do |
|
|
do |
|
|
{ |
|
|
{ |
|
|
int rv; |
|
|
int rv; |
|
@ -709,10 +717,10 @@ namespace fs |
|
|
|
|
|
|
|
|
paths.push_back(Path(existingmfspath,path)); |
|
|
paths.push_back(Path(existingmfspath,path)); |
|
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
|
return 0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void |
|
|
|
|
|
|
|
|
int |
|
|
rand(const vector<string> &basepaths, |
|
|
rand(const vector<string> &basepaths, |
|
|
const string fusepath, |
|
|
const string fusepath, |
|
|
PathVector &paths) |
|
|
PathVector &paths) |
|
@ -727,6 +735,8 @@ namespace fs |
|
|
fusepath); |
|
|
fusepath); |
|
|
|
|
|
|
|
|
paths.push_back(Path(randombasepath,randomfullpath)); |
|
|
paths.push_back(Path(randombasepath,randomfullpath)); |
|
|
|
|
|
|
|
|
|
|
|
return 0; |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
}; |
|
|
}; |