mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2025-01-06 23:13:56 +00:00
change the way to get existing fdentity
This commit is contained in:
parent
b83c2852b8
commit
d47ad2a057
@ -630,13 +630,28 @@ FdEntity* FdManager::GetExistFdEntity(const char* path, int existfd)
|
|||||||
|
|
||||||
UpdateEntityToTempPath();
|
UpdateEntityToTempPath();
|
||||||
|
|
||||||
// search from all entity.
|
// If use_cache is disabled, or the disk space is insufficient when use_cache
|
||||||
for(auto iter = fent.cbegin(); iter != fent.cend(); ++iter){
|
// is enabled, the corresponding key of the entity in fent is not path.
|
||||||
|
fdent_map_t::iterator iter = fent.find(std::string(path));
|
||||||
|
if(fent.end() != iter){
|
||||||
if(iter->second && iter->second->FindPseudoFd(existfd)){
|
if(iter->second && iter->second->FindPseudoFd(existfd)){
|
||||||
// found existfd in entity
|
return iter->second;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// no matter it's use_cache or not, we search from all entities to
|
||||||
|
// find entity with the same path. Then we compare the pseudo fd.
|
||||||
|
for(iter = fent.cbegin(); iter != fent.cend(); ++iter){
|
||||||
|
// IsOpen() is protected by fd_manager_lock, and so is GetPath().
|
||||||
|
// Therefore there is no need to hold entity lock here (FindPseudoFd
|
||||||
|
// holds it inside).
|
||||||
|
if(iter->second && iter->second->IsOpen() &&
|
||||||
|
0 == strcmp(iter->second->GetPath(), path) &&
|
||||||
|
iter->second->FindPseudoFd(existfd)){
|
||||||
return iter->second.get();
|
return iter->second.get();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// not found entity
|
// not found entity
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user