diff options
Diffstat (limited to 'indra/newview/llavatariconctrl.cpp')
-rw-r--r-- | indra/newview/llavatariconctrl.cpp | 436 |
1 files changed, 218 insertions, 218 deletions
diff --git a/indra/newview/llavatariconctrl.cpp b/indra/newview/llavatariconctrl.cpp index 44bf698caa..07e544a1ca 100644 --- a/indra/newview/llavatariconctrl.cpp +++ b/indra/newview/llavatariconctrl.cpp @@ -1,25 +1,25 @@ -/** +/** * @file llavatariconctrl.cpp * @brief LLAvatarIconCtrl class implementation * * $LicenseInfo:firstyear=2009&license=viewerlgpl$ * Second Life Viewer Source Code * Copyright (C) 2010, Linden Research, Inc. - * + * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License only. - * + * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. - * + * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - * + * * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA * $/LicenseInfo$ */ @@ -51,137 +51,137 @@ static LLDefaultChildRegistry::Register<LLAvatarIconCtrl> r("avatar_icon"); namespace LLInitParam { - void TypeValues<LLAvatarIconCtrlEnums::ESymbolPos>::declareValues() - { - declare("BottomLeft", LLAvatarIconCtrlEnums::BOTTOM_LEFT); - declare("BottomRight", LLAvatarIconCtrlEnums::BOTTOM_RIGHT); - declare("TopLeft", LLAvatarIconCtrlEnums::TOP_LEFT); - declare("TopRight", LLAvatarIconCtrlEnums::TOP_RIGHT); - } + void TypeValues<LLAvatarIconCtrlEnums::ESymbolPos>::declareValues() + { + declare("BottomLeft", LLAvatarIconCtrlEnums::BOTTOM_LEFT); + declare("BottomRight", LLAvatarIconCtrlEnums::BOTTOM_RIGHT); + declare("TopLeft", LLAvatarIconCtrlEnums::TOP_LEFT); + declare("TopRight", LLAvatarIconCtrlEnums::TOP_RIGHT); + } } bool LLAvatarIconIDCache::LLAvatarIconIDCacheItem::expired() { - const F64 SEC_PER_DAY_PLUS_HOUR = (24.0 + 1.0) * 60.0 * 60.0; - F64 delta = LLDate::now().secondsSinceEpoch() - cached_time.secondsSinceEpoch(); - if (delta > SEC_PER_DAY_PLUS_HOUR) - return true; - return false; + const F64 SEC_PER_DAY_PLUS_HOUR = (24.0 + 1.0) * 60.0 * 60.0; + F64 delta = LLDate::now().secondsSinceEpoch() - cached_time.secondsSinceEpoch(); + if (delta > SEC_PER_DAY_PLUS_HOUR) + return true; + return false; } -void LLAvatarIconIDCache::load () +void LLAvatarIconIDCache::load () { - LL_INFOS() << "Loading avatar icon id cache." << LL_ENDL; - - // build filename for each user - std::string resolved_filename = gDirUtilp->getExpandedFilename(LL_PATH_CACHE, mFilename); - llifstream file(resolved_filename.c_str()); - - if (!file.is_open()) - return; - - // add each line in the file to the list - int uuid_len = UUID_STR_LENGTH-1; - std::string line; - while (std::getline(file, line)) - { - LLUUID avatar_id; - LLUUID icon_id; - LLDate date; - - if (line.length()<=uuid_len*2) - continue; // short line, bail out to prevent substr calls throwing exception. - - std::string avatar_id_str = line.substr(0,uuid_len); - std::string icon_id_str = line.substr(uuid_len,uuid_len); - - std::string date_str = line.substr(uuid_len*2, line.length()-uuid_len*2); - - if(!avatar_id.set(avatar_id_str) || !icon_id.set(icon_id_str) || !date.fromString(date_str)) - continue; - - LLAvatarIconIDCacheItem item = {icon_id,date}; - mCache[avatar_id] = item; - } - - file.close(); - + LL_INFOS() << "Loading avatar icon id cache." << LL_ENDL; + + // build filename for each user + std::string resolved_filename = gDirUtilp->getExpandedFilename(LL_PATH_CACHE, mFilename); + llifstream file(resolved_filename.c_str()); + + if (!file.is_open()) + return; + + // add each line in the file to the list + int uuid_len = UUID_STR_LENGTH-1; + std::string line; + while (std::getline(file, line)) + { + LLUUID avatar_id; + LLUUID icon_id; + LLDate date; + + if (line.length()<=uuid_len*2) + continue; // short line, bail out to prevent substr calls throwing exception. + + std::string avatar_id_str = line.substr(0,uuid_len); + std::string icon_id_str = line.substr(uuid_len,uuid_len); + + std::string date_str = line.substr(uuid_len*2, line.length()-uuid_len*2); + + if(!avatar_id.set(avatar_id_str) || !icon_id.set(icon_id_str) || !date.fromString(date_str)) + continue; + + LLAvatarIconIDCacheItem item = {icon_id,date}; + mCache[avatar_id] = item; + } + + file.close(); + } -void LLAvatarIconIDCache::save () +void LLAvatarIconIDCache::save () { - std::string resolved_filename = gDirUtilp->getExpandedFilename(LL_PATH_CACHE, mFilename); - - // open a file for writing - llofstream file (resolved_filename.c_str()); - if (!file.is_open()) - { - LL_WARNS() << "can't open avatar icons cache file\"" << mFilename << "\" for writing" << LL_ENDL; - return; - } - - for(std::map<LLUUID,LLAvatarIconIDCacheItem>::iterator it = mCache.begin();it!=mCache.end();++it) - { - if(!it->second.expired()) - { - file << it->first << it->second.icon_id << it->second.cached_time << std::endl; - } - } - - file.close(); + std::string resolved_filename = gDirUtilp->getExpandedFilename(LL_PATH_CACHE, mFilename); + + // open a file for writing + llofstream file (resolved_filename.c_str()); + if (!file.is_open()) + { + LL_WARNS() << "can't open avatar icons cache file\"" << mFilename << "\" for writing" << LL_ENDL; + return; + } + + for(std::map<LLUUID,LLAvatarIconIDCacheItem>::iterator it = mCache.begin();it!=mCache.end();++it) + { + if(!it->second.expired()) + { + file << it->first << it->second.icon_id << it->second.cached_time << std::endl; + } + } + + file.close(); } -LLUUID* LLAvatarIconIDCache::get (const LLUUID& avatar_id) +LLUUID* LLAvatarIconIDCache::get (const LLUUID& avatar_id) { - std::map<LLUUID,LLAvatarIconIDCacheItem>::iterator it = mCache.find(avatar_id); - if(it==mCache.end()) - return 0; - if(it->second.expired()) - return 0; - return &it->second.icon_id; + std::map<LLUUID,LLAvatarIconIDCacheItem>::iterator it = mCache.find(avatar_id); + if(it==mCache.end()) + return 0; + if(it->second.expired()) + return 0; + return &it->second.icon_id; } -void LLAvatarIconIDCache::add (const LLUUID& avatar_id,const LLUUID& icon_id) +void LLAvatarIconIDCache::add (const LLUUID& avatar_id,const LLUUID& icon_id) { - LLAvatarIconIDCacheItem item = {icon_id,LLDate::now()}; - mCache[avatar_id] = item; + LLAvatarIconIDCacheItem item = {icon_id,LLDate::now()}; + mCache[avatar_id] = item; } -void LLAvatarIconIDCache::remove (const LLUUID& avatar_id) +void LLAvatarIconIDCache::remove (const LLUUID& avatar_id) { - mCache.erase(avatar_id); + mCache.erase(avatar_id); } LLAvatarIconCtrl::Params::Params() -: avatar_id("avatar_id"), - draw_tooltip("draw_tooltip", true), - default_icon_name("default_icon_name"), - symbol_hpad("symbol_hpad"), - symbol_vpad("symbol_vpad"), - symbol_size("symbol_size", 1), - symbol_pos("symbol_pos", LLAvatarIconCtrlEnums::BOTTOM_RIGHT) +: avatar_id("avatar_id"), + draw_tooltip("draw_tooltip", true), + default_icon_name("default_icon_name"), + symbol_hpad("symbol_hpad"), + symbol_vpad("symbol_vpad"), + symbol_size("symbol_size", 1), + symbol_pos("symbol_pos", LLAvatarIconCtrlEnums::BOTTOM_RIGHT) { - changeDefault(min_width, 32); - changeDefault(min_height, 32); + changeDefault(min_width, 32); + changeDefault(min_height, 32); } LLAvatarIconCtrl::LLAvatarIconCtrl(const LLAvatarIconCtrl::Params& p) -: LLIconCtrl(p), - LLAvatarPropertiesObserver(), - mAvatarId(), - mFullName(), - mDrawTooltip(p.draw_tooltip), - mDefaultIconName(p.default_icon_name), - mAvatarNameCacheConnection(), - mSymbolHpad(p.symbol_hpad), - mSymbolVpad(p.symbol_vpad), - mSymbolSize(p.symbol_size), - mSymbolPos(p.symbol_pos) +: LLIconCtrl(p), + LLAvatarPropertiesObserver(), + mAvatarId(), + mFullName(), + mDrawTooltip(p.draw_tooltip), + mDefaultIconName(p.default_icon_name), + mAvatarNameCacheConnection(), + mSymbolHpad(p.symbol_hpad), + mSymbolVpad(p.symbol_vpad), + mSymbolSize(p.symbol_size), + mSymbolPos(p.symbol_pos) { - mPriority = LLViewerFetchedTexture::BOOST_ICON; + mPriority = LLViewerFetchedTexture::BOOST_ICON; // don't request larger image then necessary to save gl memory, // but ensure that quality is sufficient @@ -189,149 +189,149 @@ LLAvatarIconCtrl::LLAvatarIconCtrl(const LLAvatarIconCtrl::Params& p) mMaxHeight = llmax((S32)p.min_height, rect.getHeight()); mMaxWidth = llmax((S32)p.min_width, rect.getWidth()); - if (p.avatar_id.isProvided()) - { - LLSD value(p.avatar_id); - setValue(value); - } - else - { - LLIconCtrl::setValue(mDefaultIconName, LLViewerFetchedTexture::BOOST_UI); - } + if (p.avatar_id.isProvided()) + { + LLSD value(p.avatar_id); + setValue(value); + } + else + { + LLIconCtrl::setValue(mDefaultIconName, LLViewerFetchedTexture::BOOST_UI); + } } LLAvatarIconCtrl::~LLAvatarIconCtrl() { - if (mAvatarId.notNull()) - { - LLAvatarPropertiesProcessor::getInstance()->removeObserver(mAvatarId, this); - // Name callbacks will be automatically disconnected since LLUICtrl is trackable - } - - if (mAvatarNameCacheConnection.connected()) - { - mAvatarNameCacheConnection.disconnect(); - } + if (mAvatarId.notNull()) + { + LLAvatarPropertiesProcessor::getInstance()->removeObserver(mAvatarId, this); + // Name callbacks will be automatically disconnected since LLUICtrl is trackable + } + + if (mAvatarNameCacheConnection.connected()) + { + mAvatarNameCacheConnection.disconnect(); + } } //virtual void LLAvatarIconCtrl::setValue(const LLSD& value) { - if (value.isUUID()) - { - LLAvatarPropertiesProcessor* app = - LLAvatarPropertiesProcessor::getInstance(); - if (mAvatarId.notNull()) - { - app->removeObserver(mAvatarId, this); - } - - if (mAvatarId != value.asUUID()) - { - mAvatarId = value.asUUID(); - - // *BUG: This will return stale icons if a user changes their - // profile picture. However, otherwise we send too many upstream - // AvatarPropertiesRequest messages. - - // to get fresh avatar icon use - // LLAvatarIconIDCache::getInstance()->remove(avatar_id); - - // Check if cache already contains image_id for that avatar - if (!updateFromCache()) - { - // *TODO: Consider getting avatar icon/badge directly from - // People API, rather than sending AvatarPropertyRequest - // messages. People API already hits the user table. - LLIconCtrl::setValue(mDefaultIconName, LLViewerFetchedTexture::BOOST_UI); - app->addObserver(mAvatarId, this); - app->sendAvatarPropertiesRequest(mAvatarId); - } + if (value.isUUID()) + { + LLAvatarPropertiesProcessor* app = + LLAvatarPropertiesProcessor::getInstance(); + if (mAvatarId.notNull()) + { + app->removeObserver(mAvatarId, this); + } + + if (mAvatarId != value.asUUID()) + { + mAvatarId = value.asUUID(); + + // *BUG: This will return stale icons if a user changes their + // profile picture. However, otherwise we send too many upstream + // AvatarPropertiesRequest messages. + + // to get fresh avatar icon use + // LLAvatarIconIDCache::getInstance()->remove(avatar_id); + + // Check if cache already contains image_id for that avatar + if (!updateFromCache()) + { + // *TODO: Consider getting avatar icon/badge directly from + // People API, rather than sending AvatarPropertyRequest + // messages. People API already hits the user table. + LLIconCtrl::setValue(mDefaultIconName, LLViewerFetchedTexture::BOOST_UI); + app->addObserver(mAvatarId, this); + app->sendAvatarPropertiesRequest(mAvatarId); + } else if (gAgentID == mAvatarId) { // Always track any changes to our own icon id app->addObserver(mAvatarId, this); } - } - } - else - { - LLIconCtrl::setValue(value); - } - - fetchAvatarName(); + } + } + else + { + LLIconCtrl::setValue(value); + } + + fetchAvatarName(); } void LLAvatarIconCtrl::fetchAvatarName() { - if (mAvatarId.notNull()) - { - if (mAvatarNameCacheConnection.connected()) - { - mAvatarNameCacheConnection.disconnect(); - } - mAvatarNameCacheConnection = LLAvatarNameCache::get(mAvatarId, boost::bind(&LLAvatarIconCtrl::onAvatarNameCache, this, _1, _2)); - } + if (mAvatarId.notNull()) + { + if (mAvatarNameCacheConnection.connected()) + { + mAvatarNameCacheConnection.disconnect(); + } + mAvatarNameCacheConnection = LLAvatarNameCache::get(mAvatarId, boost::bind(&LLAvatarIconCtrl::onAvatarNameCache, this, _1, _2)); + } } bool LLAvatarIconCtrl::updateFromCache() { - LLUUID* icon_id_ptr = LLAvatarIconIDCache::getInstance()->get(mAvatarId); - if(!icon_id_ptr) - return false; - - const LLUUID& icon_id = *icon_id_ptr; - - // Update the avatar - if (icon_id.notNull()) - { - LLIconCtrl::setValue(icon_id); - } - else - { - LLIconCtrl::setValue(mDefaultIconName, LLViewerFetchedTexture::BOOST_UI); + LLUUID* icon_id_ptr = LLAvatarIconIDCache::getInstance()->get(mAvatarId); + if(!icon_id_ptr) return false; - } - return true; + const LLUUID& icon_id = *icon_id_ptr; + + // Update the avatar + if (icon_id.notNull()) + { + LLIconCtrl::setValue(icon_id); + } + else + { + LLIconCtrl::setValue(mDefaultIconName, LLViewerFetchedTexture::BOOST_UI); + return false; + } + + return true; } //virtual void LLAvatarIconCtrl::processProperties(void* data, EAvatarProcessorType type) { - if (APT_PROPERTIES == type) - { - LLAvatarData* avatar_data = static_cast<LLAvatarData*>(data); - if (avatar_data) - { - if (avatar_data->avatar_id != mAvatarId) - { - return; - } - - LLAvatarIconIDCache::getInstance()->add(mAvatarId,avatar_data->image_id); - updateFromCache(); - } - } + if (APT_PROPERTIES == type) + { + LLAvatarData* avatar_data = static_cast<LLAvatarData*>(data); + if (avatar_data) + { + if (avatar_data->avatar_id != mAvatarId) + { + return; + } + + LLAvatarIconIDCache::getInstance()->add(mAvatarId,avatar_data->image_id); + updateFromCache(); + } + } } void LLAvatarIconCtrl::onAvatarNameCache(const LLUUID& agent_id, const LLAvatarName& av_name) { - mAvatarNameCacheConnection.disconnect(); - - if (agent_id == mAvatarId) - { - // Most avatar icon controls are next to a UI element that shows - // a display name, so only show username. - mFullName = av_name.getUserName(); - - if (mDrawTooltip) - { - setToolTip(mFullName); - } - else - { - setToolTip(std::string()); - } - } + mAvatarNameCacheConnection.disconnect(); + + if (agent_id == mAvatarId) + { + // Most avatar icon controls are next to a UI element that shows + // a display name, so only show username. + mFullName = av_name.getUserName(); + + if (mDrawTooltip) + { + setToolTip(mFullName); + } + else + { + setToolTip(std::string()); + } + } } |