fixed saving bug in GrpConfigMap

This commit is contained in:
csoler 2016-12-06 23:02:25 +01:00
parent a4c14c2212
commit 68f7fff0d8
2 changed files with 22 additions and 16 deletions

View File

@ -1634,7 +1634,7 @@ uint32_t RsGenExchange::getSyncPeriod(const RsGxsGroupId& grpId)
void RsGenExchange::setSyncPeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs) void RsGenExchange::setSyncPeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs)
{ {
if(mNetService != NULL) if(mNetService != NULL)
return mNetService->setKeepAge(grpId,age_in_secs) ; return mNetService->setSyncAge(grpId,age_in_secs) ;
else else
std::cerr << "(EE) No network service available. Cannot set storage period. " << std::endl; std::cerr << "(EE) No network service available. Cannot set storage period. " << std::endl;
} }

View File

@ -1386,7 +1386,6 @@ bool RsGxsNetService::loadList(std::list<RsItem *> &load)
time_t now = time(NULL); time_t now = time(NULL);
#warning Do we keep that?
for(GrpConfigMap::iterator it(mServerGrpConfigMap.begin());it!=mServerGrpConfigMap.end();++it) for(GrpConfigMap::iterator it(mServerGrpConfigMap.begin());it!=mServerGrpConfigMap.end();++it)
{ {
// At each reload, we reset the count of visible messages. It will be rapidely restored to its real value from friends. // At each reload, we reset the count of visible messages. It will be rapidely restored to its real value from friends.
@ -1441,6 +1440,13 @@ bool RsGxsNetService::saveList(bool& cleanup, std::list<RsItem*>& save)
{ {
RS_STACK_MUTEX(mNxsMutex) ; RS_STACK_MUTEX(mNxsMutex) ;
// First, make sure that all IDs (which are needed twice) are consistent
for(GrpConfigMap::iterator it(mServerGrpConfigMap.begin());it!=mServerGrpConfigMap.end();++it) it->second.grpId = it->first ;
for(ServerMsgMap::iterator it(mServerMsgUpdateMap.begin());it!=mServerMsgUpdateMap.end();++it) it->second.grpId = it->first ;
std::cerr << "RsGxsNetService::saveList()..." << std::endl;
// hardcore templates // hardcore templates
std::transform(mClientGrpUpdateMap.begin(), mClientGrpUpdateMap.end(), std::back_inserter(save), get_second<ClientGrpMap,RsGxsGrpUpdateItem>(mServType)); std::transform(mClientGrpUpdateMap.begin(), mClientGrpUpdateMap.end(), std::back_inserter(save), get_second<ClientGrpMap,RsGxsGrpUpdateItem>(mServType));
std::transform(mClientMsgUpdateMap.begin(), mClientMsgUpdateMap.end(), std::back_inserter(save), get_second<ClientMsgMap,RsGxsMsgUpdateItem>(mServType)); std::transform(mClientMsgUpdateMap.begin(), mClientMsgUpdateMap.end(), std::back_inserter(save), get_second<ClientMsgMap,RsGxsMsgUpdateItem>(mServType));