From 377eb50c6e97b5d2b70d375dec8fc8f7d15fa248 Mon Sep 17 00:00:00 2001 From: csoler Date: Sat, 6 Jun 2015 14:01:08 +0000 Subject: [PATCH] fixed bug in previous commit for chat lobbies git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@8386 b45a01b8-16f6-495d-af2f-9b41ad6348cc --- libretroshare/src/chat/distributedchat.cc | 46 +++++++++++------------ libretroshare/src/pqi/p3peermgr.h | 2 - 2 files changed, 23 insertions(+), 25 deletions(-) diff --git a/libretroshare/src/chat/distributedchat.cc b/libretroshare/src/chat/distributedchat.cc index d008f9c83..620886ec8 100644 --- a/libretroshare/src/chat/distributedchat.cc +++ b/libretroshare/src/chat/distributedchat.cc @@ -1622,14 +1622,14 @@ bool DistributedChatService::getIdentityForChatLobby(const ChatLobbyId& lobby_id bool DistributedChatService::setIdentityForChatLobby(const ChatLobbyId& lobby_id,const RsGxsId& nick) { if (nick.isNull()) - { + { std::cerr << "(EE) Ignore empty nickname for chat lobby " << nick << std::endl; - return false; - } + return false; + } - // first check for change and send status peer changed nick name - bool changed = false; - std::map::iterator it; + // first check for change and send status peer changed nick name + bool changed = false; + std::map::iterator it; { RsStackMutex stack(mDistributedChatMtx); /********** STACK LOCKED MTX ******/ @@ -1646,36 +1646,36 @@ bool DistributedChatService::setIdentityForChatLobby(const ChatLobbyId& lobby_id } if (!it->second.gxs_id.isNull() && it->second.gxs_id != nick) + changed = true; + } + + if (changed) + { + // Inform other peers of change the Nickname { RsIdentityDetails det1,det2 ; // Only send a nickname change event if the two Identities are not anonymous if(rsIdentity->getIdDetails(nick,det1) && rsIdentity->getIdDetails(it->second.gxs_id,det2) && det1.mPgpLinked && det2.mPgpLinked) - changed = true; + sendLobbyStatusPeerChangedNickname(lobby_id, nick.toStdString()) ; } - } - if (changed) - { - // Inform other peers of change the Nickname - sendLobbyStatusPeerChangedNickname(lobby_id, nick.toStdString()) ; + // set new nick name + RsStackMutex stack(mDistributedChatMtx); /********** STACK LOCKED MTX ******/ - // set new nick name - RsStackMutex stack(mDistributedChatMtx); /********** STACK LOCKED MTX ******/ + it = _chat_lobbys.find(lobby_id) ; - it = _chat_lobbys.find(lobby_id) ; - - if(it == _chat_lobbys.end()) - { - std::cerr << " (EE) lobby does not exist!!" << std::endl; - return false; - } + if(it == _chat_lobbys.end()) + { + std::cerr << " (EE) lobby does not exist!!" << std::endl; + return false; + } it->second.gxs_id = nick ; - } + } - return true ; + return true ; } void DistributedChatService::setLobbyAutoSubscribe(const ChatLobbyId& lobby_id, const bool autoSubscribe) diff --git a/libretroshare/src/pqi/p3peermgr.h b/libretroshare/src/pqi/p3peermgr.h index ce23d628c..2af81855a 100644 --- a/libretroshare/src/pqi/p3peermgr.h +++ b/libretroshare/src/pqi/p3peermgr.h @@ -372,8 +372,6 @@ private: struct sockaddr_storage mProxyServerAddress; uint32_t mProxyServerStatus ; - //std::map > mReportedConnectionIps ; - }; #endif // MRK_PQI_PEER_MANAGER_HEADER