mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-15 09:27:09 -05:00
fixed update of directory TS, also fixing update of empty dirs at friends
This commit is contained in:
parent
fc5176a652
commit
494d2071c9
@ -47,10 +47,10 @@ public:
|
|||||||
virtual ~FileEntry() {}
|
virtual ~FileEntry() {}
|
||||||
|
|
||||||
// local stuff
|
// local stuff
|
||||||
|
time_t file_modtime;
|
||||||
std::string file_name ;
|
std::string file_name ;
|
||||||
uint64_t file_size ;
|
uint64_t file_size ;
|
||||||
RsFileHash file_hash ;
|
RsFileHash file_hash ;
|
||||||
time_t file_modtime ;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class DirEntry: public FileStorageNode
|
class DirEntry: public FileStorageNode
|
||||||
@ -68,18 +68,21 @@ public:
|
|||||||
std::vector<DirectoryStorage::EntryIndex> subdirs ;
|
std::vector<DirectoryStorage::EntryIndex> subdirs ;
|
||||||
std::vector<DirectoryStorage::EntryIndex> subfiles ;
|
std::vector<DirectoryStorage::EntryIndex> subfiles ;
|
||||||
|
|
||||||
time_t dir_modtime ; // this accounts for deleted files, etc.
|
time_t dir_modtime;
|
||||||
time_t most_recent_time; // recursive most recent modification time, including files and subdirs in the entire hierarchy below.
|
time_t most_recent_time; // recursive most recent modification time, including files and subdirs in the entire hierarchy below.
|
||||||
|
|
||||||
time_t dir_update_time; // last time the information was updated for that directory. Includes subdirs indexes and subfile info.
|
time_t dir_update_time; // last time the information was updated for that directory. Includes subdirs indexes and subfile info.
|
||||||
};
|
};
|
||||||
|
|
||||||
// class stuff
|
// class stuff
|
||||||
InternalFileHierarchyStorage() : mRoot(0)
|
InternalFileHierarchyStorage() : mRoot(0)
|
||||||
{
|
{
|
||||||
mNodes.push_back(new DirEntry("")) ;
|
DirEntry *de = new DirEntry("") ;
|
||||||
mNodes.back()->row=0;
|
|
||||||
mNodes.back()->parent_index=0;
|
de->row=0;
|
||||||
|
de->parent_index=0;
|
||||||
|
de->dir_modtime=0;
|
||||||
|
|
||||||
|
mNodes.push_back(de) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
int parentRow(DirectoryStorage::EntryIndex e)
|
int parentRow(DirectoryStorage::EntryIndex e)
|
||||||
@ -97,14 +100,14 @@ public:
|
|||||||
return e < mNodes.size() && mNodes[e] != NULL ;
|
return e < mNodes.size() && mNodes[e] != NULL ;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool updateSubDirectoryList(const DirectoryStorage::EntryIndex& indx,const std::set<std::string>& subdirs)
|
bool updateSubDirectoryList(const DirectoryStorage::EntryIndex& indx,const std::map<std::string,time_t>& subdirs)
|
||||||
{
|
{
|
||||||
if(!checkIndex(indx,FileStorageNode::TYPE_DIR))
|
if(!checkIndex(indx,FileStorageNode::TYPE_DIR))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
DirEntry& d(*static_cast<DirEntry*>(mNodes[indx])) ;
|
DirEntry& d(*static_cast<DirEntry*>(mNodes[indx])) ;
|
||||||
|
|
||||||
std::set<std::string> should_create(subdirs);
|
std::map<std::string,time_t> should_create(subdirs);
|
||||||
|
|
||||||
for(uint32_t i=0;i<d.subdirs.size();)
|
for(uint32_t i=0;i<d.subdirs.size();)
|
||||||
if(subdirs.find(static_cast<DirEntry*>(mNodes[d.subdirs[i]])->dir_name) == subdirs.end())
|
if(subdirs.find(static_cast<DirEntry*>(mNodes[d.subdirs[i]])->dir_name) == subdirs.end())
|
||||||
@ -122,14 +125,18 @@ public:
|
|||||||
++i;
|
++i;
|
||||||
}
|
}
|
||||||
|
|
||||||
for(std::set<std::string>::const_iterator it(should_create.begin());it!=should_create.end();++it)
|
for(std::map<std::string,time_t>::const_iterator it(should_create.begin());it!=should_create.end();++it)
|
||||||
{
|
{
|
||||||
std::cerr << "[directory storage] adding new subdirectory " << *it << " at index " << mNodes.size() << std::endl;
|
std::cerr << "[directory storage] adding new subdirectory " << it->first << " at index " << mNodes.size() << std::endl;
|
||||||
|
|
||||||
|
DirEntry *de = new DirEntry(it->first) ;
|
||||||
|
|
||||||
|
de->row = mNodes.size();
|
||||||
|
de->parent_index = indx;
|
||||||
|
de->dir_modtime = it->second;
|
||||||
|
|
||||||
d.subdirs.push_back(mNodes.size()) ;
|
d.subdirs.push_back(mNodes.size()) ;
|
||||||
mNodes.push_back(new DirEntry(*it));
|
mNodes.push_back(de) ;
|
||||||
mNodes.back()->row = mNodes.size()-1;
|
|
||||||
mNodes.back()->parent_index = indx;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -664,7 +671,7 @@ bool DirectoryStorage::setDirUpdateTS(EntryIndex index,time_t recurs_max_modf_T
|
|||||||
return mFileHierarchy->setDirUpdateTS(index,recurs_max_modf_TS,local_update_TS) ;
|
return mFileHierarchy->setDirUpdateTS(index,recurs_max_modf_TS,local_update_TS) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DirectoryStorage::updateSubDirectoryList(const EntryIndex& indx,const std::set<std::string>& subdirs)
|
bool DirectoryStorage::updateSubDirectoryList(const EntryIndex& indx,const std::map<std::string,time_t>& subdirs)
|
||||||
{
|
{
|
||||||
RS_STACK_MUTEX(mDirStorageMtx) ;
|
RS_STACK_MUTEX(mDirStorageMtx) ;
|
||||||
bool res = mFileHierarchy->updateSubDirectoryList(indx,subdirs) ;
|
bool res = mFileHierarchy->updateSubDirectoryList(indx,subdirs) ;
|
||||||
@ -1035,6 +1042,10 @@ bool RemoteDirectoryStorage::deserialiseDirEntry(const EntryIndex& indx,const Rs
|
|||||||
if(!FileListIO::readField(section_data,section_size,section_offset,FILE_LIST_IO_TAG_RECURS_MODIF_TS,most_recent_time)) return false ;
|
if(!FileListIO::readField(section_data,section_size,section_offset,FILE_LIST_IO_TAG_RECURS_MODIF_TS,most_recent_time)) return false ;
|
||||||
if(!FileListIO::readField(section_data,section_size,section_offset,FILE_LIST_IO_TAG_MODIF_TS ,dir_modtime )) return false ;
|
if(!FileListIO::readField(section_data,section_size,section_offset,FILE_LIST_IO_TAG_MODIF_TS ,dir_modtime )) return false ;
|
||||||
|
|
||||||
|
std::cerr << " dir name : \"" << dir_name << "\"" << std::endl;
|
||||||
|
std::cerr << " most recent time : " << most_recent_time << std::endl;
|
||||||
|
std::cerr << " modification time : " << dir_modtime << std::endl;
|
||||||
|
|
||||||
// serialise number of subdirs and number of subfiles
|
// serialise number of subdirs and number of subfiles
|
||||||
|
|
||||||
uint32_t n_subdirs,n_subfiles ;
|
uint32_t n_subdirs,n_subfiles ;
|
||||||
@ -1042,6 +1053,9 @@ bool RemoteDirectoryStorage::deserialiseDirEntry(const EntryIndex& indx,const Rs
|
|||||||
if(!FileListIO::readField(section_data,section_size,section_offset,FILE_LIST_IO_TAG_RAW_NUMBER,n_subdirs )) return false ;
|
if(!FileListIO::readField(section_data,section_size,section_offset,FILE_LIST_IO_TAG_RAW_NUMBER,n_subdirs )) return false ;
|
||||||
if(!FileListIO::readField(section_data,section_size,section_offset,FILE_LIST_IO_TAG_RAW_NUMBER,n_subfiles )) return false ;
|
if(!FileListIO::readField(section_data,section_size,section_offset,FILE_LIST_IO_TAG_RAW_NUMBER,n_subfiles )) return false ;
|
||||||
|
|
||||||
|
std::cerr << " number of subdirs : " << n_subdirs << std::endl;
|
||||||
|
std::cerr << " number of files : " << n_subfiles << std::endl;
|
||||||
|
|
||||||
// serialise subdirs entry indexes
|
// serialise subdirs entry indexes
|
||||||
|
|
||||||
std::vector<EntryIndex> subdirs_array ;
|
std::vector<EntryIndex> subdirs_array ;
|
||||||
@ -1095,6 +1109,8 @@ bool RemoteDirectoryStorage::deserialiseDirEntry(const EntryIndex& indx,const Rs
|
|||||||
|
|
||||||
RS_STACK_MUTEX(mDirStorageMtx) ;
|
RS_STACK_MUTEX(mDirStorageMtx) ;
|
||||||
|
|
||||||
|
std::cerr << " updating dir entry..." << std::endl;
|
||||||
|
|
||||||
// first create the entries for each subdir and each subfile.
|
// first create the entries for each subdir and each subfile.
|
||||||
if(!mFileHierarchy->updateDirEntry(indx,dir_name,most_recent_time,dir_modtime,subdirs_array,subfiles_array))
|
if(!mFileHierarchy->updateDirEntry(indx,dir_name,most_recent_time,dir_modtime,subdirs_array,subfiles_array))
|
||||||
{
|
{
|
||||||
@ -1104,8 +1120,12 @@ bool RemoteDirectoryStorage::deserialiseDirEntry(const EntryIndex& indx,const Rs
|
|||||||
|
|
||||||
// then update the subfiles
|
// then update the subfiles
|
||||||
for(uint32_t i=0;i<subfiles_array.size();++i)
|
for(uint32_t i=0;i<subfiles_array.size();++i)
|
||||||
|
{
|
||||||
|
std::cerr << " updating file entry " << subfiles_hash[i] << std::endl;
|
||||||
|
|
||||||
if(!mFileHierarchy->updateFile(subfiles_array[i],subfiles_hash[i],subfiles_name[i],subfiles_size[i],subfiles_modtime[i]))
|
if(!mFileHierarchy->updateFile(subfiles_array[i],subfiles_hash[i],subfiles_name[i],subfiles_size[i],subfiles_modtime[i]))
|
||||||
std::cerr << "(EE) Cannot update file with index " << subfiles_array[i] << ". This is very weird. Entry should have just been created and therefore should exist. Skipping." << std::endl;
|
std::cerr << "(EE) Cannot update file with index " << subfiles_array[i] << ". This is very weird. Entry should have just been created and therefore should exist. Skipping." << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
|
@ -94,7 +94,7 @@ class DirectoryStorage
|
|||||||
const RsPeerId& peerId() const { return mPeerId ; }
|
const RsPeerId& peerId() const { return mPeerId ; }
|
||||||
int parentRow(EntryIndex e) const ;
|
int parentRow(EntryIndex e) const ;
|
||||||
|
|
||||||
bool updateSubDirectoryList(const EntryIndex& indx,const std::set<std::string>& subdirs) ;
|
bool updateSubDirectoryList(const EntryIndex& indx, const std::map<std::__cxx11::string, time_t> &subdirs) ;
|
||||||
bool updateSubFilesList(const EntryIndex& indx, const std::map<std::string, FileTS> &subfiles, std::map<std::string, FileTS> &new_files) ;
|
bool updateSubFilesList(const EntryIndex& indx, const std::map<std::string, FileTS> &subfiles, std::map<std::string, FileTS> &new_files) ;
|
||||||
bool removeDirectory(const EntryIndex& indx) ;
|
bool removeDirectory(const EntryIndex& indx) ;
|
||||||
|
|
||||||
|
@ -59,10 +59,10 @@ void LocalDirectoryUpdater::sweepSharedDirectories()
|
|||||||
std::list<SharedDirInfo> shared_directory_list ;
|
std::list<SharedDirInfo> shared_directory_list ;
|
||||||
mSharedDirectories->getSharedDirectoryList(shared_directory_list);
|
mSharedDirectories->getSharedDirectoryList(shared_directory_list);
|
||||||
|
|
||||||
std::set<std::string> sub_dir_list ;
|
std::map<std::string,time_t> sub_dir_list ;
|
||||||
|
|
||||||
for(std::list<SharedDirInfo>::const_iterator real_dir_it(shared_directory_list.begin());real_dir_it!=shared_directory_list.end();++real_dir_it)
|
for(std::list<SharedDirInfo>::const_iterator real_dir_it(shared_directory_list.begin());real_dir_it!=shared_directory_list.end();++real_dir_it)
|
||||||
sub_dir_list.insert( (*real_dir_it).filename ) ;
|
sub_dir_list[(*real_dir_it).filename] = 0 ;
|
||||||
|
|
||||||
// make sure that entries in stored_dir_it are the same than paths in real_dir_it, and in the same order.
|
// make sure that entries in stored_dir_it are the same than paths in real_dir_it, and in the same order.
|
||||||
|
|
||||||
@ -93,7 +93,7 @@ void LocalDirectoryUpdater::recursUpdateSharedDir(const std::string& cumulated_p
|
|||||||
// collect subdirs and subfiles
|
// collect subdirs and subfiles
|
||||||
|
|
||||||
std::map<std::string,DirectoryStorage::FileTS> subfiles ;
|
std::map<std::string,DirectoryStorage::FileTS> subfiles ;
|
||||||
std::set<std::string> subdirs ;
|
std::map<std::string,time_t> subdirs ;
|
||||||
|
|
||||||
for(;dirIt.isValid();dirIt.next())
|
for(;dirIt.isValid();dirIt.next())
|
||||||
{
|
{
|
||||||
@ -104,7 +104,7 @@ void LocalDirectoryUpdater::recursUpdateSharedDir(const std::string& cumulated_p
|
|||||||
std::cerr << " adding sub-file \"" << dirIt.file_name() << "\"" << std::endl;
|
std::cerr << " adding sub-file \"" << dirIt.file_name() << "\"" << std::endl;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case librs::util::FolderIterator::TYPE_DIR: subdirs.insert(dirIt.file_name()) ;
|
case librs::util::FolderIterator::TYPE_DIR: subdirs[dirIt.file_name()] = dirIt.file_modtime();
|
||||||
std::cerr << " adding sub-dir \"" << dirIt.file_name() << "\"" << std::endl;
|
std::cerr << " adding sub-dir \"" << dirIt.file_name() << "\"" << std::endl;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -134,7 +134,7 @@ void LocalDirectoryUpdater::recursUpdateSharedDir(const std::string& cumulated_p
|
|||||||
|
|
||||||
DirectoryStorage::DirIterator stored_dir_it(mSharedDirectories,indx) ;
|
DirectoryStorage::DirIterator stored_dir_it(mSharedDirectories,indx) ;
|
||||||
|
|
||||||
for(std::set<std::string>::const_iterator real_dir_it(subdirs.begin());real_dir_it!=subdirs.end();++real_dir_it, ++stored_dir_it)
|
for(std::map<std::string,time_t>::const_iterator real_dir_it(subdirs.begin());real_dir_it!=subdirs.end();++real_dir_it, ++stored_dir_it)
|
||||||
{
|
{
|
||||||
std::cerr << " recursing into " << stored_dir_it.name() << std::endl;
|
std::cerr << " recursing into " << stored_dir_it.name() << std::endl;
|
||||||
recursUpdateSharedDir(cumulated_path + "/" + stored_dir_it.name(), *stored_dir_it) ;
|
recursUpdateSharedDir(cumulated_path + "/" + stored_dir_it.name(), *stored_dir_it) ;
|
||||||
|
@ -834,15 +834,10 @@ void p3FileDatabase::handleDirSyncResponse(RsFileListsSyncResponseItem *item)
|
|||||||
}
|
}
|
||||||
else if(item->flags & RsFileListsItem::FLAGS_SYNC_DIR_CONTENT)
|
else if(item->flags & RsFileListsItem::FLAGS_SYNC_DIR_CONTENT)
|
||||||
{
|
{
|
||||||
P3FILELISTS_DEBUG() << " Item contains directory data. Updating." << std::endl;
|
P3FILELISTS_DEBUG() << " Item contains directory data. Deserialising/Updating." << std::endl;
|
||||||
|
|
||||||
if(mRemoteDirectories[fi]->deserialiseDirEntry(item->entry_index,item->directory_content_data))
|
if(mRemoteDirectories[fi]->deserialiseDirEntry(item->entry_index,item->directory_content_data))
|
||||||
{
|
RsServer::notify()->notifyListChange(NOTIFY_LIST_DIRLIST_FRIENDS, 0); // notify the GUI if the hierarchy has changed
|
||||||
mRemoteDirectories[fi]->setDirUpdateTS(item->entry_index,item->last_known_recurs_modf_TS,time(NULL));
|
|
||||||
|
|
||||||
// notify the GUI if the hierarchy has changed
|
|
||||||
RsServer::notify()->notifyListChange(NOTIFY_LIST_DIRLIST_FRIENDS, 0);
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
std::cerr << "(EE) Cannot deserialise dir entry. ERROR. "<< std::endl;
|
std::cerr << "(EE) Cannot deserialise dir entry. ERROR. "<< std::endl;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user