Put similar processing together into method GetCacheFileStatTopDir

This commit is contained in:
Takeshi Nakatani 2020-07-12 07:49:51 +00:00
parent e72a64785b
commit 700e288718
2 changed files with 27 additions and 17 deletions

View File

@ -65,13 +65,28 @@ static const int MAX_MULTIPART_CNT = 10 * 1000; // S3 multipart max count
//------------------------------------------------ //------------------------------------------------
// CacheFileStat class methods // CacheFileStat class methods
//------------------------------------------------ //------------------------------------------------
bool CacheFileStat::MakeCacheFileStatPath(const char* path, string& sfile_path, bool is_create_dir) string CacheFileStat::GetCacheFileStatTopDir()
{ {
// make stat dir top path( "/<cache_dir>/.<bucket_name>.stat" ) string top_path("");
string top_path = FdManager::GetCacheDir(); if(!FdManager::IsCacheDir() || bucket.empty()){
return top_path;
}
// stat top dir( "/<cache_dir>/.<bucket_name>.stat" )
top_path += FdManager::GetCacheDir();
top_path += "/."; top_path += "/.";
top_path += bucket; top_path += bucket;
top_path += ".stat"; top_path += ".stat";
return top_path;
}
bool CacheFileStat::MakeCacheFileStatPath(const char* path, string& sfile_path, bool is_create_dir)
{
string top_path = CacheFileStat::GetCacheFileStatTopDir();
if(top_path.empty()){
S3FS_PRN_ERR("The path to cache top dir is empty.");
return false;
}
if(is_create_dir){ if(is_create_dir){
int result; int result;
@ -90,14 +105,11 @@ bool CacheFileStat::MakeCacheFileStatPath(const char* path, string& sfile_path,
bool CacheFileStat::CheckCacheFileStatTopDir() bool CacheFileStat::CheckCacheFileStatTopDir()
{ {
if(!FdManager::IsCacheDir()){ string top_path = CacheFileStat::GetCacheFileStatTopDir();
if(top_path.empty()){
S3FS_PRN_INFO("The path to cache top dir is empty, thus not need to check permission.");
return true; return true;
} }
// make stat dir top path( "/<cache_dir>/.<bucket_name>.stat" )
string top_path = FdManager::GetCacheDir();
top_path += "/.";
top_path += bucket;
top_path += ".stat";
return check_exist_dir_permission(top_path.c_str()); return check_exist_dir_permission(top_path.c_str());
} }
@ -130,14 +142,11 @@ bool CacheFileStat::DeleteCacheFileStat(const char* path)
// //
bool CacheFileStat::DeleteCacheFileStatDirectory() bool CacheFileStat::DeleteCacheFileStatDirectory()
{ {
string top_path = FdManager::GetCacheDir(); string top_path = CacheFileStat::GetCacheFileStatTopDir();
if(top_path.empty()){
if(top_path.empty() || bucket.empty()){ S3FS_PRN_INFO("The path to cache top dir is empty, thus not need to remove it.");
return true; return true;
} }
top_path += "/.";
top_path += bucket;
top_path += ".stat";
return delete_files_in_dir(top_path.c_str(), true); return delete_files_in_dir(top_path.c_str(), true);
} }

View File

@ -35,6 +35,7 @@ class CacheFileStat
static bool MakeCacheFileStatPath(const char* path, std::string& sfile_path, bool is_create_dir = true); static bool MakeCacheFileStatPath(const char* path, std::string& sfile_path, bool is_create_dir = true);
public: public:
static std::string GetCacheFileStatTopDir(void);
static bool DeleteCacheFileStat(const char* path); static bool DeleteCacheFileStat(const char* path);
static bool CheckCacheFileStatTopDir(void); static bool CheckCacheFileStatTopDir(void);
static bool DeleteCacheFileStatDirectory(void); static bool DeleteCacheFileStatDirectory(void);