diff options
Diffstat (limited to 'Swiften/Avatars/CombinedAvatarProvider.cpp')
| -rw-r--r-- | Swiften/Avatars/CombinedAvatarProvider.cpp | 16 | 
1 files changed, 10 insertions, 6 deletions
| diff --git a/Swiften/Avatars/CombinedAvatarProvider.cpp b/Swiften/Avatars/CombinedAvatarProvider.cpp index d283664..1bd74dd 100644 --- a/Swiften/Avatars/CombinedAvatarProvider.cpp +++ b/Swiften/Avatars/CombinedAvatarProvider.cpp @@ -7,19 +7,19 @@  #include <Swiften/Avatars/CombinedAvatarProvider.h>  #include <algorithm>  #include <boost/bind.hpp>  #include <Swiften/Base/Log.h>  namespace Swift { -std::string CombinedAvatarProvider::getAvatarHash(const JID& jid) const { +boost::optional<std::string> CombinedAvatarProvider::getAvatarHash(const JID& jid) const {  	return getCombinedAvatarAndCache(jid);  }  void CombinedAvatarProvider::addProvider(AvatarProvider* provider) {  	provider->onAvatarChanged.connect(boost::bind(&CombinedAvatarProvider::handleAvatarChanged, this, _1));  	providers.push_back(provider);  }  void CombinedAvatarProvider::removeProvider(AvatarProvider* provider) { @@ -30,28 +30,32 @@ void CombinedAvatarProvider::removeProvider(AvatarProvider* provider) {  	providers.erase(i, providers.end());  }  void CombinedAvatarProvider::handleAvatarChanged(const JID& jid) {  	std::string oldHash;  	std::map<JID, std::string>::const_iterator i = avatars.find(jid);  	if (i != avatars.end()) {  		oldHash = i->second;  	} -	std::string newHash = getCombinedAvatarAndCache(jid); +	boost::optional<std::string> newHash = getCombinedAvatarAndCache(jid);  	if (newHash != oldHash) {  		SWIFT_LOG(debug) << "Avatar changed: " << jid << ": " << oldHash << " -> " << newHash << std::endl;  		onAvatarChanged(jid);  	}  } -std::string CombinedAvatarProvider::getCombinedAvatarAndCache(const JID& jid) const { +boost::optional<std::string> CombinedAvatarProvider::getCombinedAvatarAndCache(const JID& jid) const {  	SWIFT_LOG(debug) << "JID: " << jid << std::endl; -	std::string hash; -	for (size_t i = 0; i < providers.size() && hash.empty(); ++i) { +	boost::optional<std::string> hash; +	for (size_t i = 0; i < providers.size() && !hash; ++i) {  		hash = providers[i]->getAvatarHash(jid);  		SWIFT_LOG(debug) << "Provider " << providers[i] << ": " << hash << std::endl;  	} -	avatars[jid] = hash; +	if (hash) { +		avatars[jid] = *hash; +	} else { +		avatars[jid] = ""; +	}  	return hash;  }  } | 
 Swift
 Swift