merge changes for 5.0.4-release
commit
1b032c3783
1
.hgtags
1
.hgtags
|
|
@ -525,3 +525,4 @@ b41e1e7c7876f7656c505f552b5888b4e478f92b 5.0.0-release
|
|||
c9ce2295012995e3cf5c57bcffcb4870b94c649f 5.0.1-release
|
||||
cea1632c002c065985ebea15eeeb4aac90f50545 5.0.2-release
|
||||
02c24e9f4f7d8aa0de75f27817dda098582f4936 5.0.3-release
|
||||
022709ef76a331cac1ba6ef1a6da8a5e9ef63f5a 5.0.4-release
|
||||
|
|
|
|||
|
|
@ -755,6 +755,28 @@ void LLAvatarNameCache::insert(const LLUUID& agent_id, const LLAvatarName& av_na
|
|||
sCache[agent_id] = av_name;
|
||||
}
|
||||
|
||||
LLUUID LLAvatarNameCache::findIdByName(const std::string& name)
|
||||
{
|
||||
std::map<LLUUID, LLAvatarName>::iterator it;
|
||||
std::map<LLUUID, LLAvatarName>::iterator end = sCache.end();
|
||||
for (it = sCache.begin(); it != end; ++it)
|
||||
{
|
||||
if (it->second.getUserName() == name)
|
||||
{
|
||||
return it->first;
|
||||
}
|
||||
}
|
||||
|
||||
// Legacy method
|
||||
LLUUID id;
|
||||
if (gCacheName->getUUID(name, id))
|
||||
{
|
||||
return id;
|
||||
}
|
||||
|
||||
return LLUUID::null;
|
||||
}
|
||||
|
||||
#if 0
|
||||
F64 LLAvatarNameCache::nameExpirationFromHeaders(LLCore::HttpHeaders *headers)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -84,7 +84,15 @@ namespace LLAvatarNameCache
|
|||
void insert(const LLUUID& agent_id, const LLAvatarName& av_name);
|
||||
void erase(const LLUUID& agent_id);
|
||||
|
||||
/// Provide some fallback for agents that return errors.
|
||||
// A way to find agent id by UUID, very slow, also unreliable
|
||||
// since it doesn't request names, just serch exsisting ones
|
||||
// that are likely not in cache.
|
||||
//
|
||||
// Todo: Find a way to remove this.
|
||||
// Curently this method is used for chat history and in some cases notices.
|
||||
LLUUID findIdByName(const std::string& name);
|
||||
|
||||
/// Provide some fallback for agents that return errors.
|
||||
void handleAgentError(const LLUUID& agent_id);
|
||||
|
||||
// Compute name expiration time from HTTP Cache-Control header,
|
||||
|
|
|
|||
|
|
@ -540,18 +540,34 @@ void LLExperienceCache::fetchAssociatedExperience(const LLUUID& objectId, const
|
|||
}
|
||||
|
||||
LLCoprocedureManager::instance().enqueueCoprocedure("ExpCache", "Fetch Associated",
|
||||
boost::bind(&LLExperienceCache::fetchAssociatedExperienceCoro, this, _1, objectId, itemId, fn));
|
||||
boost::bind(&LLExperienceCache::fetchAssociatedExperienceCoro, this, _1, objectId, itemId, std::string(), fn));
|
||||
}
|
||||
|
||||
void LLExperienceCache::fetchAssociatedExperienceCoro(LLCoreHttpUtil::HttpCoroutineAdapter::ptr_t &httpAdapter, LLUUID objectId, LLUUID itemId, ExperienceGetFn_t fn)
|
||||
void LLExperienceCache::fetchAssociatedExperience(const LLUUID& objectId, const LLUUID& itemId, std::string url, ExperienceGetFn_t fn)
|
||||
{
|
||||
if (mCapability.empty())
|
||||
{
|
||||
LL_WARNS("ExperienceCache") << "Capability query method not set." << LL_ENDL;
|
||||
return;
|
||||
}
|
||||
|
||||
LLCoprocedureManager::instance().enqueueCoprocedure("ExpCache", "Fetch Associated",
|
||||
boost::bind(&LLExperienceCache::fetchAssociatedExperienceCoro, this, _1, objectId, itemId, url, fn));
|
||||
}
|
||||
|
||||
void LLExperienceCache::fetchAssociatedExperienceCoro(LLCoreHttpUtil::HttpCoroutineAdapter::ptr_t &httpAdapter, LLUUID objectId, LLUUID itemId, std::string url, ExperienceGetFn_t fn)
|
||||
{
|
||||
LLCore::HttpRequest::ptr_t httpRequest(new LLCore::HttpRequest());
|
||||
std::string url = mCapability("GetMetadata");
|
||||
|
||||
if (url.empty())
|
||||
{
|
||||
LL_WARNS("ExperienceCache") << "No Metadata capability." << LL_ENDL;
|
||||
return;
|
||||
url = mCapability("GetMetadata");
|
||||
|
||||
if (url.empty())
|
||||
{
|
||||
LL_WARNS("ExperienceCache") << "No Metadata capability." << LL_ENDL;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
LLSD fields;
|
||||
|
|
|
|||
|
|
@ -64,6 +64,7 @@ public:
|
|||
|
||||
//-------------------------------------------
|
||||
void fetchAssociatedExperience(const LLUUID& objectId, const LLUUID& itemId, ExperienceGetFn_t fn);
|
||||
void fetchAssociatedExperience(const LLUUID& objectId, const LLUUID& itemId, std::string url, ExperienceGetFn_t fn);
|
||||
void findExperienceByName(const std::string text, int page, ExperienceGetFn_t fn);
|
||||
void getGroupExperiences(const LLUUID &groupId, ExperienceGetFn_t fn);
|
||||
|
||||
|
|
@ -148,7 +149,7 @@ private:
|
|||
void requestExperiencesCoro(LLCoreHttpUtil::HttpCoroutineAdapter::ptr_t &, std::string, RequestQueue_t);
|
||||
void requestExperiences();
|
||||
|
||||
void fetchAssociatedExperienceCoro(LLCoreHttpUtil::HttpCoroutineAdapter::ptr_t &, LLUUID, LLUUID, ExperienceGetFn_t);
|
||||
void fetchAssociatedExperienceCoro(LLCoreHttpUtil::HttpCoroutineAdapter::ptr_t &, LLUUID, LLUUID, std::string, ExperienceGetFn_t);
|
||||
void findExperienceByNameCoro(LLCoreHttpUtil::HttpCoroutineAdapter::ptr_t &, std::string, int, ExperienceGetFn_t);
|
||||
void getGroupExperiencesCoro(LLCoreHttpUtil::HttpCoroutineAdapter::ptr_t &, LLUUID , ExperienceGetFn_t);
|
||||
void regionExperiencesCoro(LLCoreHttpUtil::HttpCoroutineAdapter::ptr_t &httpAdapter, CapabilityQuery_t regioncaps, bool update, LLSD experiences, ExperienceGetFn_t fn);
|
||||
|
|
|
|||
|
|
@ -618,6 +618,7 @@ char const* const _PREHASH_GroupAccountSummaryRequest = LLMessageStringTable::ge
|
|||
char const* const _PREHASH_GroupVoteHistoryRequest = LLMessageStringTable::getInstance()->getString("GroupVoteHistoryRequest");
|
||||
char const* const _PREHASH_ParamValue = LLMessageStringTable::getInstance()->getString("ParamValue");
|
||||
char const* const _PREHASH_MaxAgents = LLMessageStringTable::getInstance()->getString("MaxAgents");
|
||||
char const* const _PREHASH_HardMaxAgents = LLMessageStringTable::getInstance()->getString("HardMaxAgents");
|
||||
char const* const _PREHASH_CreateNewOutfitAttachments = LLMessageStringTable::getInstance()->getString("CreateNewOutfitAttachments");
|
||||
char const* const _PREHASH_RegionHandle = LLMessageStringTable::getInstance()->getString("RegionHandle");
|
||||
char const* const _PREHASH_TeleportProgress = LLMessageStringTable::getInstance()->getString("TeleportProgress");
|
||||
|
|
|
|||
|
|
@ -618,6 +618,7 @@ extern char const* const _PREHASH_GroupAccountSummaryRequest;
|
|||
extern char const* const _PREHASH_GroupVoteHistoryRequest;
|
||||
extern char const* const _PREHASH_ParamValue;
|
||||
extern char const* const _PREHASH_MaxAgents;
|
||||
extern char const* const _PREHASH_HardMaxAgents;
|
||||
extern char const* const _PREHASH_CreateNewOutfitAttachments;
|
||||
extern char const* const _PREHASH_RegionHandle;
|
||||
extern char const* const _PREHASH_TeleportProgress;
|
||||
|
|
|
|||
|
|
@ -172,7 +172,7 @@ LLPrimitive::~LLPrimitive()
|
|||
{
|
||||
clearTextureList();
|
||||
// Cleanup handled by volume manager
|
||||
if (mVolumep)
|
||||
if (mVolumep && sVolumeManager)
|
||||
{
|
||||
sVolumeManager->unrefVolume(mVolumep);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -58,9 +58,6 @@ public:
|
|||
|
||||
virtual void deselect() {};
|
||||
virtual BOOL canDeselect() const { return FALSE; }
|
||||
|
||||
virtual void duplicate() {};
|
||||
virtual BOOL canDuplicate() const { return FALSE; }
|
||||
|
||||
// TODO: Instead of being a public data member, it would be better to hide it altogether
|
||||
// and have a "set" method and then a bunch of static versions of the cut, copy, paste
|
||||
|
|
|
|||
|
|
@ -3342,6 +3342,12 @@ BOOL LLMenuBarGL::handleAcceleratorKey(KEY key, MASK mask)
|
|||
return TRUE;
|
||||
}
|
||||
|
||||
if (result && !getHighlightedItem() && LLMenuGL::sMenuContainer->hasVisibleMenu())
|
||||
{
|
||||
// close menus originating from other menu bars
|
||||
LLMenuGL::sMenuContainer->hideMenus();
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -1808,6 +1808,7 @@ BOOL LLScrollListCtrl::handleRightMouseDown(S32 x, S32 y, MASK mask)
|
|||
registrar.add("Url.ShowProfile", boost::bind(&LLScrollListCtrl::showProfile, id, is_group));
|
||||
registrar.add("Url.SendIM", boost::bind(&LLScrollListCtrl::sendIM, id));
|
||||
registrar.add("Url.AddFriend", boost::bind(&LLScrollListCtrl::addFriend, id));
|
||||
registrar.add("Url.RemoveFriend", boost::bind(&LLScrollListCtrl::removeFriend, id));
|
||||
registrar.add("Url.Execute", boost::bind(&LLScrollListCtrl::showNameDetails, id, is_group));
|
||||
registrar.add("Url.CopyLabel", boost::bind(&LLScrollListCtrl::copyNameToClipboard, id, is_group));
|
||||
registrar.add("Url.CopyUrl", boost::bind(&LLScrollListCtrl::copySLURLToClipboard, id, is_group));
|
||||
|
|
@ -1852,6 +1853,12 @@ void LLScrollListCtrl::addFriend(std::string id)
|
|||
LLUrlAction::addFriend(slurl);
|
||||
}
|
||||
|
||||
void LLScrollListCtrl::removeFriend(std::string id)
|
||||
{
|
||||
std::string slurl = "secondlife:///app/agent/" + id + "/about";
|
||||
LLUrlAction::removeFriend(slurl);
|
||||
}
|
||||
|
||||
void LLScrollListCtrl::showNameDetails(std::string id, bool is_group)
|
||||
{
|
||||
// open the resident's details or the group details
|
||||
|
|
|
|||
|
|
@ -432,6 +432,7 @@ private:
|
|||
static void showProfile(std::string id, bool is_group);
|
||||
static void sendIM(std::string id);
|
||||
static void addFriend(std::string id);
|
||||
static void removeFriend(std::string id);
|
||||
static void showNameDetails(std::string id, bool is_group);
|
||||
static void copyNameToClipboard(std::string id, bool is_group);
|
||||
static void copySLURLToClipboard(std::string id, bool is_group);
|
||||
|
|
|
|||
|
|
@ -1522,7 +1522,7 @@ void LLTextBase::reflow()
|
|||
}
|
||||
|
||||
S32 line_height = 0;
|
||||
S32 seg_line_offset = line_count;
|
||||
S32 seg_line_offset = line_count + 1;
|
||||
|
||||
while(seg_iter != mSegments.end())
|
||||
{
|
||||
|
|
|
|||
|
|
@ -1459,6 +1459,10 @@ void LLTextEditor::pasteHelper(bool is_primary)
|
|||
// Clean up string (replace tabs and remove characters that our fonts don't support).
|
||||
void LLTextEditor::cleanStringForPaste(LLWString & clean_string)
|
||||
{
|
||||
std::string clean_string_utf = wstring_to_utf8str(clean_string);
|
||||
std::replace( clean_string_utf.begin(), clean_string_utf.end(), '\r', '\n');
|
||||
clean_string = utf8str_to_wstring(clean_string_utf);
|
||||
|
||||
LLWStringUtil::replaceTabsWithSpaces(clean_string, SPACES_PER_TAB);
|
||||
if( mAllowEmbeddedItems )
|
||||
{
|
||||
|
|
|
|||
|
|
@ -204,6 +204,7 @@ set(viewer_SOURCE_FILES
|
|||
llfloaterautoreplacesettings.cpp
|
||||
llfloateravatar.cpp
|
||||
llfloateravatarpicker.cpp
|
||||
llfloateravatarrendersettings.cpp
|
||||
llfloateravatartextures.cpp
|
||||
llfloaterbeacons.cpp
|
||||
llfloaterbigpreview.cpp
|
||||
|
|
@ -237,6 +238,7 @@ set(viewer_SOURCE_FILES
|
|||
llfloatergesture.cpp
|
||||
llfloatergodtools.cpp
|
||||
llfloatergotoline.cpp
|
||||
llfloatergridstatus.cpp
|
||||
llfloatergroupbulkban.cpp
|
||||
llfloatergroupinvite.cpp
|
||||
llfloatergroups.cpp
|
||||
|
|
@ -820,6 +822,7 @@ set(viewer_HEADER_FILES
|
|||
llfloaterautoreplacesettings.h
|
||||
llfloateravatar.h
|
||||
llfloateravatarpicker.h
|
||||
llfloateravatarrendersettings.h
|
||||
llfloateravatartextures.h
|
||||
llfloaterbeacons.h
|
||||
llfloaterbigpreview.h
|
||||
|
|
@ -853,6 +856,7 @@ set(viewer_HEADER_FILES
|
|||
llfloatergesture.h
|
||||
llfloatergodtools.h
|
||||
llfloatergotoline.h
|
||||
llfloatergridstatus.h
|
||||
llfloatergroupbulkban.h
|
||||
llfloatergroupinvite.h
|
||||
llfloatergroups.h
|
||||
|
|
|
|||
|
|
@ -1 +1 @@
|
|||
5.0.4
|
||||
5.0.5
|
||||
|
|
|
|||
|
|
@ -292,4 +292,15 @@
|
|||
is_running_function="Floater.IsOpen"
|
||||
is_running_parameters="reporter"
|
||||
/>
|
||||
<command name="gridstatus"
|
||||
available_in_toybox="true"
|
||||
is_flashing_allowed="true"
|
||||
icon="Command_Grid_Status_Icon"
|
||||
label_ref="Command_Grid_Status_Label"
|
||||
tooltip_ref="Command_Grid_Status_Tooltip"
|
||||
execute_function="Floater.ToggleOrBringToFront"
|
||||
execute_parameters="grid_status"
|
||||
is_running_function="Floater.IsOpen"
|
||||
is_running_parameters="grid_status"
|
||||
/>
|
||||
</commands>
|
||||
|
|
|
|||
|
|
@ -5163,6 +5163,39 @@
|
|||
<key>Value</key>
|
||||
<string>http://wiki.secondlife.com/wiki/[LSL_STRING]</string>
|
||||
</map>
|
||||
<key>GridStatusRSS</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
<string>URL that points to SL Grid Status RSS</string>
|
||||
<key>Persist</key>
|
||||
<integer>1</integer>
|
||||
<key>Type</key>
|
||||
<string>String</string>
|
||||
<key>Value</key>
|
||||
<string>https://secondlife-status.statuspage.io/history.atom</string>
|
||||
</map>
|
||||
<key>GridStatusUpdateDelay</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
<string>Timer delay for updating Grid Status RSS.</string>
|
||||
<key>Persist</key>
|
||||
<integer>1</integer>
|
||||
<key>Type</key>
|
||||
<string>F32</string>
|
||||
<key>Value</key>
|
||||
<real>60.0</real>
|
||||
</map>
|
||||
<key>TestGridStatusRSSFromFile</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
<string>For testing only: Don't update rss xml file from server.</string>
|
||||
<key>Persist</key>
|
||||
<integer>1</integer>
|
||||
<key>Type</key>
|
||||
<string>Boolean</string>
|
||||
<key>Value</key>
|
||||
<integer>0</integer>
|
||||
</map>
|
||||
<key>LagMeterShrunk</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
|
|
@ -8393,6 +8426,17 @@
|
|||
<key>Value</key>
|
||||
<integer>1</integer>
|
||||
</map>
|
||||
<key>AlwaysRenderFriends</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
<string>Always render friends regardless of max complexity</string>
|
||||
<key>Persist</key>
|
||||
<integer>1</integer>
|
||||
<key>Type</key>
|
||||
<string>Boolean</string>
|
||||
<key>Value</key>
|
||||
<integer>0</integer>
|
||||
</map>
|
||||
<key>RenderAvatar</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
|
|
@ -15125,6 +15169,22 @@
|
|||
<integer>0</integer>
|
||||
</array>
|
||||
</map>
|
||||
<key>GridStatusFloaterRect</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
<string>Web profile floater dimensions</string>
|
||||
<key>Persist</key>
|
||||
<integer>1</integer>
|
||||
<key>Type</key>
|
||||
<string>Rect</string>
|
||||
<key>Value</key>
|
||||
<array>
|
||||
<integer>0</integer>
|
||||
<integer>520</integer>
|
||||
<integer>625</integer>
|
||||
<integer>0</integer>
|
||||
</array>
|
||||
</map>
|
||||
<key>HelpFloaterOpen</key>
|
||||
<map>
|
||||
<key>Comment</key>
|
||||
|
|
|
|||
|
|
@ -1537,6 +1537,14 @@ LLVector3d LLAgentCamera::calcFocusPositionTargetGlobal()
|
|||
}
|
||||
else if (mCameraMode == CAMERA_MODE_CUSTOMIZE_AVATAR)
|
||||
{
|
||||
if (mFocusOnAvatar)
|
||||
{
|
||||
LLVector3 focus_target = isAgentAvatarValid()
|
||||
? gAgentAvatarp->mHeadp->getWorldPosition()
|
||||
: gAgent.getPositionAgent();
|
||||
LLVector3d focus_target_global = gAgent.getPosGlobalFromAgent(focus_target);
|
||||
mFocusTargetGlobal = focus_target_global;
|
||||
}
|
||||
return mFocusTargetGlobal;
|
||||
}
|
||||
else if (!mFocusOnAvatar)
|
||||
|
|
|
|||
|
|
@ -3313,7 +3313,12 @@ LLSD LLAppViewer::getViewerInfo() const
|
|||
std::string url = LLTrans::getString("RELEASE_NOTES_BASE_URL");
|
||||
if (! LLStringUtil::endsWith(url, "/"))
|
||||
url += "/";
|
||||
url += LLURI::escape(LLVersionInfo::getChannel()) + "/";
|
||||
std::string channel = LLVersionInfo::getChannel();
|
||||
if (LLStringUtil::endsWith(boost::to_lower_copy(channel), " edu")) // Release Notes url shouldn't include the EDU parameter
|
||||
{
|
||||
boost::erase_tail(channel, 4);
|
||||
}
|
||||
url += LLURI::escape(channel) + "/";
|
||||
url += LLURI::escape(LLVersionInfo::getVersion());
|
||||
|
||||
info["VIEWER_RELEASE_NOTES_URL"] = url;
|
||||
|
|
@ -5588,6 +5593,8 @@ void LLAppViewer::forceErrorBreakpoint()
|
|||
LL_WARNS() << "Forcing a deliberate breakpoint" << LL_ENDL;
|
||||
#ifdef LL_WINDOWS
|
||||
DebugBreak();
|
||||
#else
|
||||
asm ("int $3");
|
||||
#endif
|
||||
return;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -478,15 +478,14 @@ void LLAvatarActions::kick(const LLUUID& id)
|
|||
// static
|
||||
void LLAvatarActions::freezeAvatar(const LLUUID& id)
|
||||
{
|
||||
std::string fullname;
|
||||
gCacheName->getFullName(id, fullname);
|
||||
LLAvatarName av_name;
|
||||
LLSD payload;
|
||||
payload["avatar_id"] = id;
|
||||
|
||||
if (!fullname.empty())
|
||||
if (LLAvatarNameCache::get(id, &av_name))
|
||||
{
|
||||
LLSD args;
|
||||
args["AVATAR_NAME"] = fullname;
|
||||
args["AVATAR_NAME"] = av_name.getUserName();
|
||||
LLNotificationsUtil::add("FreezeAvatarFullname", args, payload, handleFreezeAvatar);
|
||||
}
|
||||
else
|
||||
|
|
@ -498,15 +497,15 @@ void LLAvatarActions::freezeAvatar(const LLUUID& id)
|
|||
// static
|
||||
void LLAvatarActions::ejectAvatar(const LLUUID& id, bool ban_enabled)
|
||||
{
|
||||
std::string fullname;
|
||||
gCacheName->getFullName(id, fullname);
|
||||
LLAvatarName av_name;
|
||||
LLSD payload;
|
||||
payload["avatar_id"] = id;
|
||||
payload["ban_enabled"] = ban_enabled;
|
||||
LLSD args;
|
||||
if (!fullname.empty())
|
||||
bool has_name = LLAvatarNameCache::get(id, &av_name);
|
||||
if (has_name)
|
||||
{
|
||||
args["AVATAR_NAME"] = fullname;
|
||||
args["AVATAR_NAME"] = av_name.getUserName();
|
||||
}
|
||||
|
||||
if (ban_enabled)
|
||||
|
|
@ -515,7 +514,7 @@ void LLAvatarActions::ejectAvatar(const LLUUID& id, bool ban_enabled)
|
|||
}
|
||||
else
|
||||
{
|
||||
if (!fullname.empty())
|
||||
if (has_name)
|
||||
{
|
||||
LLNotificationsUtil::add("EjectAvatarFullnameNoBan", args, payload, handleEjectAvatar);
|
||||
}
|
||||
|
|
@ -991,10 +990,10 @@ bool LLAvatarActions::canShareSelectedItems(LLInventoryPanel* inv_panel /* = NUL
|
|||
// static
|
||||
void LLAvatarActions::toggleBlock(const LLUUID& id)
|
||||
{
|
||||
std::string name;
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(id, &av_name);
|
||||
|
||||
gCacheName->getFullName(id, name); // needed for mute
|
||||
LLMute mute(id, name, LLMute::AGENT);
|
||||
LLMute mute(id, av_name.getUserName(), LLMute::AGENT);
|
||||
|
||||
if (LLMuteList::getInstance()->isMuted(mute.mID, mute.mName))
|
||||
{
|
||||
|
|
@ -1009,13 +1008,13 @@ void LLAvatarActions::toggleBlock(const LLUUID& id)
|
|||
// static
|
||||
void LLAvatarActions::toggleMuteVoice(const LLUUID& id)
|
||||
{
|
||||
std::string name;
|
||||
gCacheName->getFullName(id, name); // needed for mute
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(id, &av_name);
|
||||
|
||||
LLMuteList* mute_list = LLMuteList::getInstance();
|
||||
bool is_muted = mute_list->isMuted(id, LLMute::flagVoiceChat);
|
||||
|
||||
LLMute mute(id, name, LLMute::AGENT);
|
||||
LLMute mute(id, av_name.getUserName(), LLMute::AGENT);
|
||||
if (!is_muted)
|
||||
{
|
||||
mute_list->add(mute, LLMute::flagVoiceChat);
|
||||
|
|
@ -1329,9 +1328,9 @@ bool LLAvatarActions::isFriend(const LLUUID& id)
|
|||
// static
|
||||
bool LLAvatarActions::isBlocked(const LLUUID& id)
|
||||
{
|
||||
std::string name;
|
||||
gCacheName->getFullName(id, name); // needed for mute
|
||||
return LLMuteList::getInstance()->isMuted(id, name);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(id, &av_name);
|
||||
return LLMuteList::getInstance()->isMuted(id, av_name.getUserName());
|
||||
}
|
||||
|
||||
// static
|
||||
|
|
@ -1343,8 +1342,10 @@ bool LLAvatarActions::isVoiceMuted(const LLUUID& id)
|
|||
// static
|
||||
bool LLAvatarActions::canBlock(const LLUUID& id)
|
||||
{
|
||||
std::string full_name;
|
||||
gCacheName->getFullName(id, full_name); // needed for mute
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(id, &av_name);
|
||||
|
||||
std::string full_name = av_name.getUserName();
|
||||
bool is_linden = (full_name.find("Linden") != std::string::npos);
|
||||
bool is_self = id == gAgentID;
|
||||
return !is_self && !is_linden;
|
||||
|
|
|
|||
|
|
@ -55,7 +55,9 @@ LLBlockList::LLBlockList(const Params& p)
|
|||
|
||||
registrar.add ("Block.Action", boost::bind(&LLBlockList::onCustomAction, this, _2));
|
||||
enable_registrar.add("Block.Enable", boost::bind(&LLBlockList::isActionEnabled, this, _2));
|
||||
|
||||
enable_registrar.add("Block.Check", boost::bind(&LLBlockList::isMenuItemChecked, this, _2));
|
||||
enable_registrar.add("Block.Visible", boost::bind(&LLBlockList::isMenuItemVisible, this, _2));
|
||||
|
||||
LLToggleableMenu* context_menu = LLUICtrlFactory::getInstance()->createFromFile<LLToggleableMenu>(
|
||||
"menu_people_blocked_gear.xml",
|
||||
gMenuHolder,
|
||||
|
|
@ -128,7 +130,14 @@ BOOL LLBlockList::handleRightMouseDown(S32 x, S32 y, MASK mask)
|
|||
|
||||
void LLBlockList::removeListItem(const LLMute* mute)
|
||||
{
|
||||
removeItemByUUID(mute->mID);
|
||||
if (mute->mID.notNull())
|
||||
{
|
||||
removeItemByUUID(mute->mID);
|
||||
}
|
||||
else
|
||||
{
|
||||
removeItemByValue(mute->mName);
|
||||
}
|
||||
}
|
||||
|
||||
void LLBlockList::hideListItem(LLBlockedListItem* item, bool show)
|
||||
|
|
@ -176,7 +185,14 @@ void LLBlockList::addNewItem(const LLMute* mute)
|
|||
{
|
||||
item->highlightName(mNameFilter);
|
||||
}
|
||||
addItem(item, item->getUUID(), ADD_BOTTOM);
|
||||
if (item->getUUID().notNull())
|
||||
{
|
||||
addItem(item, item->getUUID(), ADD_BOTTOM);
|
||||
}
|
||||
else
|
||||
{
|
||||
addItem(item, item->getName(), ADD_BOTTOM);
|
||||
}
|
||||
}
|
||||
|
||||
void LLBlockList::refresh()
|
||||
|
|
@ -184,7 +200,8 @@ void LLBlockList::refresh()
|
|||
bool have_filter = !mNameFilter.empty();
|
||||
|
||||
// save selection to restore it after list rebuilt
|
||||
LLUUID selected = getSelectedUUID(), next_selected;
|
||||
LLSD selected = getSelectedValue();
|
||||
LLSD next_selected;
|
||||
|
||||
if(mShouldAddAll) // creating list of blockers
|
||||
{
|
||||
|
|
@ -202,14 +219,15 @@ void LLBlockList::refresh()
|
|||
}
|
||||
else if(mActionType == REMOVE)
|
||||
{
|
||||
if(selected == mute.mID)
|
||||
if ((mute.mID.notNull() && selected.isUUID() && selected.asUUID() == mute.mID)
|
||||
|| (mute.mID.isNull() && selected.isString() && selected.asString() == mute.mName))
|
||||
{
|
||||
// we are going to remove currently selected item, so select next item and save the selection to restore it
|
||||
if (!selectNextItemPair(false, true))
|
||||
{
|
||||
selectNextItemPair(true, true);
|
||||
}
|
||||
next_selected = getSelectedUUID();
|
||||
if (!selectNextItemPair(false, true))
|
||||
{
|
||||
selectNextItemPair(true, true);
|
||||
}
|
||||
next_selected = getSelectedValue();
|
||||
}
|
||||
removeListItem(&mute);
|
||||
}
|
||||
|
|
@ -235,15 +253,18 @@ void LLBlockList::refresh()
|
|||
}
|
||||
mPrevNameFilter = mNameFilter;
|
||||
|
||||
if (getItemPair(selected))
|
||||
if (selected.isDefined())
|
||||
{
|
||||
// restore previously selected item
|
||||
selectItemPair(getItemPair(selected), true);
|
||||
}
|
||||
else if (getItemPair(next_selected))
|
||||
{
|
||||
// previously selected item was removed, so select next item
|
||||
selectItemPair(getItemPair(next_selected), true);
|
||||
if (getItemPair(selected))
|
||||
{
|
||||
// restore previously selected item
|
||||
selectItemPair(getItemPair(selected), true);
|
||||
}
|
||||
else if (next_selected.isDefined() && getItemPair(next_selected))
|
||||
{
|
||||
// previously selected item was removed, so select next item
|
||||
selectItemPair(getItemPair(next_selected), true);
|
||||
}
|
||||
}
|
||||
mMuteListSize = LLMuteList::getInstance()->getMutes().size();
|
||||
|
||||
|
|
@ -272,7 +293,11 @@ bool LLBlockList::isActionEnabled(const LLSD& userdata)
|
|||
|
||||
const std::string command_name = userdata.asString();
|
||||
|
||||
if ("profile_item" == command_name)
|
||||
if ("profile_item" == command_name
|
||||
|| "block_voice" == command_name
|
||||
|| "block_text" == command_name
|
||||
|| "block_particles" == command_name
|
||||
|| "block_obj_sounds" == command_name)
|
||||
{
|
||||
LLBlockedListItem* item = getBlockedItem();
|
||||
action_enabled = item && (LLMute::AGENT == item->getType());
|
||||
|
|
@ -314,6 +339,83 @@ void LLBlockList::onCustomAction(const LLSD& userdata)
|
|||
break;
|
||||
}
|
||||
}
|
||||
else if ("block_voice" == command_name)
|
||||
{
|
||||
toggleMute(LLMute::flagVoiceChat);
|
||||
}
|
||||
else if ("block_text" == command_name)
|
||||
{
|
||||
toggleMute(LLMute::flagTextChat);
|
||||
}
|
||||
else if ("block_particles" == command_name)
|
||||
{
|
||||
toggleMute(LLMute::flagParticles);
|
||||
}
|
||||
else if ("block_obj_sounds" == command_name)
|
||||
{
|
||||
toggleMute(LLMute::flagObjectSounds);
|
||||
}
|
||||
}
|
||||
|
||||
bool LLBlockList::isMenuItemChecked(const LLSD& userdata)
|
||||
{
|
||||
LLBlockedListItem* item = getBlockedItem();
|
||||
if (!item)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
const std::string command_name = userdata.asString();
|
||||
|
||||
if ("block_voice" == command_name)
|
||||
{
|
||||
return LLMuteList::getInstance()->isMuted(item->getUUID(), LLMute::flagVoiceChat);
|
||||
}
|
||||
else if ("block_text" == command_name)
|
||||
{
|
||||
return LLMuteList::getInstance()->isMuted(item->getUUID(), LLMute::flagTextChat);
|
||||
}
|
||||
else if ("block_particles" == command_name)
|
||||
{
|
||||
return LLMuteList::getInstance()->isMuted(item->getUUID(), LLMute::flagParticles);
|
||||
}
|
||||
else if ("block_obj_sounds" == command_name)
|
||||
{
|
||||
return LLMuteList::getInstance()->isMuted(item->getUUID(), LLMute::flagObjectSounds);
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
bool LLBlockList::isMenuItemVisible(const LLSD& userdata)
|
||||
{
|
||||
LLBlockedListItem* item = getBlockedItem();
|
||||
const std::string command_name = userdata.asString();
|
||||
|
||||
if ("block_voice" == command_name
|
||||
|| "block_text" == command_name
|
||||
|| "block_particles" == command_name
|
||||
|| "block_obj_sounds" == command_name)
|
||||
{
|
||||
return item && (LLMute::AGENT == item->getType());
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
void LLBlockList::toggleMute(U32 flags)
|
||||
{
|
||||
LLBlockedListItem* item = getBlockedItem();
|
||||
LLMute mute(item->getUUID(), item->getName(), item->getType());
|
||||
|
||||
if (!LLMuteList::getInstance()->isMuted(item->getUUID(), flags))
|
||||
{
|
||||
LLMuteList::getInstance()->add(mute, flags);
|
||||
}
|
||||
else
|
||||
{
|
||||
LLMuteList::getInstance()->remove(mute, flags);
|
||||
}
|
||||
}
|
||||
|
||||
bool LLBlockListItemComparator::compare(const LLPanel* item1, const LLPanel* item2) const
|
||||
|
|
|
|||
|
|
@ -79,6 +79,9 @@ private:
|
|||
|
||||
bool isActionEnabled(const LLSD& userdata);
|
||||
void onCustomAction (const LLSD& userdata);
|
||||
bool isMenuItemChecked(const LLSD& userdata);
|
||||
bool isMenuItemVisible(const LLSD& userdata);
|
||||
void toggleMute(U32 flags);
|
||||
void createList();
|
||||
|
||||
BlockListActionType getCurrentMuteListActionType();
|
||||
|
|
|
|||
|
|
@ -243,7 +243,6 @@ S32 LLAvatarTracker::addBuddyList(const LLAvatarTracker::buddy_map_t& buds)
|
|||
using namespace std;
|
||||
|
||||
U32 new_buddy_count = 0;
|
||||
std::string full_name;
|
||||
LLUUID agent_id;
|
||||
for(buddy_map_t::const_iterator itr = buds.begin(); itr != buds.end(); ++itr)
|
||||
{
|
||||
|
|
@ -253,8 +252,11 @@ S32 LLAvatarTracker::addBuddyList(const LLAvatarTracker::buddy_map_t& buds)
|
|||
{
|
||||
++new_buddy_count;
|
||||
mBuddyInfo[agent_id] = (*itr).second;
|
||||
// IDEVO: is this necessary? name is unused?
|
||||
gCacheName->getFullName(agent_id, full_name);
|
||||
|
||||
// pre-request name for notifications?
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(agent_id, &av_name);
|
||||
|
||||
addChangedMask(LLFriendObserver::ADD, agent_id);
|
||||
LL_DEBUGS() << "Added buddy " << agent_id
|
||||
<< ", " << (mBuddyInfo[agent_id]->isOnline() ? "Online" : "Offline")
|
||||
|
|
@ -889,7 +891,9 @@ bool LLCollectMappableBuddies::operator()(const LLUUID& buddy_id, LLRelationship
|
|||
|
||||
bool LLCollectOnlineBuddies::operator()(const LLUUID& buddy_id, LLRelationship* buddy)
|
||||
{
|
||||
gCacheName->getFullName(buddy_id, mFullName);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(buddy_id, &av_name);
|
||||
mFullName = av_name.getUserName();
|
||||
buddy_map_t::value_type value(buddy_id, mFullName);
|
||||
if(buddy->isOnline())
|
||||
{
|
||||
|
|
|
|||
|
|
@ -271,9 +271,9 @@ public:
|
|||
void mute(const LLUUID& participant_id, U32 flags)
|
||||
{
|
||||
BOOL is_muted = LLMuteList::getInstance()->isMuted(participant_id, flags);
|
||||
std::string name;
|
||||
gCacheName->getFullName(participant_id, name);
|
||||
LLMute mute(participant_id, name, LLMute::AGENT);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(participant_id, &av_name);
|
||||
LLMute mute(participant_id, av_name.getUserName(), LLMute::AGENT);
|
||||
|
||||
if (!is_muted)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -602,12 +602,12 @@ bool LLConversationItemParticipant::isVoiceMuted()
|
|||
|
||||
void LLConversationItemParticipant::muteVoice(bool mute_voice)
|
||||
{
|
||||
std::string name;
|
||||
gCacheName->getFullName(mUUID, name);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(mUUID, &av_name);
|
||||
LLMuteList * mute_listp = LLMuteList::getInstance();
|
||||
bool voice_already_muted = mute_listp->isMuted(mUUID, name);
|
||||
bool voice_already_muted = mute_listp->isMuted(mUUID, av_name.getUserName());
|
||||
|
||||
LLMute mute(mUUID, name, LLMute::AGENT);
|
||||
LLMute mute(mUUID, av_name.getUserName(), LLMute::AGENT);
|
||||
if (voice_already_muted && !mute_voice)
|
||||
{
|
||||
mute_listp->remove(mute);
|
||||
|
|
|
|||
|
|
@ -2063,7 +2063,9 @@ void LLDrawPoolAvatar::removeRiggedFace(LLFace* facep)
|
|||
}
|
||||
else
|
||||
{
|
||||
LL_ERRS() << "Face reference data corrupt for rigged type " << i << LL_ENDL;
|
||||
LL_ERRS() << "Face reference data corrupt for rigged type " << i
|
||||
<< ((mRiggedFace[i].size() <= index) ? "; wrong index (out of bounds)" : (mRiggedFace[i][index] != facep) ? "; wrong face pointer" : "")
|
||||
<< LL_ENDL;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -37,6 +37,7 @@
|
|||
LLFilteredWearableListManager::LLFilteredWearableListManager(LLInventoryItemsList* list, LLInventoryCollectFunctor* collector)
|
||||
: mWearableList(list)
|
||||
, mCollector(collector)
|
||||
, mListStale(true)
|
||||
{
|
||||
llassert(mWearableList);
|
||||
gInventory.addObserver(this);
|
||||
|
|
@ -64,7 +65,16 @@ void LLFilteredWearableListManager::changed(U32 mask)
|
|||
return;
|
||||
}
|
||||
|
||||
populateList();
|
||||
if (mWearableList->isInVisibleChain() || mWearableList->getForceRefresh())
|
||||
{
|
||||
// Todo: current populateList() is time consuming and changed() is time-sensitive,
|
||||
// either move from here or optimize
|
||||
populateList();
|
||||
}
|
||||
else
|
||||
{
|
||||
mListStale = true;
|
||||
}
|
||||
}
|
||||
|
||||
void LLFilteredWearableListManager::setFilterCollector(LLInventoryCollectFunctor* collector)
|
||||
|
|
@ -73,13 +83,31 @@ void LLFilteredWearableListManager::setFilterCollector(LLInventoryCollectFunctor
|
|||
populateList();
|
||||
}
|
||||
|
||||
void LLFilteredWearableListManager::populateIfNeeded()
|
||||
{
|
||||
if (mListStale)
|
||||
{
|
||||
populateList();
|
||||
}
|
||||
}
|
||||
|
||||
LLTrace::BlockTimerStatHandle FTM_MANAGER_LIST_POPULATION("Manager List Population");
|
||||
|
||||
void LLFilteredWearableListManager::populateList()
|
||||
{
|
||||
LL_RECORD_BLOCK_TIME(FTM_MANAGER_LIST_POPULATION);
|
||||
|
||||
LLInventoryModel::cat_array_t cat_array;
|
||||
LLInventoryModel::item_array_t item_array;
|
||||
|
||||
if(mCollector)
|
||||
{
|
||||
// Too slow with large inventory!
|
||||
// Consider refactoring into "request once, append ids on changed()", since
|
||||
// Inventory observer provides ids of changed items this should be possible,
|
||||
// but will likely require modifying LLInventoryItemsList to avoid code-repeats.
|
||||
// Or make something like "gather everything and filter manually on idle"
|
||||
mListStale = false;
|
||||
gInventory.collectDescendentsIf(
|
||||
gInventory.getRootFolderID(),
|
||||
cat_array,
|
||||
|
|
|
|||
|
|
@ -52,9 +52,9 @@ public:
|
|||
void setFilterCollector(LLInventoryCollectFunctor* collector);
|
||||
|
||||
/**
|
||||
* Populates wearable list with filtered data.
|
||||
*/
|
||||
void populateList();
|
||||
* Populates wearable list with filtered data in case there were any updates.
|
||||
*/
|
||||
void populateIfNeeded();
|
||||
|
||||
/**
|
||||
* Drop operation
|
||||
|
|
@ -62,8 +62,14 @@ public:
|
|||
void holdProgress();
|
||||
|
||||
private:
|
||||
/**
|
||||
* Populates wearable list with filtered data.
|
||||
*/
|
||||
void populateList();
|
||||
|
||||
LLInventoryItemsList* mWearableList;
|
||||
LLInventoryCollectFunctor* mCollector;
|
||||
bool mListStale;
|
||||
};
|
||||
|
||||
#endif //LL_LLFILTEREDWEARABLELIST_H
|
||||
|
|
|
|||
|
|
@ -0,0 +1,286 @@
|
|||
/**
|
||||
* @file llfloateravatarrendersettings.cpp
|
||||
* @brief Shows the list of avatars with non-default rendering settings
|
||||
*
|
||||
* $LicenseInfo:firstyear=2009&license=viewerlgpl$
|
||||
* Second Life Viewer Source Code
|
||||
* Copyright (C) 2017, 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$
|
||||
*/
|
||||
#include "llviewerprecompiledheaders.h"
|
||||
|
||||
#include "llfloateravatarrendersettings.h"
|
||||
|
||||
#include "llavatarnamecache.h"
|
||||
#include "llfloateravatarpicker.h"
|
||||
#include "llfiltereditor.h"
|
||||
#include "llfloaterreg.h"
|
||||
#include "llnamelistctrl.h"
|
||||
#include "llmenugl.h"
|
||||
#include "llviewerobjectlist.h"
|
||||
#include "llvoavatar.h"
|
||||
|
||||
class LLSettingsContextMenu : public LLListContextMenu
|
||||
|
||||
{
|
||||
public:
|
||||
LLSettingsContextMenu(LLFloaterAvatarRenderSettings* floater_settings)
|
||||
: mFloaterSettings(floater_settings)
|
||||
{}
|
||||
protected:
|
||||
LLContextMenu* createMenu()
|
||||
{
|
||||
LLUICtrl::CommitCallbackRegistry::ScopedRegistrar registrar;
|
||||
LLUICtrl::EnableCallbackRegistry::ScopedRegistrar enable_registrar;
|
||||
registrar.add("Settings.SetRendering", boost::bind(&LLFloaterAvatarRenderSettings::onCustomAction, mFloaterSettings, _2, mUUIDs.front()));
|
||||
enable_registrar.add("Settings.IsSelected", boost::bind(&LLFloaterAvatarRenderSettings::isActionChecked, mFloaterSettings, _2, mUUIDs.front()));
|
||||
LLContextMenu* menu = createFromFile("menu_avatar_rendering_settings.xml");
|
||||
|
||||
return menu;
|
||||
}
|
||||
|
||||
LLFloaterAvatarRenderSettings* mFloaterSettings;
|
||||
};
|
||||
|
||||
class LLAvatarRenderMuteListObserver : public LLMuteListObserver
|
||||
{
|
||||
/* virtual */ void onChange() { LLFloaterAvatarRenderSettings::setNeedsUpdate();}
|
||||
};
|
||||
|
||||
static LLAvatarRenderMuteListObserver sAvatarRenderMuteListObserver;
|
||||
|
||||
LLFloaterAvatarRenderSettings::LLFloaterAvatarRenderSettings(const LLSD& key)
|
||||
: LLFloater(key),
|
||||
mAvatarSettingsList(NULL),
|
||||
mNeedsUpdate(false)
|
||||
{
|
||||
mContextMenu = new LLSettingsContextMenu(this);
|
||||
LLRenderMuteList::getInstance()->addObserver(&sAvatarRenderMuteListObserver);
|
||||
mCommitCallbackRegistrar.add("Settings.AddNewEntry", boost::bind(&LLFloaterAvatarRenderSettings::onClickAdd, this, _2));
|
||||
}
|
||||
|
||||
LLFloaterAvatarRenderSettings::~LLFloaterAvatarRenderSettings()
|
||||
{
|
||||
delete mContextMenu;
|
||||
LLRenderMuteList::getInstance()->removeObserver(&sAvatarRenderMuteListObserver);
|
||||
}
|
||||
|
||||
BOOL LLFloaterAvatarRenderSettings::postBuild()
|
||||
{
|
||||
LLFloater::postBuild();
|
||||
mAvatarSettingsList = getChild<LLNameListCtrl>("render_settings_list");
|
||||
mAvatarSettingsList->setRightMouseDownCallback(boost::bind(&LLFloaterAvatarRenderSettings::onAvatarListRightClick, this, _1, _2, _3));
|
||||
this->setVisibleCallback(boost::bind(&LLFloaterAvatarRenderSettings::removePicker, this));
|
||||
getChild<LLFilterEditor>("people_filter_input")->setCommitCallback(boost::bind(&LLFloaterAvatarRenderSettings::onFilterEdit, this, _2));
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
void LLFloaterAvatarRenderSettings::removePicker()
|
||||
{
|
||||
if(mPicker.get())
|
||||
{
|
||||
mPicker.get()->closeFloater();
|
||||
}
|
||||
}
|
||||
|
||||
void LLFloaterAvatarRenderSettings::draw()
|
||||
{
|
||||
if(mNeedsUpdate)
|
||||
{
|
||||
updateList();
|
||||
mNeedsUpdate = false;
|
||||
}
|
||||
|
||||
LLFloater::draw();
|
||||
}
|
||||
|
||||
void LLFloaterAvatarRenderSettings::onAvatarListRightClick(LLUICtrl* ctrl, S32 x, S32 y)
|
||||
{
|
||||
LLNameListCtrl* list = dynamic_cast<LLNameListCtrl*>(ctrl);
|
||||
if (!list) return;
|
||||
list->selectItemAt(x, y, MASK_NONE);
|
||||
uuid_vec_t selected_uuids;
|
||||
|
||||
if(list->getCurrentID().notNull())
|
||||
{
|
||||
selected_uuids.push_back(list->getCurrentID());
|
||||
mContextMenu->show(ctrl, selected_uuids, x, y);
|
||||
}
|
||||
}
|
||||
|
||||
void LLFloaterAvatarRenderSettings::onOpen(const LLSD& key)
|
||||
{
|
||||
updateList();
|
||||
}
|
||||
|
||||
void LLFloaterAvatarRenderSettings::updateList()
|
||||
{
|
||||
mAvatarSettingsList->deleteAllItems();
|
||||
LLAvatarName av_name;
|
||||
LLNameListCtrl::NameItem item_params;
|
||||
for (std::map<LLUUID, S32>::iterator iter = LLRenderMuteList::getInstance()->sVisuallyMuteSettingsMap.begin(); iter != LLRenderMuteList::getInstance()->sVisuallyMuteSettingsMap.end(); iter++)
|
||||
{
|
||||
item_params.value = iter->first;
|
||||
LLAvatarNameCache::get(iter->first, &av_name);
|
||||
if(!isHiddenRow(av_name.getCompleteName()))
|
||||
{
|
||||
item_params.columns.add().value(av_name.getCompleteName()).column("name");
|
||||
std::string setting = getString(iter->second == 1 ? "av_never_render" : "av_always_render");
|
||||
item_params.columns.add().value(setting).column("setting");
|
||||
mAvatarSettingsList->addNameItemRow(item_params);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void LLFloaterAvatarRenderSettings::onFilterEdit(const std::string& search_string)
|
||||
{
|
||||
std::string filter_upper = search_string;
|
||||
LLStringUtil::toUpper(filter_upper);
|
||||
if (mNameFilter != filter_upper)
|
||||
{
|
||||
mNameFilter = filter_upper;
|
||||
mNeedsUpdate = true;
|
||||
}
|
||||
}
|
||||
|
||||
bool LLFloaterAvatarRenderSettings::isHiddenRow(const std::string& av_name)
|
||||
{
|
||||
if (mNameFilter.empty()) return false;
|
||||
std::string upper_name = av_name;
|
||||
LLStringUtil::toUpper(upper_name);
|
||||
return std::string::npos == upper_name.find(mNameFilter);
|
||||
}
|
||||
|
||||
static LLVOAvatar* find_avatar(const LLUUID& id)
|
||||
{
|
||||
LLViewerObject *obj = gObjectList.findObject(id);
|
||||
while (obj && obj->isAttachment())
|
||||
{
|
||||
obj = (LLViewerObject *)obj->getParent();
|
||||
}
|
||||
|
||||
if (obj && obj->isAvatar())
|
||||
{
|
||||
return (LLVOAvatar*)obj;
|
||||
}
|
||||
else
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void LLFloaterAvatarRenderSettings::onCustomAction (const LLSD& userdata, const LLUUID& av_id)
|
||||
{
|
||||
const std::string command_name = userdata.asString();
|
||||
|
||||
S32 new_setting = 0;
|
||||
if ("default" == command_name)
|
||||
{
|
||||
new_setting = S32(LLVOAvatar::AV_RENDER_NORMALLY);
|
||||
}
|
||||
else if ("never" == command_name)
|
||||
{
|
||||
new_setting = S32(LLVOAvatar::AV_DO_NOT_RENDER);
|
||||
}
|
||||
else if ("always" == command_name)
|
||||
{
|
||||
new_setting = S32(LLVOAvatar::AV_ALWAYS_RENDER);
|
||||
}
|
||||
|
||||
LLVOAvatar *avatarp = find_avatar(av_id);
|
||||
if (avatarp)
|
||||
{
|
||||
avatarp->setVisualMuteSettings(LLVOAvatar::VisualMuteSettings(new_setting));
|
||||
}
|
||||
else
|
||||
{
|
||||
LLRenderMuteList::getInstance()->saveVisualMuteSetting(av_id, new_setting);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
bool LLFloaterAvatarRenderSettings::isActionChecked(const LLSD& userdata, const LLUUID& av_id)
|
||||
{
|
||||
const std::string command_name = userdata.asString();
|
||||
|
||||
S32 visual_setting = LLRenderMuteList::getInstance()->getSavedVisualMuteSetting(av_id);
|
||||
if ("default" == command_name)
|
||||
{
|
||||
return (visual_setting == S32(LLVOAvatar::AV_RENDER_NORMALLY));
|
||||
}
|
||||
else if ("never" == command_name)
|
||||
{
|
||||
return (visual_setting == S32(LLVOAvatar::AV_DO_NOT_RENDER));
|
||||
}
|
||||
else if ("always" == command_name)
|
||||
{
|
||||
return (visual_setting == S32(LLVOAvatar::AV_ALWAYS_RENDER));
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void LLFloaterAvatarRenderSettings::setNeedsUpdate()
|
||||
{
|
||||
LLFloaterAvatarRenderSettings* instance = LLFloaterReg::getTypedInstance<LLFloaterAvatarRenderSettings>("avatar_render_settings");
|
||||
if(!instance) return;
|
||||
instance->mNeedsUpdate = true;
|
||||
}
|
||||
|
||||
void LLFloaterAvatarRenderSettings::onClickAdd(const LLSD& userdata)
|
||||
{
|
||||
const std::string command_name = userdata.asString();
|
||||
S32 visual_setting = 0;
|
||||
if ("never" == command_name)
|
||||
{
|
||||
visual_setting = S32(LLVOAvatar::AV_DO_NOT_RENDER);
|
||||
}
|
||||
else if ("always" == command_name)
|
||||
{
|
||||
visual_setting = S32(LLVOAvatar::AV_ALWAYS_RENDER);
|
||||
}
|
||||
|
||||
LLView * button = findChild<LLButton>("plus_btn", TRUE);
|
||||
LLFloater* root_floater = gFloaterView->getParentFloater(this);
|
||||
LLFloaterAvatarPicker * picker = LLFloaterAvatarPicker::show(boost::bind(&LLFloaterAvatarRenderSettings::callbackAvatarPicked, this, _1, visual_setting),
|
||||
FALSE, TRUE, FALSE, root_floater->getName(), button);
|
||||
|
||||
if (root_floater)
|
||||
{
|
||||
root_floater->addDependentFloater(picker);
|
||||
}
|
||||
|
||||
mPicker = picker->getHandle();
|
||||
}
|
||||
|
||||
void LLFloaterAvatarRenderSettings::callbackAvatarPicked(const uuid_vec_t& ids, S32 visual_setting)
|
||||
{
|
||||
if (ids.empty()) return;
|
||||
|
||||
LLVOAvatar *avatarp = find_avatar(ids[0]);
|
||||
if (avatarp)
|
||||
{
|
||||
avatarp->setVisualMuteSettings(LLVOAvatar::VisualMuteSettings(visual_setting));
|
||||
}
|
||||
else
|
||||
{
|
||||
LLRenderMuteList::getInstance()->saveVisualMuteSetting(ids[0], visual_setting);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,71 @@
|
|||
/**
|
||||
* @file llfloateravatarrendersettings.h
|
||||
* @brief Shows the list of avatars with non-default rendering settings
|
||||
*
|
||||
* $LicenseInfo:firstyear=2009&license=viewerlgpl$
|
||||
* Second Life Viewer Source Code
|
||||
* Copyright (C) 2017, 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$
|
||||
*/
|
||||
|
||||
#ifndef LL_LLFLOATERAVATARRENDERSETTINGS_H
|
||||
#define LL_LLFLOATERAVATARRENDERSETTINGS_H
|
||||
|
||||
#include "llfloater.h"
|
||||
#include "lllistcontextmenu.h"
|
||||
#include "llmutelist.h"
|
||||
|
||||
class LLNameListCtrl;
|
||||
|
||||
class LLFloaterAvatarRenderSettings : public LLFloater
|
||||
{
|
||||
public:
|
||||
|
||||
LLFloaterAvatarRenderSettings(const LLSD& key);
|
||||
virtual ~LLFloaterAvatarRenderSettings();
|
||||
|
||||
/*virtual*/ BOOL postBuild();
|
||||
/*virtual*/ void onOpen(const LLSD& key);
|
||||
/*virtual*/ void draw();
|
||||
|
||||
void onAvatarListRightClick(LLUICtrl* ctrl, S32 x, S32 y);
|
||||
|
||||
void updateList();
|
||||
void onFilterEdit(const std::string& search_string);
|
||||
void onCustomAction (const LLSD& userdata, const LLUUID& av_id);
|
||||
bool isActionChecked(const LLSD& userdata, const LLUUID& av_id);
|
||||
void onClickAdd(const LLSD& userdata);
|
||||
|
||||
static void setNeedsUpdate();
|
||||
|
||||
private:
|
||||
bool isHiddenRow(const std::string& av_name);
|
||||
void callbackAvatarPicked(const uuid_vec_t& ids, S32 visual_setting);
|
||||
void removePicker();
|
||||
|
||||
bool mNeedsUpdate;
|
||||
LLListContextMenu* mContextMenu;
|
||||
LLNameListCtrl* mAvatarSettingsList;
|
||||
LLHandle<LLFloater> mPicker;
|
||||
|
||||
std::string mNameFilter;
|
||||
};
|
||||
|
||||
|
||||
#endif //LL_LLFLOATERAVATARRENDERSETTINGS_H
|
||||
|
|
@ -25,6 +25,7 @@
|
|||
|
||||
#include "llviewerprecompiledheaders.h"
|
||||
|
||||
#include "llavatarnamecache.h"
|
||||
#include "llconversationlog.h"
|
||||
#include "llfloaterconversationpreview.h"
|
||||
#include "llimview.h"
|
||||
|
|
@ -220,7 +221,7 @@ void LLFloaterConversationPreview::showHistory()
|
|||
else
|
||||
{
|
||||
std::string legacy_name = gCacheName->buildLegacyName(from);
|
||||
gCacheName->getUUID(legacy_name, from_id);
|
||||
from_id = LLAvatarNameCache::findIdByName(legacy_name);
|
||||
}
|
||||
|
||||
LLChat chat;
|
||||
|
|
|
|||
|
|
@ -0,0 +1,184 @@
|
|||
/**
|
||||
* @file llfloatergridstatus.cpp
|
||||
* @brief Grid status floater - uses an embedded web browser to show Grid status info
|
||||
*
|
||||
* $LicenseInfo:firstyear=2009&license=viewerlgpl$
|
||||
* Second Life Viewer Source Code
|
||||
* Copyright (C) 2017, 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$
|
||||
*/
|
||||
|
||||
#include "llviewerprecompiledheaders.h"
|
||||
|
||||
#include "llfloatergridstatus.h"
|
||||
|
||||
#include "llcallbacklist.h"
|
||||
#include "llcorehttputil.h"
|
||||
#include "llfloaterreg.h"
|
||||
#include "llhttpconstants.h"
|
||||
#include "llmediactrl.h"
|
||||
#include "llsdserialize.h"
|
||||
#include "lltoolbarview.h"
|
||||
#include "llviewercontrol.h"
|
||||
#include "llxmltree.h"
|
||||
|
||||
std::map<std::string, std::string> LLFloaterGridStatus::sItemsMap;
|
||||
const std::string DEFAULT_GRID_STATUS_URL = "http://secondlife-status.statuspage.io/";
|
||||
|
||||
LLFloaterGridStatus::LLFloaterGridStatus(const Params& key) :
|
||||
LLFloaterWebContent(key),
|
||||
mIsFirstUpdate(TRUE)
|
||||
{
|
||||
}
|
||||
|
||||
BOOL LLFloaterGridStatus::postBuild()
|
||||
{
|
||||
LLFloaterWebContent::postBuild();
|
||||
mWebBrowser->addObserver(this);
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
void LLFloaterGridStatus::onOpen(const LLSD& key)
|
||||
{
|
||||
Params p(key);
|
||||
p.trusted_content = true;
|
||||
p.allow_address_entry = false;
|
||||
|
||||
LLFloaterWebContent::onOpen(p);
|
||||
applyPreferredRect();
|
||||
if (mWebBrowser)
|
||||
{
|
||||
mWebBrowser->navigateTo(DEFAULT_GRID_STATUS_URL, HTTP_CONTENT_TEXT_HTML);
|
||||
}
|
||||
}
|
||||
|
||||
void LLFloaterGridStatus::startGridStatusTimer()
|
||||
{
|
||||
checkGridStatusRSS();
|
||||
doPeriodically(boost::bind(&LLFloaterGridStatus::checkGridStatusRSS), gSavedSettings.getF32("GridStatusUpdateDelay"));
|
||||
}
|
||||
|
||||
bool LLFloaterGridStatus::checkGridStatusRSS()
|
||||
{
|
||||
if(gToolBarView->hasCommand(LLCommandId("gridstatus")))
|
||||
{
|
||||
LLCoros::instance().launch("LLFloaterGridStatus::getGridStatusRSSCoro",
|
||||
boost::bind(&LLFloaterGridStatus::getGridStatusRSSCoro));
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void LLFloaterGridStatus::getGridStatusRSSCoro()
|
||||
{
|
||||
|
||||
LLCore::HttpRequest::policy_t httpPolicy(LLCore::HttpRequest::DEFAULT_POLICY_ID);
|
||||
LLCoreHttpUtil::HttpCoroutineAdapter::ptr_t
|
||||
httpAdapter(new LLCoreHttpUtil::HttpCoroutineAdapter("getGridStatusRSSCoro", httpPolicy));
|
||||
LLCore::HttpRequest::ptr_t httpRequest(new LLCore::HttpRequest);
|
||||
LLCore::HttpOptions::ptr_t httpOpts(new LLCore::HttpOptions);
|
||||
LLCore::HttpHeaders::ptr_t httpHeaders(new LLCore::HttpHeaders);
|
||||
|
||||
httpHeaders->append(HTTP_OUT_HEADER_CONTENT_TYPE, HTTP_CONTENT_TEXT_XML);
|
||||
std::string url = gSavedSettings.getString("GridStatusRSS");
|
||||
|
||||
LLSD result = httpAdapter->getRawAndSuspend(httpRequest, url, httpOpts, httpHeaders);
|
||||
LLSD httpResults = result[LLCoreHttpUtil::HttpCoroutineAdapter::HTTP_RESULTS];
|
||||
LLCore::HttpStatus status = LLCoreHttpUtil::HttpCoroutineAdapter::getStatusFromLLSD(httpResults);
|
||||
if (!status)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
const LLSD::Binary &rawBody = result[LLCoreHttpUtil::HttpCoroutineAdapter::HTTP_RESULTS_RAW].asBinary();
|
||||
std::string body(rawBody.begin(), rawBody.end());
|
||||
|
||||
std::string fullpath = gDirUtilp->getExpandedFilename(LL_PATH_LOGS,"grid_status_rss.xml");
|
||||
if(!gSavedSettings.getBOOL("TestGridStatusRSSFromFile"))
|
||||
{
|
||||
llofstream custom_file_out(fullpath.c_str(), std::ios::trunc);
|
||||
if (custom_file_out.is_open())
|
||||
{
|
||||
custom_file_out << body;
|
||||
custom_file_out.close();
|
||||
}
|
||||
}
|
||||
LLXmlTree grid_status_xml;
|
||||
if (!grid_status_xml.parseFile(fullpath))
|
||||
{
|
||||
return ;
|
||||
}
|
||||
bool new_entries = false;
|
||||
LLXmlTreeNode* rootp = grid_status_xml.getRoot();
|
||||
for (LLXmlTreeNode* item = rootp->getChildByName( "entry" ); item; item = rootp->getNextNamedChild())
|
||||
{
|
||||
LLXmlTreeNode* id_node = item->getChildByName("id");
|
||||
LLXmlTreeNode* updated_node = item->getChildByName("updated");
|
||||
if (!id_node || !updated_node)
|
||||
{
|
||||
continue;
|
||||
}
|
||||
std::string guid = id_node->getContents();
|
||||
std::string date = updated_node->getContents();
|
||||
if(sItemsMap.find( guid ) == sItemsMap.end())
|
||||
{
|
||||
new_entries = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
if(sItemsMap[guid] != date)
|
||||
{
|
||||
new_entries = true;
|
||||
}
|
||||
}
|
||||
sItemsMap[guid] = date;
|
||||
}
|
||||
if(new_entries && !getInstance()->isFirstUpdate())
|
||||
{
|
||||
gToolBarView->flashCommand(LLCommandId("gridstatus"), true);
|
||||
}
|
||||
getInstance()->setFirstUpdate(FALSE);
|
||||
}
|
||||
|
||||
// virtual
|
||||
void LLFloaterGridStatus::handleReshape(const LLRect& new_rect, bool by_user)
|
||||
{
|
||||
if (by_user && !isMinimized())
|
||||
{
|
||||
gSavedSettings.setRect("GridStatusFloaterRect", new_rect);
|
||||
}
|
||||
|
||||
LLFloaterWebContent::handleReshape(new_rect, by_user);
|
||||
}
|
||||
|
||||
void LLFloaterGridStatus::applyPreferredRect()
|
||||
{
|
||||
const LLRect preferred_rect = gSavedSettings.getRect("GridStatusFloaterRect");
|
||||
|
||||
LLRect new_rect = getRect();
|
||||
new_rect.setLeftTopAndSize(
|
||||
new_rect.mLeft, new_rect.mTop,
|
||||
preferred_rect.getWidth(), preferred_rect.getHeight());
|
||||
setShape(new_rect);
|
||||
}
|
||||
|
||||
LLFloaterGridStatus* LLFloaterGridStatus::getInstance()
|
||||
{
|
||||
return LLFloaterReg::getTypedInstance<LLFloaterGridStatus>("grid_status");
|
||||
}
|
||||
|
|
@ -0,0 +1,71 @@
|
|||
/**
|
||||
* @file llfloatergridstatus.h
|
||||
* @brief Grid status floater - uses an embedded web browser to show Grid status info
|
||||
*
|
||||
* $LicenseInfo:firstyear=2009&license=viewerlgpl$
|
||||
* Second Life Viewer Source Code
|
||||
* Copyright (C) 2017, 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$
|
||||
*/
|
||||
|
||||
#ifndef LL_LLFLOATERGRIDSTATUS_H
|
||||
#define LL_LLFLOATERGRIDSTATUS_H
|
||||
|
||||
#include "llfloaterwebcontent.h"
|
||||
#include "llviewermediaobserver.h"
|
||||
|
||||
#include <string>
|
||||
|
||||
class LLMediaCtrl;
|
||||
|
||||
|
||||
class LLFloaterGridStatus :
|
||||
public LLFloaterWebContent
|
||||
{
|
||||
public:
|
||||
typedef LLSDParamAdapter<_Params> Params;
|
||||
|
||||
LLFloaterGridStatus(const Params& key);
|
||||
|
||||
/*virtual*/ void onOpen(const LLSD& key);
|
||||
/*virtual*/ void handleReshape(const LLRect& new_rect, bool by_user = false);
|
||||
|
||||
static bool checkGridStatusRSS();
|
||||
static void getGridStatusRSSCoro();
|
||||
|
||||
void startGridStatusTimer();
|
||||
BOOL isFirstUpdate() { return mIsFirstUpdate; }
|
||||
void setFirstUpdate(BOOL first_update) { mIsFirstUpdate = first_update; }
|
||||
|
||||
static LLFloaterGridStatus* getInstance();
|
||||
|
||||
|
||||
private:
|
||||
/*virtual*/ BOOL postBuild();
|
||||
|
||||
void applyPreferredRect();
|
||||
|
||||
static std::map<std::string, std::string> sItemsMap;
|
||||
|
||||
LLFrameTimer mGridStatusTimer;
|
||||
BOOL mIsFirstUpdate;
|
||||
};
|
||||
|
||||
#endif // LL_LLFLOATERGRIDSTATUS_H
|
||||
|
||||
|
|
@ -2099,9 +2099,10 @@ void LLFloaterIMContainer::toggleAllowTextChat(const LLUUID& participant_uuid)
|
|||
void LLFloaterIMContainer::toggleMute(const LLUUID& participant_id, U32 flags)
|
||||
{
|
||||
BOOL is_muted = LLMuteList::getInstance()->isMuted(participant_id, flags);
|
||||
std::string name;
|
||||
gCacheName->getFullName(participant_id, name);
|
||||
LLMute mute(participant_id, name, LLMute::AGENT);
|
||||
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(participant_id, &av_name);
|
||||
LLMute mute(participant_id, av_name.getUserName(), LLMute::AGENT);
|
||||
|
||||
if (!is_muted)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -218,7 +218,7 @@ void LLFloaterIMNearbyChat::loadHistory()
|
|||
else
|
||||
{
|
||||
std::string legacy_name = gCacheName->buildLegacyName(from);
|
||||
gCacheName->getUUID(legacy_name, from_id);
|
||||
from_id = LLAvatarNameCache::findIdByName(legacy_name);
|
||||
}
|
||||
|
||||
LLChat chat;
|
||||
|
|
|
|||
|
|
@ -603,6 +603,7 @@ void LLFloaterMarketplaceListings::updateView()
|
|||
text = LLTrans::getString("InventoryMarketplaceError", subs);
|
||||
title = LLTrans::getString("InventoryOutboxErrorTitle");
|
||||
tooltip = LLTrans::getString("InventoryOutboxErrorTooltip");
|
||||
LL_WARNS() << "Marketplace status code: " << mkt_status << LL_ENDL;
|
||||
}
|
||||
|
||||
mInventoryText->setValue(text);
|
||||
|
|
|
|||
|
|
@ -360,6 +360,7 @@ LLFloaterPreference::LLFloaterPreference(const LLSD& key)
|
|||
mCommitCallbackRegistrar.add("Pref.ClickEnablePopup", boost::bind(&LLFloaterPreference::onClickEnablePopup, this));
|
||||
mCommitCallbackRegistrar.add("Pref.ClickDisablePopup", boost::bind(&LLFloaterPreference::onClickDisablePopup, this));
|
||||
mCommitCallbackRegistrar.add("Pref.LogPath", boost::bind(&LLFloaterPreference::onClickLogPath, this));
|
||||
mCommitCallbackRegistrar.add("Pref.RenderExceptions", boost::bind(&LLFloaterPreference::onClickRenderExceptions, this));
|
||||
mCommitCallbackRegistrar.add("Pref.HardwareDefaults", boost::bind(&LLFloaterPreference::setHardwareDefaults, this));
|
||||
mCommitCallbackRegistrar.add("Pref.AvatarImpostorsEnable", boost::bind(&LLFloaterPreference::onAvatarImpostorsEnable, this));
|
||||
mCommitCallbackRegistrar.add("Pref.UpdateIndirectMaxComplexity", boost::bind(&LLFloaterPreference::updateMaxComplexity, this));
|
||||
|
|
@ -385,7 +386,7 @@ LLFloaterPreference::LLFloaterPreference(const LLSD& key)
|
|||
gSavedSettings.getControl("NameTagShowUsernames")->getCommitSignal()->connect(boost::bind(&handleNameTagOptionChanged, _2));
|
||||
gSavedSettings.getControl("NameTagShowFriends")->getCommitSignal()->connect(boost::bind(&handleNameTagOptionChanged, _2));
|
||||
gSavedSettings.getControl("UseDisplayNames")->getCommitSignal()->connect(boost::bind(&handleDisplayNamesOptionChanged, _2));
|
||||
|
||||
|
||||
gSavedSettings.getControl("AppearanceCameraMovement")->getCommitSignal()->connect(boost::bind(&handleAppearanceCameraMovementChanged, _2));
|
||||
|
||||
LLAvatarPropertiesProcessor::getInstance()->addObserver( gAgent.getID(), this );
|
||||
|
|
@ -786,10 +787,12 @@ void LLFloaterPreference::onOpen(const LLSD& key)
|
|||
LLButton* load_btn = findChild<LLButton>("PrefLoadButton");
|
||||
LLButton* save_btn = findChild<LLButton>("PrefSaveButton");
|
||||
LLButton* delete_btn = findChild<LLButton>("PrefDeleteButton");
|
||||
LLButton* exceptions_btn = findChild<LLButton>("RenderExceptionsButton");
|
||||
|
||||
load_btn->setEnabled(started);
|
||||
save_btn->setEnabled(started);
|
||||
delete_btn->setEnabled(started);
|
||||
exceptions_btn->setEnabled(started);
|
||||
}
|
||||
|
||||
void LLFloaterPreference::onVertexShaderEnable()
|
||||
|
|
@ -2075,6 +2078,11 @@ void LLFloaterPreference::onClickSpellChecker()
|
|||
LLFloaterReg::showInstance("prefs_spellchecker");
|
||||
}
|
||||
|
||||
void LLFloaterPreference::onClickRenderExceptions()
|
||||
{
|
||||
LLFloaterReg::showInstance("avatar_render_settings");
|
||||
}
|
||||
|
||||
void LLFloaterPreference::onClickAdvanced()
|
||||
{
|
||||
LLFloaterReg::showInstance("prefs_graphics_advanced");
|
||||
|
|
|
|||
|
|
@ -171,6 +171,7 @@ public:
|
|||
void onClickPermsDefault();
|
||||
void onClickAutoReplace();
|
||||
void onClickSpellChecker();
|
||||
void onClickRenderExceptions();
|
||||
void onClickAdvanced();
|
||||
void applyUIColor(LLUICtrl* ctrl, const LLSD& param);
|
||||
void getUIColor(LLUICtrl* ctrl, const LLSD& param);
|
||||
|
|
|
|||
|
|
@ -30,6 +30,7 @@
|
|||
#include <algorithm>
|
||||
#include <functional>
|
||||
#include "llcachename.h"
|
||||
#include "llavatarnamecache.h"
|
||||
#include "lldbstrings.h"
|
||||
#include "llfloaterreg.h"
|
||||
|
||||
|
|
@ -274,12 +275,12 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item)
|
|||
|
||||
if (item->getCreatorUUID().notNull())
|
||||
{
|
||||
std::string name;
|
||||
gCacheName->getFullName(item->getCreatorUUID(), name);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(item->getCreatorUUID(), &av_name);
|
||||
getChildView("BtnCreator")->setEnabled(TRUE);
|
||||
getChildView("LabelCreatorTitle")->setEnabled(TRUE);
|
||||
getChildView("LabelCreatorName")->setEnabled(TRUE);
|
||||
getChild<LLUICtrl>("LabelCreatorName")->setValue(name);
|
||||
getChild<LLUICtrl>("LabelCreatorName")->setValue(av_name.getUserName());
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -301,7 +302,9 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item)
|
|||
}
|
||||
else
|
||||
{
|
||||
gCacheName->getFullName(perm.getOwner(), name);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(perm.getOwner(), &av_name);
|
||||
name = av_name.getUserName();
|
||||
}
|
||||
getChildView("BtnOwner")->setEnabled(TRUE);
|
||||
getChildView("LabelOwnerTitle")->setEnabled(TRUE);
|
||||
|
|
|
|||
|
|
@ -357,6 +357,7 @@ void LLFloaterRegionInfo::processRegionInfo(LLMessageSystem* msg)
|
|||
std::string sim_type = LLTrans::getString("land_type_unknown");
|
||||
U64 region_flags;
|
||||
U8 agent_limit;
|
||||
S32 hard_agent_limit;
|
||||
F32 object_bonus_factor;
|
||||
U8 sim_access;
|
||||
F32 water_height;
|
||||
|
|
@ -366,6 +367,7 @@ void LLFloaterRegionInfo::processRegionInfo(LLMessageSystem* msg)
|
|||
F32 sun_hour;
|
||||
msg->getString("RegionInfo", "SimName", sim_name);
|
||||
msg->getU8("RegionInfo", "MaxAgents", agent_limit);
|
||||
msg->getS32("RegionInfo2", "HardMaxAgents", hard_agent_limit);
|
||||
msg->getF32("RegionInfo", "ObjectBonusFactor", object_bonus_factor);
|
||||
msg->getU8("RegionInfo", "SimAccess", sim_access);
|
||||
msg->getF32Fast(_PREHASH_RegionInfo, _PREHASH_WaterHeight, water_height);
|
||||
|
|
@ -412,6 +414,8 @@ void LLFloaterRegionInfo::processRegionInfo(LLMessageSystem* msg)
|
|||
panel->getChild<LLUICtrl>("object_bonus_spin")->setValue(LLSD(object_bonus_factor) );
|
||||
panel->getChild<LLUICtrl>("access_combo")->setValue(LLSD(sim_access) );
|
||||
|
||||
panel->getChild<LLSpinCtrl>("agent_limit_spin")->setMaxValue(hard_agent_limit);
|
||||
|
||||
LLPanelRegionGeneralInfo* panel_general = LLFloaterRegionInfo::getPanelGeneral();
|
||||
if (panel)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -390,6 +390,14 @@ void LLPanelScriptLimitsRegionMemory::setErrorStatus(S32 status, const std::stri
|
|||
LL_WARNS() << "Can't handle remote parcel request."<< " Http Status: "<< status << ". Reason : "<< reason<<LL_ENDL;
|
||||
}
|
||||
|
||||
// callback from the name cache with an owner name to add to the list
|
||||
void LLPanelScriptLimitsRegionMemory::onAvatarNameCache(
|
||||
const LLUUID& id,
|
||||
const LLAvatarName& av_name)
|
||||
{
|
||||
onNameCache(id, av_name.getUserName());
|
||||
}
|
||||
|
||||
// callback from the name cache with an owner name to add to the list
|
||||
void LLPanelScriptLimitsRegionMemory::onNameCache(
|
||||
const LLUUID& id,
|
||||
|
|
@ -503,7 +511,9 @@ void LLPanelScriptLimitsRegionMemory::setRegionDetails(LLSD content)
|
|||
}
|
||||
else
|
||||
{
|
||||
name_is_cached = gCacheName->getFullName(owner_id, owner_buf); // username
|
||||
LLAvatarName av_name;
|
||||
name_is_cached = LLAvatarNameCache::get(owner_id, &av_name);
|
||||
owner_buf = av_name.getUserName();
|
||||
owner_buf = LLCacheName::buildUsername(owner_buf);
|
||||
}
|
||||
if(!name_is_cached)
|
||||
|
|
@ -511,9 +521,18 @@ void LLPanelScriptLimitsRegionMemory::setRegionDetails(LLSD content)
|
|||
if(std::find(names_requested.begin(), names_requested.end(), owner_id) == names_requested.end())
|
||||
{
|
||||
names_requested.push_back(owner_id);
|
||||
gCacheName->get(owner_id, is_group_owned, // username
|
||||
boost::bind(&LLPanelScriptLimitsRegionMemory::onNameCache,
|
||||
this, _1, _2));
|
||||
if (is_group_owned)
|
||||
{
|
||||
gCacheName->getGroup(owner_id,
|
||||
boost::bind(&LLPanelScriptLimitsRegionMemory::onNameCache,
|
||||
this, _1, _2));
|
||||
}
|
||||
else
|
||||
{
|
||||
LLAvatarNameCache::get(owner_id,
|
||||
boost::bind(&LLPanelScriptLimitsRegionMemory::onAvatarNameCache,
|
||||
this, _1, _2));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -38,6 +38,7 @@
|
|||
|
||||
class LLPanelScriptLimitsInfo;
|
||||
class LLTabContainer;
|
||||
class LLAvatarName;
|
||||
|
||||
class LLPanelScriptLimitsRegionMemory;
|
||||
|
||||
|
|
@ -116,6 +117,8 @@ public:
|
|||
void checkButtonsEnabled();
|
||||
|
||||
private:
|
||||
void onAvatarNameCache(const LLUUID& id,
|
||||
const LLAvatarName& av_name);
|
||||
void onNameCache(const LLUUID& id,
|
||||
const std::string& name);
|
||||
|
||||
|
|
|
|||
|
|
@ -653,10 +653,6 @@ void LLFloaterSnapshot::Impl::setFinished(bool finished, bool ok, const std::str
|
|||
LLUICtrl* finished_lbl = mFloater->getChild<LLUICtrl>(ok ? "succeeded_lbl" : "failed_lbl");
|
||||
std::string result_text = mFloater->getString(msg + "_" + (ok ? "succeeded_str" : "failed_str"));
|
||||
finished_lbl->setValue(result_text);
|
||||
|
||||
LLSideTrayPanelContainer* panel_container = mFloater->getChild<LLSideTrayPanelContainer>("panel_container");
|
||||
panel_container->openPreviousPanel();
|
||||
panel_container->getCurrentPanel()->onOpen(LLSD());
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -36,6 +36,7 @@
|
|||
#include "llagentdata.h"
|
||||
#include "llagentui.h"
|
||||
#include "llagentwearables.h"
|
||||
#include "llavatarnamecache.h"
|
||||
#include "llfloatertools.h" // for gFloaterTool
|
||||
#include "llhudeffecttrail.h"
|
||||
#include "llhudmanager.h"
|
||||
|
|
@ -306,32 +307,36 @@ bool LLGiveInventory::doGiveInventoryCategory(const LLUUID& to_agent,
|
|||
//////////////////////////////////////////////////////////////////////////
|
||||
|
||||
//static
|
||||
void LLGiveInventory::logInventoryOffer(const LLUUID& to_agent, const LLUUID &im_session_id)
|
||||
void LLGiveInventory::logInventoryOffer(const LLUUID& to_agent, const LLUUID &im_session_id, const std::string& item_name, bool is_folder)
|
||||
{
|
||||
// compute id of possible IM session with agent that has "to_agent" id
|
||||
LLUUID session_id = LLIMMgr::computeSessionID(IM_NOTHING_SPECIAL, to_agent);
|
||||
// If this item was given by drag-and-drop into an IM panel, log this action in the IM panel chat.
|
||||
LLSD args;
|
||||
args["user_id"] = to_agent;
|
||||
args["ITEM_NAME"] = item_name;
|
||||
std::string message_name = is_folder ? "inventory_folder_offered" : "inventory_item_offered";
|
||||
if (im_session_id.notNull())
|
||||
{
|
||||
gIMMgr->addSystemMessage(im_session_id, "inventory_item_offered", args);
|
||||
gIMMgr->addSystemMessage(im_session_id, message_name, args);
|
||||
}
|
||||
// If this item was given by drag-and-drop on avatar while IM panel was open, log this action in the IM panel chat.
|
||||
else if (LLIMModel::getInstance()->findIMSession(session_id))
|
||||
{
|
||||
gIMMgr->addSystemMessage(session_id, "inventory_item_offered", args);
|
||||
gIMMgr->addSystemMessage(session_id, message_name, args);
|
||||
}
|
||||
// If this item was given by drag-and-drop on avatar while IM panel wasn't open, log this action to IM history.
|
||||
else
|
||||
{
|
||||
std::string full_name;
|
||||
if (gCacheName->getFullName(to_agent, full_name))
|
||||
LLAvatarName av_name;
|
||||
if (LLAvatarNameCache::get(to_agent, &av_name))
|
||||
{
|
||||
// Build a new format username or firstname_lastname for legacy names
|
||||
// to use it for a history log filename.
|
||||
full_name = LLCacheName::buildUsername(full_name);
|
||||
LLIMModel::instance().logToFile(full_name, LLTrans::getString("SECOND_LIFE"), im_session_id, LLTrans::getString("inventory_item_offered-im"));
|
||||
std::string full_name = LLCacheName::buildUsername(av_name.getUserName());
|
||||
LLUIString message = LLTrans::getString(message_name + "-im");
|
||||
message.setArgs(args);
|
||||
LLIMModel::instance().logToFile(full_name, LLTrans::getString("SECOND_LIFE"), im_session_id, message.getString());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -385,6 +390,7 @@ void LLGiveInventory::commitGiveInventoryItem(const LLUUID& to_agent,
|
|||
{
|
||||
if (!item) return;
|
||||
std::string name;
|
||||
std::string item_name = item->getName();
|
||||
LLAgentUI::buildFullname(name);
|
||||
LLUUID transaction_id;
|
||||
transaction_id.generate();
|
||||
|
|
@ -399,7 +405,7 @@ void LLGiveInventory::commitGiveInventoryItem(const LLUUID& to_agent,
|
|||
gAgentSessionID,
|
||||
to_agent,
|
||||
name,
|
||||
item->getName(),
|
||||
item_name,
|
||||
IM_ONLINE,
|
||||
IM_INVENTORY_OFFERED,
|
||||
transaction_id,
|
||||
|
|
@ -421,7 +427,7 @@ void LLGiveInventory::commitGiveInventoryItem(const LLUUID& to_agent,
|
|||
|
||||
LLMuteList::getInstance()->autoRemove(to_agent, LLMuteList::AR_INVENTORY);
|
||||
|
||||
logInventoryOffer(to_agent, im_session_id);
|
||||
logInventoryOffer(to_agent, im_session_id, item_name);
|
||||
|
||||
// add buddy to recent people list
|
||||
LLRecentPeople::instance().add(to_agent);
|
||||
|
|
@ -501,7 +507,7 @@ bool LLGiveInventory::commitGiveInventoryCategory(const LLUUID& to_agent,
|
|||
items,
|
||||
LLInventoryModel::EXCLUDE_TRASH,
|
||||
giveable);
|
||||
|
||||
std::string cat_name = cat->getName();
|
||||
bool give_successful = true;
|
||||
// MAX ITEMS is based on (sizeof(uuid)+2) * count must be <
|
||||
// MTUBYTES or 18 * count < 1200 => count < 1200/18 =>
|
||||
|
|
@ -556,7 +562,7 @@ bool LLGiveInventory::commitGiveInventoryCategory(const LLUUID& to_agent,
|
|||
gAgent.getSessionID(),
|
||||
to_agent,
|
||||
name,
|
||||
cat->getName(),
|
||||
cat_name,
|
||||
IM_ONLINE,
|
||||
IM_INVENTORY_OFFERED,
|
||||
transaction_id,
|
||||
|
|
@ -579,7 +585,7 @@ bool LLGiveInventory::commitGiveInventoryCategory(const LLUUID& to_agent,
|
|||
|
||||
LLMuteList::getInstance()->autoRemove(to_agent, LLMuteList::AR_INVENTORY);
|
||||
|
||||
logInventoryOffer(to_agent, im_session_id);
|
||||
logInventoryOffer(to_agent, im_session_id, cat_name, true);
|
||||
}
|
||||
|
||||
return give_successful;
|
||||
|
|
|
|||
|
|
@ -78,7 +78,9 @@ private:
|
|||
* logs "Inventory item offered" to IM
|
||||
*/
|
||||
static void logInventoryOffer(const LLUUID& to_agent,
|
||||
const LLUUID &im_session_id = LLUUID::null);
|
||||
const LLUUID &im_session_id = LLUUID::null,
|
||||
const std::string& item_name = std::string(),
|
||||
bool is_folder = false);
|
||||
|
||||
static void commitGiveInventoryItem(const LLUUID& to_agent,
|
||||
const LLInventoryItem* item,
|
||||
|
|
|
|||
|
|
@ -38,6 +38,7 @@
|
|||
|
||||
#include "llappviewer.h"
|
||||
#include "llagent.h"
|
||||
#include "llavatarnamecache.h"
|
||||
#include "llui.h"
|
||||
#include "message.h"
|
||||
#include "roles_constants.h"
|
||||
|
|
@ -54,6 +55,7 @@
|
|||
#include <boost/regex.hpp>
|
||||
#include "llcorehttputil.h"
|
||||
|
||||
|
||||
#if LL_MSVC
|
||||
#pragma warning(push)
|
||||
// disable boost::lexical_cast warning
|
||||
|
|
@ -819,9 +821,9 @@ void LLGroupMgrGroupData::banMemberById(const LLUUID& participant_uuid)
|
|||
LLGroupMgr::getInstance()->sendGroupMemberEjects(mID, ids);
|
||||
LLGroupMgr::getInstance()->sendGroupMembersRequest(mID);
|
||||
LLSD args;
|
||||
std::string name;
|
||||
gCacheName->getFullName(participant_uuid, name);
|
||||
args["AVATAR_NAME"] = name;
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(participant_uuid, &av_name);
|
||||
args["AVATAR_NAME"] = av_name.getUserName();
|
||||
args["GROUP_NAME"] = mName;
|
||||
LLNotifications::instance().add(LLNotification::Params("EjectAvatarFromGroup").substitutions(args));
|
||||
}
|
||||
|
|
|
|||
|
|
@ -646,6 +646,7 @@ void LLIMModel::LLIMSession::onVoiceChannelStateChanged(const LLVoiceChannel::ES
|
|||
std::string you_joined_call = LLTrans::getString("you_joined_call");
|
||||
std::string you_started_call = LLTrans::getString("you_started_call");
|
||||
std::string other_avatar_name = "";
|
||||
LLAvatarName av_name;
|
||||
|
||||
std::string message;
|
||||
|
||||
|
|
@ -655,7 +656,8 @@ void LLIMModel::LLIMSession::onVoiceChannelStateChanged(const LLVoiceChannel::ES
|
|||
// no text notifications
|
||||
break;
|
||||
case P2P_SESSION:
|
||||
gCacheName->getFullName(mOtherParticipantID, other_avatar_name); // voice
|
||||
LLAvatarNameCache::get(mOtherParticipantID, &av_name);
|
||||
other_avatar_name = av_name.getUserName();
|
||||
|
||||
if(direction == LLVoiceChannel::INCOMING_CALL)
|
||||
{
|
||||
|
|
@ -806,7 +808,7 @@ void LLIMModel::LLIMSession::addMessagesFromHistory(const std::list<LLSD>& histo
|
|||
{
|
||||
// convert it to a legacy name if we have a complete name
|
||||
std::string legacy_name = gCacheName->buildLegacyName(from);
|
||||
gCacheName->getUUID(legacy_name, from_id);
|
||||
from_id = LLAvatarNameCache::findIdByName(legacy_name);
|
||||
}
|
||||
|
||||
std::string timestamp = msg[LL_IM_TIME];
|
||||
|
|
@ -2765,10 +2767,10 @@ void LLIMMgr::addSystemMessage(const LLUUID& session_id, const std::string& mess
|
|||
|
||||
else
|
||||
{
|
||||
std::string session_name;
|
||||
LLAvatarName av_name;
|
||||
// since we select user to share item with - his name is already in cache
|
||||
gCacheName->getFullName(args["user_id"], session_name);
|
||||
session_name = LLCacheName::buildUsername(session_name);
|
||||
LLAvatarNameCache::get(args["user_id"], &av_name);
|
||||
std::string session_name = LLCacheName::buildUsername(av_name.getUserName());
|
||||
LLIMModel::instance().logToFile(session_name, SYSTEM_FROM, LLUUID::null, message.getString());
|
||||
}
|
||||
}
|
||||
|
|
@ -3075,8 +3077,8 @@ void LLIMMgr::inviteToSession(
|
|||
{
|
||||
if (caller_name.empty())
|
||||
{
|
||||
gCacheName->get(caller_id, false, // voice
|
||||
boost::bind(&LLIMMgr::onInviteNameLookup, payload, _1, _2, _3));
|
||||
LLAvatarNameCache::get(caller_id,
|
||||
boost::bind(&LLIMMgr::onInviteNameLookup, payload, _1, _2));
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -3095,9 +3097,9 @@ void LLIMMgr::inviteToSession(
|
|||
}
|
||||
}
|
||||
|
||||
void LLIMMgr::onInviteNameLookup(LLSD payload, const LLUUID& id, const std::string& name, bool is_group)
|
||||
void LLIMMgr::onInviteNameLookup(LLSD payload, const LLUUID& id, const LLAvatarName& av_name)
|
||||
{
|
||||
payload["caller_name"] = name;
|
||||
payload["caller_name"] = av_name.getUserName();
|
||||
payload["session_name"] = payload["caller_name"].asString();
|
||||
|
||||
std::string notify_box_type = payload["notify_box_type"].asString();
|
||||
|
|
|
|||
|
|
@ -473,7 +473,7 @@ private:
|
|||
|
||||
void processIMTypingCore(const LLIMInfo* im_info, BOOL typing);
|
||||
|
||||
static void onInviteNameLookup(LLSD payload, const LLUUID& id, const std::string& name, bool is_group);
|
||||
static void onInviteNameLookup(LLSD payload, const LLUUID& id, const LLAvatarName& name);
|
||||
|
||||
void notifyObserverSessionAdded(const LLUUID& session_id, const std::string& name, const LLUUID& other_participant_id, bool has_offline_msg);
|
||||
//Triggers when a session has already been added
|
||||
|
|
|
|||
|
|
@ -275,8 +275,10 @@ BOOL LLInvFVBridge::cutToClipboard()
|
|||
if (cut_from_marketplacelistings && (LLMarketplaceData::instance().isInActiveFolder(mUUID) ||
|
||||
LLMarketplaceData::instance().isListedAndActive(mUUID)))
|
||||
{
|
||||
// Prompt the user if cutting from a marketplace active listing
|
||||
LLNotificationsUtil::add("ConfirmMerchantActiveChange", LLSD(), LLSD(), boost::bind(&LLInvFVBridge::callback_cutToClipboard, this, _1, _2));
|
||||
LLUUID parent_uuid = obj->getParentUUID();
|
||||
BOOL result = perform_cutToClipboard();
|
||||
gInventory.addChangedMask(LLInventoryObserver::STRUCTURE, parent_uuid);
|
||||
return result;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -303,11 +305,7 @@ BOOL LLInvFVBridge::callback_cutToClipboard(const LLSD& notification, const LLSD
|
|||
S32 option = LLNotificationsUtil::getSelectedOption(notification, response);
|
||||
if (option == 0) // YES
|
||||
{
|
||||
const LLInventoryObject* obj = gInventory.getObject(mUUID);
|
||||
LLUUID parent_uuid = obj->getParentUUID();
|
||||
BOOL result = perform_cutToClipboard();
|
||||
gInventory.addChangedMask(LLInventoryObserver::STRUCTURE, parent_uuid);
|
||||
return result;
|
||||
return perform_cutToClipboard();
|
||||
}
|
||||
return FALSE;
|
||||
}
|
||||
|
|
@ -3471,7 +3469,24 @@ void LLFolderBridge::pasteFromClipboard()
|
|||
const LLUUID &marketplacelistings_id = model->findCategoryUUIDForType(LLFolderType::FT_MARKETPLACE_LISTINGS, false);
|
||||
const BOOL paste_into_marketplacelistings = model->isObjectDescendentOf(mUUID, marketplacelistings_id);
|
||||
|
||||
if (paste_into_marketplacelistings && !LLMarketplaceData::instance().isListed(mUUID) && LLMarketplaceData::instance().isInActiveFolder(mUUID))
|
||||
BOOL cut_from_marketplacelistings = FALSE;
|
||||
if (LLClipboard::instance().isCutMode())
|
||||
{
|
||||
//Items are not removed from folder on "cut", so we need update listing folder on "paste" operation
|
||||
std::vector<LLUUID> objects;
|
||||
LLClipboard::instance().pasteFromClipboard(objects);
|
||||
for (std::vector<LLUUID>::const_iterator iter = objects.begin(); iter != objects.end(); ++iter)
|
||||
{
|
||||
const LLUUID& item_id = (*iter);
|
||||
if(gInventory.isObjectDescendentOf(item_id, marketplacelistings_id) && (LLMarketplaceData::instance().isInActiveFolder(item_id) ||
|
||||
LLMarketplaceData::instance().isListedAndActive(item_id)))
|
||||
{
|
||||
cut_from_marketplacelistings = TRUE;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (cut_from_marketplacelistings || (paste_into_marketplacelistings && !LLMarketplaceData::instance().isListed(mUUID) && LLMarketplaceData::instance().isInActiveFolder(mUUID)))
|
||||
{
|
||||
// Prompt the user if pasting in a marketplace active version listing (note that pasting right under the listing folder root doesn't need a prompt)
|
||||
LLNotificationsUtil::add("ConfirmMerchantActiveChange", LLSD(), LLSD(), boost::bind(&LLFolderBridge::callback_pasteFromClipboard, this, _1, _2));
|
||||
|
|
@ -3490,7 +3505,20 @@ void LLFolderBridge::callback_pasteFromClipboard(const LLSD& notification, const
|
|||
S32 option = LLNotificationsUtil::getSelectedOption(notification, response);
|
||||
if (option == 0) // YES
|
||||
{
|
||||
std::vector<LLUUID> objects;
|
||||
std::set<LLUUID> parent_folders;
|
||||
LLClipboard::instance().pasteFromClipboard(objects);
|
||||
for (std::vector<LLUUID>::const_iterator iter = objects.begin(); iter != objects.end(); ++iter)
|
||||
{
|
||||
const LLInventoryObject* obj = gInventory.getObject(*iter);
|
||||
parent_folders.insert(obj->getParentUUID());
|
||||
}
|
||||
perform_pasteFromClipboard();
|
||||
for (std::set<LLUUID>::const_iterator iter = parent_folders.begin(); iter != parent_folders.end(); ++iter)
|
||||
{
|
||||
gInventory.addChangedMask(LLInventoryObserver::STRUCTURE, *iter);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -3913,6 +3941,37 @@ void LLFolderBridge::buildContextMenuOptions(U32 flags, menuentry_vec_t& items
|
|||
mWearables=TRUE;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
// Mark wearables and allow copy from library
|
||||
LLInventoryModel* model = getInventoryModel();
|
||||
if(!model) return;
|
||||
const LLInventoryCategory* category = model->getCategory(mUUID);
|
||||
if (!category) return;
|
||||
LLFolderType::EType type = category->getPreferredType();
|
||||
const bool is_system_folder = LLFolderType::lookupIsProtectedType(type);
|
||||
|
||||
LLFindWearables is_wearable;
|
||||
LLIsType is_object(LLAssetType::AT_OBJECT);
|
||||
LLIsType is_gesture(LLAssetType::AT_GESTURE);
|
||||
|
||||
if (checkFolderForContentsOfType(model, is_wearable) ||
|
||||
checkFolderForContentsOfType(model, is_object) ||
|
||||
checkFolderForContentsOfType(model, is_gesture))
|
||||
{
|
||||
mWearables = TRUE;
|
||||
}
|
||||
|
||||
if (!is_system_folder)
|
||||
{
|
||||
items.push_back(std::string("Copy"));
|
||||
if (!isItemCopyable())
|
||||
{
|
||||
// For some reason there are items in library that can't be copied directly
|
||||
disabled_items.push_back(std::string("Copy"));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Preemptively disable system folder removal if more than one item selected.
|
||||
if ((flags & FIRST_SELECTED_ITEM) == 0)
|
||||
|
|
@ -3920,7 +3979,7 @@ void LLFolderBridge::buildContextMenuOptions(U32 flags, menuentry_vec_t& items
|
|||
disabled_items.push_back(std::string("Delete System Folder"));
|
||||
}
|
||||
|
||||
if (!isMarketplaceListingsFolder())
|
||||
if (isAgentInventory() && !isMarketplaceListingsFolder())
|
||||
{
|
||||
items.push_back(std::string("Share"));
|
||||
if (!canShare())
|
||||
|
|
@ -3928,6 +3987,9 @@ void LLFolderBridge::buildContextMenuOptions(U32 flags, menuentry_vec_t& items
|
|||
disabled_items.push_back(std::string("Share"));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
// Add menu items that are dependent on the contents of the folder.
|
||||
LLViewerInventoryCategory* category = (LLViewerInventoryCategory *) model->getCategory(mUUID);
|
||||
if (category && (marketplace_listings_id != mUUID))
|
||||
|
|
@ -3965,7 +4027,6 @@ void LLFolderBridge::buildContextMenuFolderOptions(U32 flags, menuentry_vec_t&
|
|||
const LLUUID trash_id = model->findCategoryUUIDForType(LLFolderType::FT_TRASH);
|
||||
if (trash_id == mUUID) return;
|
||||
if (isItemInTrash()) return;
|
||||
if (!isAgentInventory()) return;
|
||||
|
||||
if (!isItemRemovable())
|
||||
{
|
||||
|
|
@ -3978,9 +4039,10 @@ void LLFolderBridge::buildContextMenuFolderOptions(U32 flags, menuentry_vec_t&
|
|||
// BAP change once we're no longer treating regular categories as ensembles.
|
||||
const bool is_ensemble = (type == LLFolderType::FT_NONE ||
|
||||
LLFolderType::lookupIsEnsembleType(type));
|
||||
const bool is_agent_inventory = isAgentInventory();
|
||||
|
||||
// Only enable calling-card related options for non-system folders.
|
||||
if (!is_system_folder)
|
||||
if (!is_system_folder && is_agent_inventory)
|
||||
{
|
||||
LLIsType is_callingcard(LLAssetType::AT_CALLINGCARD);
|
||||
if (mCallingCards || checkFolderForContentsOfType(model, is_callingcard))
|
||||
|
|
@ -3992,7 +4054,7 @@ void LLFolderBridge::buildContextMenuFolderOptions(U32 flags, menuentry_vec_t&
|
|||
}
|
||||
|
||||
#ifndef LL_RELEASE_FOR_DOWNLOAD
|
||||
if (LLFolderType::lookupIsProtectedType(type))
|
||||
if (LLFolderType::lookupIsProtectedType(type) && is_agent_inventory)
|
||||
{
|
||||
items.push_back(std::string("Delete System Folder"));
|
||||
}
|
||||
|
|
@ -4009,8 +4071,6 @@ void LLFolderBridge::buildContextMenuFolderOptions(U32 flags, menuentry_vec_t&
|
|||
checkFolderForContentsOfType(model, is_object) ||
|
||||
checkFolderForContentsOfType(model, is_gesture) )
|
||||
{
|
||||
items.push_back(std::string("Folder Wearables Separator"));
|
||||
|
||||
// Only enable add/replace outfit for non-system folders.
|
||||
if (!is_system_folder)
|
||||
{
|
||||
|
|
@ -4021,25 +4081,30 @@ void LLFolderBridge::buildContextMenuFolderOptions(U32 flags, menuentry_vec_t&
|
|||
}
|
||||
|
||||
items.push_back(std::string("Replace Outfit"));
|
||||
|
||||
if (is_agent_inventory)
|
||||
{
|
||||
items.push_back(std::string("Folder Wearables Separator"));
|
||||
if (is_ensemble)
|
||||
{
|
||||
items.push_back(std::string("Wear As Ensemble"));
|
||||
}
|
||||
items.push_back(std::string("Remove From Outfit"));
|
||||
if (!LLAppearanceMgr::getCanRemoveFromCOF(mUUID))
|
||||
{
|
||||
disabled_items.push_back(std::string("Remove From Outfit"));
|
||||
}
|
||||
}
|
||||
if (!LLAppearanceMgr::instance().getCanReplaceCOF(mUUID))
|
||||
{
|
||||
disabled_items.push_back(std::string("Replace Outfit"));
|
||||
}
|
||||
if (!LLAppearanceMgr::instance().getCanAddToCOF(mUUID))
|
||||
{
|
||||
disabled_items.push_back(std::string("Add To Outfit"));
|
||||
}
|
||||
items.push_back(std::string("Outfit Separator"));
|
||||
}
|
||||
if (is_ensemble)
|
||||
{
|
||||
items.push_back(std::string("Wear As Ensemble"));
|
||||
}
|
||||
items.push_back(std::string("Remove From Outfit"));
|
||||
if (!LLAppearanceMgr::getCanRemoveFromCOF(mUUID))
|
||||
{
|
||||
disabled_items.push_back(std::string("Remove From Outfit"));
|
||||
}
|
||||
if (!LLAppearanceMgr::instance().getCanReplaceCOF(mUUID))
|
||||
{
|
||||
disabled_items.push_back(std::string("Replace Outfit"));
|
||||
}
|
||||
if (!LLAppearanceMgr::instance().getCanAddToCOF(mUUID))
|
||||
{
|
||||
disabled_items.push_back(std::string("Add To Outfit"));
|
||||
}
|
||||
items.push_back(std::string("Outfit Separator"));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -4276,9 +4341,18 @@ void LLFolderBridge::modifyOutfit(BOOL append)
|
|||
return;
|
||||
}
|
||||
|
||||
LLAppearanceMgr::instance().wearInventoryCategory( cat, FALSE, append );
|
||||
if (isAgentInventory())
|
||||
{
|
||||
LLAppearanceMgr::instance().wearInventoryCategory(cat, FALSE, append);
|
||||
}
|
||||
else
|
||||
{
|
||||
// Library, we need to copy content first
|
||||
LLAppearanceMgr::instance().wearInventoryCategory(cat, TRUE, append);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// +=================================================+
|
||||
// | LLMarketplaceFolderBridge |
|
||||
// +=================================================+
|
||||
|
|
|
|||
|
|
@ -61,6 +61,11 @@ public:
|
|||
*/
|
||||
void setForceRefresh(bool force_refresh){ mForceRefresh = force_refresh; }
|
||||
|
||||
/**
|
||||
* If refreshes when invisible.
|
||||
*/
|
||||
bool getForceRefresh(){ return mForceRefresh; }
|
||||
|
||||
virtual bool selectItemByValue(const LLSD& value, bool select = true);
|
||||
|
||||
void updateSelection();
|
||||
|
|
|
|||
|
|
@ -182,10 +182,10 @@ void LLPanelInventoryListItemBase::setValue(const LLSD& value)
|
|||
mSelected = value["selected"];
|
||||
}
|
||||
|
||||
void LLPanelInventoryListItemBase::onMouseEnter(S32 x, S32 y, MASK mask)
|
||||
BOOL LLPanelInventoryListItemBase::handleHover(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
mHovered = true;
|
||||
LLPanel::onMouseEnter(x, y, mask);
|
||||
return LLPanel::handleHover(x, y, mask);
|
||||
}
|
||||
|
||||
void LLPanelInventoryListItemBase::onMouseLeave(S32 x, S32 y, MASK mask)
|
||||
|
|
|
|||
|
|
@ -129,8 +129,8 @@ public:
|
|||
*/
|
||||
/*virtual*/ S32 notify(const LLSD& info);
|
||||
|
||||
/* Highlights item */
|
||||
/*virtual*/ void onMouseEnter(S32 x, S32 y, MASK mask);
|
||||
/* Highlights item */
|
||||
/*virtual*/ BOOL handleHover(S32 x, S32 y, MASK mask);
|
||||
/* Removes item highlight */
|
||||
/*virtual*/ void onMouseLeave(S32 x, S32 y, MASK mask);
|
||||
|
||||
|
|
@ -153,6 +153,7 @@ public:
|
|||
LLViewerInventoryItem* getItem() const;
|
||||
|
||||
void setSeparatorVisible(bool visible) { mSeparatorVisible = visible; }
|
||||
void resetHighlight() { mHovered = FALSE; }
|
||||
|
||||
virtual ~LLPanelInventoryListItemBase(){}
|
||||
|
||||
|
|
|
|||
|
|
@ -34,6 +34,7 @@
|
|||
#include "llagent.h"
|
||||
#include "llagentwearables.h"
|
||||
#include "llappearancemgr.h"
|
||||
#include "llavatarnamecache.h"
|
||||
#include "llclipboard.h"
|
||||
#include "llinventorypanel.h"
|
||||
#include "llinventorybridge.h"
|
||||
|
|
@ -1022,19 +1023,19 @@ U32 LLInventoryModel::updateItem(const LLViewerInventoryItem* item, U32 mask)
|
|||
{
|
||||
// Valid UUID; set the item UUID and rename it
|
||||
new_item->setCreator(id);
|
||||
std::string avatar_name;
|
||||
LLAvatarName av_name;
|
||||
|
||||
if (gCacheName->getFullName(id, avatar_name))
|
||||
if (LLAvatarNameCache::get(id, &av_name))
|
||||
{
|
||||
new_item->rename(avatar_name);
|
||||
new_item->rename(av_name.getUserName());
|
||||
mask |= LLInventoryObserver::LABEL;
|
||||
}
|
||||
else
|
||||
{
|
||||
// Fetch the current name
|
||||
gCacheName->get(id, FALSE,
|
||||
LLAvatarNameCache::get(id,
|
||||
boost::bind(&LLViewerInventoryItem::onCallingCardNameLookup, new_item.get(),
|
||||
_1, _2, _3));
|
||||
_1, _2));
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
|
|
@ -360,9 +360,12 @@ void LLInventoryModelBackgroundFetch::incrFetchCount(S32 fetching)
|
|||
}
|
||||
}
|
||||
|
||||
static LLTrace::BlockTimerStatHandle FTM_BULK_FETCH("Bulk Fetch");
|
||||
|
||||
// Bundle up a bunch of requests to send all at once.
|
||||
void LLInventoryModelBackgroundFetch::bulkFetch()
|
||||
{
|
||||
LL_RECORD_BLOCK_TIME(FTM_BULK_FETCH);
|
||||
//Background fetch is called from gIdleCallbacks in a loop until background fetch is stopped.
|
||||
//If there are items in mFetchQueue, we want to check the time since the last bulkFetch was
|
||||
//sent. If it exceeds our retry time, go ahead and fire off another batch.
|
||||
|
|
|
|||
|
|
@ -121,7 +121,6 @@ namespace {
|
|||
{
|
||||
// Prompt the user with the warning (so they know why things are failing)
|
||||
LLSD subs;
|
||||
subs["[ERROR_REASON]"] = reason;
|
||||
// We do show long descriptions in the alert (unlikely to be readable). The description string will be in the log though.
|
||||
std::string description;
|
||||
if (result.has(LLCoreHttpUtil::HttpCoroutineAdapter::HTTP_RESULTS_CONTENT))
|
||||
|
|
@ -145,6 +144,16 @@ namespace {
|
|||
{
|
||||
description = result.asString();
|
||||
}
|
||||
std::string reason_lc = reason;
|
||||
LLStringUtil::toLower(reason_lc);
|
||||
if (!description.empty() && reason_lc.find("unknown") != std::string::npos)
|
||||
{
|
||||
subs["[ERROR_REASON]"] = "";
|
||||
}
|
||||
else
|
||||
{
|
||||
subs["[ERROR_REASON]"] = "'" + reason +"'\n";
|
||||
}
|
||||
subs["[ERROR_DESCRIPTION]"] = description;
|
||||
LLNotificationsUtil::add("MerchantTransactionFailed", subs);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -730,9 +730,16 @@ void LLPanelStandStopFlying::updatePosition()
|
|||
panel_ssf_container->setOrigin(0, y_pos);
|
||||
}
|
||||
|
||||
S32 x_pos = bottom_tb_center-getRect().getWidth()/2 - left_tb_width;
|
||||
|
||||
setOrigin( x_pos, 0);
|
||||
if (gToolBarView != NULL && gToolBarView->getToolbar(LLToolBarEnums::TOOLBAR_LEFT)->hasButtons())
|
||||
{
|
||||
S32 x_pos = bottom_tb_center - getRect().getWidth() / 2 - left_tb_width;
|
||||
setOrigin( x_pos, 0);
|
||||
}
|
||||
else
|
||||
{
|
||||
S32 x_pos = bottom_tb_center - getRect().getWidth() / 2;
|
||||
setOrigin( x_pos, 0);
|
||||
}
|
||||
}
|
||||
|
||||
// EOF
|
||||
|
|
|
|||
|
|
@ -53,6 +53,7 @@
|
|||
#include "llxfermanager.h"
|
||||
|
||||
#include "llagent.h"
|
||||
#include "llavatarnamecache.h"
|
||||
#include "llviewergenericmessage.h" // for gGenericDispatcher
|
||||
#include "llworld.h" //for particle system banning
|
||||
#include "llimview.h"
|
||||
|
|
@ -456,7 +457,7 @@ void LLMuteList::updateRemove(const LLMute& mute)
|
|||
gAgent.sendReliableMessage();
|
||||
}
|
||||
|
||||
void notify_automute_callback(const LLUUID& agent_id, const std::string& full_name, bool is_group, LLMuteList::EAutoReason reason)
|
||||
void notify_automute_callback(const LLUUID& agent_id, const LLAvatarName& full_name, LLMuteList::EAutoReason reason)
|
||||
{
|
||||
std::string notif_name;
|
||||
switch (reason)
|
||||
|
|
@ -474,7 +475,7 @@ void notify_automute_callback(const LLUUID& agent_id, const std::string& full_na
|
|||
}
|
||||
|
||||
LLSD args;
|
||||
args["NAME"] = full_name;
|
||||
args["NAME"] = full_name.getUserName();
|
||||
|
||||
LLNotificationPtr notif_ptr = LLNotifications::instance().add(notif_name, args, LLSD());
|
||||
if (notif_ptr)
|
||||
|
|
@ -499,17 +500,17 @@ BOOL LLMuteList::autoRemove(const LLUUID& agent_id, const EAutoReason reason)
|
|||
removed = TRUE;
|
||||
remove(automute);
|
||||
|
||||
std::string full_name;
|
||||
if (gCacheName->getFullName(agent_id, full_name))
|
||||
{
|
||||
// name in cache, call callback directly
|
||||
notify_automute_callback(agent_id, full_name, false, reason);
|
||||
}
|
||||
else
|
||||
{
|
||||
// not in cache, lookup name from cache
|
||||
gCacheName->get(agent_id, false,
|
||||
boost::bind(¬ify_automute_callback, _1, _2, _3, reason));
|
||||
LLAvatarName av_name;
|
||||
if (LLAvatarNameCache::get(agent_id, &av_name))
|
||||
{
|
||||
// name in cache, call callback directly
|
||||
notify_automute_callback(agent_id, av_name, reason);
|
||||
}
|
||||
else
|
||||
{
|
||||
// not in cache, lookup name from cache
|
||||
LLAvatarNameCache::get(agent_id,
|
||||
boost::bind(¬ify_automute_callback, _1, _2, reason));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -811,3 +812,99 @@ void LLMuteList::notifyObserversDetailed(const LLMute& mute)
|
|||
it = mObservers.upper_bound(observer);
|
||||
}
|
||||
}
|
||||
|
||||
LLRenderMuteList::LLRenderMuteList()
|
||||
{}
|
||||
|
||||
bool LLRenderMuteList::saveToFile()
|
||||
{
|
||||
std::string filename = gDirUtilp->getExpandedFilename(LL_PATH_PER_SL_ACCOUNT, "render_mute_settings.txt");
|
||||
LLFILE* fp = LLFile::fopen(filename, "wb");
|
||||
if (!fp)
|
||||
{
|
||||
LL_WARNS() << "Couldn't open render mute list file: " << filename << LL_ENDL;
|
||||
return false;
|
||||
}
|
||||
for (std::map<LLUUID, S32>::iterator it = sVisuallyMuteSettingsMap.begin(); it != sVisuallyMuteSettingsMap.end(); ++it)
|
||||
{
|
||||
if (it->second != 0)
|
||||
{
|
||||
std::string id_string;
|
||||
it->first.toString(id_string);
|
||||
fprintf(fp, "%d %s\n", (S32)it->second, id_string.c_str());
|
||||
}
|
||||
}
|
||||
fclose(fp);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool LLRenderMuteList::loadFromFile()
|
||||
{
|
||||
std::string filename = gDirUtilp->getExpandedFilename(LL_PATH_PER_SL_ACCOUNT, "render_mute_settings.txt");
|
||||
LLFILE* fp = LLFile::fopen(filename, "rb");
|
||||
if (!fp)
|
||||
{
|
||||
LL_WARNS() << "Couldn't open render mute list file: " << filename << LL_ENDL;
|
||||
return false;
|
||||
}
|
||||
|
||||
char id_buffer[MAX_STRING];
|
||||
char buffer[MAX_STRING];
|
||||
while (!feof(fp) && fgets(buffer, MAX_STRING, fp))
|
||||
{
|
||||
id_buffer[0] = '\0';
|
||||
S32 setting = 0;
|
||||
sscanf(buffer, " %d %254s\n", &setting, id_buffer);
|
||||
sVisuallyMuteSettingsMap[LLUUID(id_buffer)] = setting;
|
||||
}
|
||||
fclose(fp);
|
||||
return true;
|
||||
}
|
||||
|
||||
void LLRenderMuteList::saveVisualMuteSetting(const LLUUID& agent_id, S32 setting)
|
||||
{
|
||||
if(setting == 0)
|
||||
{
|
||||
sVisuallyMuteSettingsMap.erase(agent_id);
|
||||
}
|
||||
else
|
||||
{
|
||||
sVisuallyMuteSettingsMap[agent_id] = setting;
|
||||
}
|
||||
saveToFile();
|
||||
notifyObservers();
|
||||
}
|
||||
|
||||
S32 LLRenderMuteList::getSavedVisualMuteSetting(const LLUUID& agent_id)
|
||||
{
|
||||
std::map<LLUUID, S32>::iterator iter = sVisuallyMuteSettingsMap.find(agent_id);
|
||||
if (iter != sVisuallyMuteSettingsMap.end())
|
||||
{
|
||||
return iter->second;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void LLRenderMuteList::addObserver(LLMuteListObserver* observer)
|
||||
{
|
||||
mObservers.insert(observer);
|
||||
}
|
||||
|
||||
void LLRenderMuteList::removeObserver(LLMuteListObserver* observer)
|
||||
{
|
||||
mObservers.erase(observer);
|
||||
}
|
||||
|
||||
void LLRenderMuteList::notifyObservers()
|
||||
{
|
||||
for (observer_set_t::iterator it = mObservers.begin();
|
||||
it != mObservers.end();
|
||||
)
|
||||
{
|
||||
LLMuteListObserver* observer = *it;
|
||||
observer->onChange();
|
||||
// In case onChange() deleted an entry.
|
||||
it = mObservers.upper_bound(observer);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -175,5 +175,25 @@ public:
|
|||
virtual void onChangeDetailed(const LLMute& ) { }
|
||||
};
|
||||
|
||||
class LLRenderMuteList : public LLSingleton<LLRenderMuteList>
|
||||
{
|
||||
LLSINGLETON(LLRenderMuteList);
|
||||
public:
|
||||
bool loadFromFile();
|
||||
bool saveToFile();
|
||||
S32 getSavedVisualMuteSetting(const LLUUID& agent_id);
|
||||
void saveVisualMuteSetting(const LLUUID& agent_id, S32 setting);
|
||||
|
||||
void addObserver(LLMuteListObserver* observer);
|
||||
void removeObserver(LLMuteListObserver* observer);
|
||||
|
||||
std::map<LLUUID, S32> sVisuallyMuteSettingsMap;
|
||||
|
||||
private:
|
||||
void notifyObservers();
|
||||
typedef std::set<LLMuteListObserver*> observer_set_t;
|
||||
observer_set_t mObservers;
|
||||
};
|
||||
|
||||
|
||||
#endif //LL_MUTELIST_H
|
||||
|
|
|
|||
|
|
@ -35,6 +35,7 @@
|
|||
#include "lluuid.h"
|
||||
|
||||
#include "llcachename.h"
|
||||
#include "llavatarnamecache.h"
|
||||
|
||||
// statics
|
||||
std::set<LLNameBox*> LLNameBox::sInstances;
|
||||
|
|
@ -67,7 +68,9 @@ void LLNameBox::setNameID(const LLUUID& name_id, BOOL is_group)
|
|||
|
||||
if (!is_group)
|
||||
{
|
||||
got_name = gCacheName->getFullName(name_id, name);
|
||||
LLAvatarName av_name;
|
||||
got_name = LLAvatarNameCache::get(name_id, &av_name);
|
||||
name = av_name.getUserName();
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
|
|||
|
|
@ -28,6 +28,7 @@
|
|||
|
||||
#include "llnameeditor.h"
|
||||
#include "llcachename.h"
|
||||
#include "llavatarnamecache.h"
|
||||
|
||||
#include "llfontgl.h"
|
||||
|
||||
|
|
@ -65,7 +66,9 @@ void LLNameEditor::setNameID(const LLUUID& name_id, BOOL is_group)
|
|||
|
||||
if (!is_group)
|
||||
{
|
||||
gCacheName->getFullName(name_id, name);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(name_id, &av_name);
|
||||
name = av_name.getUserName();
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
|
|||
|
|
@ -114,11 +114,11 @@ void LLHandlerUtil::logToIM(const EInstantMessage& session_type,
|
|||
}
|
||||
}
|
||||
|
||||
void log_name_callback(const std::string& full_name, const std::string& from_name,
|
||||
void log_name_callback(const LLAvatarName& av_name, const std::string& from_name,
|
||||
const std::string& message, const LLUUID& from_id)
|
||||
|
||||
{
|
||||
LLHandlerUtil::logToIM(IM_NOTHING_SPECIAL, full_name, from_name, message,
|
||||
LLHandlerUtil::logToIM(IM_NOTHING_SPECIAL, av_name.getUserName(), from_name, message,
|
||||
from_id, LLUUID());
|
||||
}
|
||||
|
||||
|
|
@ -141,11 +141,11 @@ void LLHandlerUtil::logToIMP2P(const LLNotificationPtr& notification, bool to_fi
|
|||
|
||||
if(to_file_only)
|
||||
{
|
||||
gCacheName->get(from_id, false, boost::bind(&log_name_callback, _2, "", notification->getMessage(), LLUUID()));
|
||||
LLAvatarNameCache::get(from_id, boost::bind(&log_name_callback, _2, "", notification->getMessage(), LLUUID()));
|
||||
}
|
||||
else
|
||||
{
|
||||
gCacheName->get(from_id, false, boost::bind(&log_name_callback, _2, INTERACTIVE_SYSTEM_FROM, notification->getMessage(), from_id));
|
||||
LLAvatarNameCache::get(from_id, boost::bind(&log_name_callback, _2, INTERACTIVE_SYSTEM_FROM, notification->getMessage(), from_id));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -167,9 +167,18 @@ void LLHandlerUtil::logGroupNoticeToIMGroup(
|
|||
const std::string group_name = groupData.mName;
|
||||
const std::string sender_name = payload["sender_name"].asString();
|
||||
|
||||
// we can't retrieve sender id from group notice system message, so try to lookup it from cache
|
||||
LLUUID sender_id;
|
||||
gCacheName->getUUID(sender_name, sender_id);
|
||||
if (payload.has("sender_id"))
|
||||
{
|
||||
sender_id = payload["sender_id"].asUUID();
|
||||
}
|
||||
|
||||
if (sender_id.notNull())
|
||||
{
|
||||
// Legacy support and fallback method
|
||||
// if we can't retrieve sender id from group notice system message, try to lookup it from cache
|
||||
sender_id = LLAvatarNameCache::findIdByName(sender_name);
|
||||
}
|
||||
|
||||
logToIM(IM_SESSION_GROUP_START, group_name, sender_name, payload["message"],
|
||||
payload["group_id"], sender_id);
|
||||
|
|
@ -219,7 +228,12 @@ std::string LLHandlerUtil::getSubstitutionName(const LLNotificationPtr& notifica
|
|||
{
|
||||
from_id = notification->getPayload()["from_id"];
|
||||
}
|
||||
if(!gCacheName->getFullName(from_id, res))
|
||||
LLAvatarName av_name;
|
||||
if(LLAvatarNameCache::get(from_id, &av_name))
|
||||
{
|
||||
res = av_name.getUserName();
|
||||
}
|
||||
else
|
||||
{
|
||||
res = "";
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1168,9 +1168,9 @@ void LLPanelGroupMembersSubTab::confirmEjectMembers()
|
|||
if (selection_count == 1)
|
||||
{
|
||||
LLSD args;
|
||||
std::string fullname;
|
||||
gCacheName->getFullName(mMembersList->getValue(), fullname);
|
||||
args["AVATAR_NAME"] = fullname;
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(mMembersList->getValue(), &av_name);
|
||||
args["AVATAR_NAME"] = av_name.getUserName();
|
||||
LLSD payload;
|
||||
LLNotificationsUtil::add("EjectGroupMemberWarning",
|
||||
args,
|
||||
|
|
@ -1231,7 +1231,7 @@ void LLPanelGroupMembersSubTab::sendEjectNotifications(const LLUUID& group_id, c
|
|||
for (uuid_vec_t::const_iterator i = selected_members.begin(); i != selected_members.end(); ++i)
|
||||
{
|
||||
LLSD args;
|
||||
args["AVATAR_NAME"] = LLSLURL("agent", *i, "displayname").getSLURLString();
|
||||
args["AVATAR_NAME"] = LLSLURL("agent", *i, "completename").getSLURLString();
|
||||
args["GROUP_NAME"] = group_data->mName;
|
||||
|
||||
LLNotifications::instance().add(LLNotification::Params("EjectAvatarFromGroup").substitutions(args));
|
||||
|
|
@ -1862,9 +1862,9 @@ void LLPanelGroupMembersSubTab::confirmBanMembers()
|
|||
if (selection_count == 1)
|
||||
{
|
||||
LLSD args;
|
||||
std::string fullname;
|
||||
gCacheName->getFullName(mMembersList->getValue(), fullname);
|
||||
args["AVATAR_NAME"] = fullname;
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(mMembersList->getValue(), &av_name);
|
||||
args["AVATAR_NAME"] = av_name.getUserName();
|
||||
LLSD payload;
|
||||
LLNotificationsUtil::add("BanGroupMemberWarning",
|
||||
args,
|
||||
|
|
|
|||
|
|
@ -578,7 +578,6 @@ void LLPanelOutfitEdit::onOpen(const LLSD& key)
|
|||
// *TODO: this method is called even panel is not visible to user because its parent layout panel is hidden.
|
||||
// So, we can defer initializing a bit.
|
||||
mWearableListManager = new LLFilteredWearableListManager(mWearableItemsList, mListViewItemTypes[LVIT_ALL]->collector);
|
||||
mWearableListManager->populateList();
|
||||
displayCurrentOutfit();
|
||||
mInitialized = true;
|
||||
}
|
||||
|
|
@ -632,6 +631,10 @@ void LLPanelOutfitEdit::showAddWearablesPanel(bool show_add_wearables)
|
|||
// Reset mWearableItemsList position to top. See EXT-8180.
|
||||
mWearableItemsList->goToTop();
|
||||
}
|
||||
else
|
||||
{
|
||||
mWearableListManager->populateIfNeeded();
|
||||
}
|
||||
|
||||
//switching button bars
|
||||
getChildView("no_add_wearables_button_bar")->setVisible( !show_add_wearables);
|
||||
|
|
@ -661,6 +664,7 @@ void LLPanelOutfitEdit::showWearablesListView()
|
|||
{
|
||||
updateWearablesPanelVerbButtons();
|
||||
updateFiltersVisibility();
|
||||
mWearableListManager->populateIfNeeded();
|
||||
}
|
||||
mListViewBtn->setToggleState(TRUE);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -384,9 +384,9 @@ void LLPanelPicks::processProperties(void* data, EAvatarProcessorType type)
|
|||
LLAvatarPicks* avatar_picks = static_cast<LLAvatarPicks*>(data);
|
||||
if(avatar_picks && getAvatarId() == avatar_picks->target_id)
|
||||
{
|
||||
std::string full_name;
|
||||
gCacheName->getFullName(getAvatarId(), full_name);
|
||||
getChild<LLUICtrl>("pick_title")->setTextArg("[NAME]", full_name);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(getAvatarId(), &av_name);
|
||||
getChild<LLUICtrl>("pick_title")->setTextArg("[NAME]", av_name.getUserName());
|
||||
|
||||
// Save selection, to be able to edit same item after saving changes. See EXT-3023.
|
||||
LLUUID selected_id = mPicksList->getSelectedValue()[PICK_ID];
|
||||
|
|
|
|||
|
|
@ -168,12 +168,11 @@ void LLPanelSnapshotLocal::onSaveFlyoutCommit(LLUICtrl* ctrl)
|
|||
if (saved)
|
||||
{
|
||||
mSnapshotFloater->postSave();
|
||||
goBack();
|
||||
floater->notify(LLSD().with("set-finished", LLSD().with("ok", true).with("msg", "local")));
|
||||
}
|
||||
else
|
||||
{
|
||||
cancel();
|
||||
floater->notify(LLSD().with("set-finished", LLSD().with("ok", false).with("msg", "local")));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -106,6 +106,14 @@ BOOL LLPanelSnapshotPostcard::postBuild()
|
|||
// virtual
|
||||
void LLPanelSnapshotPostcard::onOpen(const LLSD& key)
|
||||
{
|
||||
LLUICtrl* name_form = getChild<LLUICtrl>("name_form");
|
||||
if (name_form && name_form->getValue().asString().empty())
|
||||
{
|
||||
std::string name_string;
|
||||
LLAgentUI::buildFullname(name_string);
|
||||
getChild<LLUICtrl>("name_form")->setValue(LLSD(name_string));
|
||||
}
|
||||
|
||||
LLPanelSnapshot::onOpen(key);
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -1870,8 +1870,14 @@ void LLLiveLSLEditor::loadAsset()
|
|||
|
||||
if(item)
|
||||
{
|
||||
LLExperienceCache::instance().fetchAssociatedExperience(item->getParentUUID(), item->getUUID(),
|
||||
boost::bind(&LLLiveLSLEditor::setAssociatedExperience, getDerivedHandle<LLLiveLSLEditor>(), _1));
|
||||
LLViewerRegion* region = object->getRegion();
|
||||
std::string url = std::string();
|
||||
if(region)
|
||||
{
|
||||
url = region->getCapability("GetMetadata");
|
||||
}
|
||||
LLExperienceCache::instance().fetchAssociatedExperience(item->getParentUUID(), item->getUUID(), url,
|
||||
boost::bind(&LLLiveLSLEditor::setAssociatedExperience, getDerivedHandle<LLLiveLSLEditor>(), _1));
|
||||
|
||||
bool isGodlike = gAgent.isGodlike();
|
||||
bool copyManipulate = gAgent.allowOperation(PERM_COPY, item->getPermissions(), GP_OBJECT_MANIPULATE);
|
||||
|
|
|
|||
|
|
@ -40,6 +40,7 @@ void LLRegionInfoModel::reset()
|
|||
{
|
||||
mSimAccess = 0;
|
||||
mAgentLimit = 0;
|
||||
mHardAgentLimit = 100;
|
||||
|
||||
mRegionFlags = 0;
|
||||
mEstateID = 0;
|
||||
|
|
@ -143,6 +144,7 @@ void LLRegionInfoModel::update(LLMessageSystem* msg)
|
|||
msg->getU32Fast(_PREHASH_RegionInfo, _PREHASH_ParentEstateID, mParentEstateID);
|
||||
msg->getU8Fast(_PREHASH_RegionInfo, _PREHASH_SimAccess, mSimAccess);
|
||||
msg->getU8Fast(_PREHASH_RegionInfo, _PREHASH_MaxAgents, mAgentLimit);
|
||||
|
||||
msg->getF32Fast(_PREHASH_RegionInfo, _PREHASH_ObjectBonusFactor, mObjectBonusFactor);
|
||||
msg->getF32Fast(_PREHASH_RegionInfo, _PREHASH_BillableFactor, mBillableFactor);
|
||||
msg->getF32Fast(_PREHASH_RegionInfo, _PREHASH_WaterHeight, mWaterHeight);
|
||||
|
|
@ -158,6 +160,8 @@ void LLRegionInfoModel::update(LLMessageSystem* msg)
|
|||
msg->getF32(_PREHASH_RegionInfo, _PREHASH_SunHour, mSunHour);
|
||||
LL_DEBUGS("Windlight Sync") << "Got region sun hour: " << mSunHour << LL_ENDL;
|
||||
|
||||
msg->getS32Fast(_PREHASH_RegionInfo2, _PREHASH_HardMaxAgents, mHardAgentLimit);
|
||||
|
||||
if (msg->has(_PREHASH_RegionInfo3))
|
||||
{
|
||||
msg->getU64Fast(_PREHASH_RegionInfo3, _PREHASH_RegionFlagsExtended, mRegionFlags);
|
||||
|
|
|
|||
|
|
@ -53,6 +53,8 @@ public:
|
|||
U8 mSimAccess;
|
||||
U8 mAgentLimit;
|
||||
|
||||
S32 mHardAgentLimit;
|
||||
|
||||
U64 mRegionFlags;
|
||||
U32 mEstateID;
|
||||
U32 mParentEstateID;
|
||||
|
|
|
|||
|
|
@ -33,6 +33,7 @@
|
|||
|
||||
// library includes
|
||||
#include "llcachename.h"
|
||||
#include "llavatarnamecache.h"
|
||||
#include "lldbstrings.h"
|
||||
#include "lleconomy.h"
|
||||
#include "llgl.h"
|
||||
|
|
@ -613,6 +614,12 @@ bool LLSelectMgr::linkObjects()
|
|||
return true;
|
||||
}
|
||||
|
||||
if (!LLSelectMgr::getInstance()->selectGetSameRegion())
|
||||
{
|
||||
LLNotificationsUtil::add("CannotLinkAcrossRegions");
|
||||
return true;
|
||||
}
|
||||
|
||||
LLSelectMgr::getInstance()->sendLink();
|
||||
|
||||
return true;
|
||||
|
|
@ -2777,6 +2784,35 @@ BOOL LLSelectMgr::selectGetRootsModify()
|
|||
return TRUE;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// selectGetSameRegion() - return TRUE if all objects are in same region
|
||||
//-----------------------------------------------------------------------------
|
||||
BOOL LLSelectMgr::selectGetSameRegion()
|
||||
{
|
||||
if (getSelection()->isEmpty())
|
||||
{
|
||||
return TRUE;
|
||||
}
|
||||
LLViewerObject* object = getSelection()->getFirstObject();
|
||||
if (!object)
|
||||
{
|
||||
return FALSE;
|
||||
}
|
||||
LLViewerRegion* current_region = object->getRegion();
|
||||
|
||||
for (LLObjectSelection::root_iterator iter = getSelection()->root_begin();
|
||||
iter != getSelection()->root_end(); iter++)
|
||||
{
|
||||
LLSelectNode* node = *iter;
|
||||
object = node->getObject();
|
||||
if (!node->mValid || !object || current_region != object->getRegion())
|
||||
{
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// selectGetNonPermanentEnforced() - return TRUE if all objects are not
|
||||
|
|
@ -5385,9 +5421,9 @@ void LLSelectMgr::processObjectPropertiesFamily(LLMessageSystem* msg, void** use
|
|||
LLFloaterReporter *reporterp = LLFloaterReg::findTypedInstance<LLFloaterReporter>("reporter");
|
||||
if (reporterp)
|
||||
{
|
||||
std::string fullname;
|
||||
gCacheName->getFullName(owner_id, fullname);
|
||||
reporterp->setPickedObjectProperties(name, fullname, owner_id);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(owner_id, &av_name);
|
||||
reporterp->setPickedObjectProperties(name, av_name.getUserName(), owner_id);
|
||||
}
|
||||
}
|
||||
else if (request_flags & OBJECT_PAY_REQUEST)
|
||||
|
|
@ -6618,7 +6654,7 @@ void LLSelectMgr::updateSelectionCenter()
|
|||
{
|
||||
mSelectedObjects->mSelectType = getSelectTypeForObject(object);
|
||||
|
||||
if (mSelectedObjects->mSelectType == SELECT_TYPE_ATTACHMENT && isAgentAvatarValid())
|
||||
if (mSelectedObjects->mSelectType == SELECT_TYPE_ATTACHMENT && isAgentAvatarValid() && object->getParent() != NULL)
|
||||
{
|
||||
mPauseRequest = gAgentAvatarp->requestPause();
|
||||
}
|
||||
|
|
|
|||
|
|
@ -624,6 +624,9 @@ public:
|
|||
BOOL selectGetRootsModify();
|
||||
BOOL selectGetModify();
|
||||
|
||||
// returns TRUE if all objects are in same region
|
||||
BOOL selectGetSameRegion();
|
||||
|
||||
// returns TRUE if is all objects are non-permanent-enforced
|
||||
BOOL selectGetRootsNonPermanentEnforced();
|
||||
BOOL selectGetNonPermanentEnforced();
|
||||
|
|
|
|||
|
|
@ -388,7 +388,7 @@ void LLSidepanelAppearance::toggleWearableEditPanel(BOOL visible, LLViewerWearab
|
|||
return;
|
||||
}
|
||||
|
||||
if (mEditWearable->getVisible() == visible && (!visible || mEditWearable->getWearable() != wearable))
|
||||
if (mEditWearable->getVisible() == visible && (!visible || mEditWearable->getWearable() == wearable))
|
||||
{
|
||||
// visibility isn't changing and panel doesn't need an update, hence nothing to do
|
||||
return;
|
||||
|
|
|
|||
|
|
@ -46,6 +46,7 @@
|
|||
#include "llviewerobjectlist.h"
|
||||
#include "llexperiencecache.h"
|
||||
#include "lltrans.h"
|
||||
#include "llviewerregion.h"
|
||||
|
||||
|
||||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
|
@ -327,9 +328,13 @@ void LLSidepanelItemInfo::refreshFromItem(LLViewerInventoryItem* item)
|
|||
LLTextBox* tb = getChild<LLTextBox>("LabelItemExperience");
|
||||
tb->setText(getString("loading_experience"));
|
||||
tb->setVisible(TRUE);
|
||||
|
||||
LLExperienceCache::instance().fetchAssociatedExperience(item->getParentUUID(), item->getUUID(),
|
||||
boost::bind(&LLSidepanelItemInfo::setAssociatedExperience, getDerivedHandle<LLSidepanelItemInfo>(), _1));
|
||||
std::string url = std::string();
|
||||
if(object && object->getRegion())
|
||||
{
|
||||
url = object->getRegion()->getCapability("GetMetadata");
|
||||
}
|
||||
LLExperienceCache::instance().fetchAssociatedExperience(item->getParentUUID(), item->getUUID(), url,
|
||||
boost::bind(&LLSidepanelItemInfo::setAssociatedExperience, getDerivedHandle<LLSidepanelItemInfo>(), _1));
|
||||
}
|
||||
|
||||
//////////////////////
|
||||
|
|
|
|||
|
|
@ -29,6 +29,7 @@
|
|||
#include "llspeakers.h"
|
||||
|
||||
#include "llagent.h"
|
||||
#include "llavatarnamecache.h"
|
||||
#include "llappviewer.h"
|
||||
#include "llimview.h"
|
||||
#include "llgroupmgr.h"
|
||||
|
|
@ -75,13 +76,13 @@ void LLSpeaker::lookupName()
|
|||
{
|
||||
if (mDisplayName.empty())
|
||||
{
|
||||
gCacheName->get(mID, false, boost::bind(&LLSpeaker::onNameCache, this, _1, _2, _3));
|
||||
LLAvatarNameCache::get(mID, boost::bind(&LLSpeaker::onNameCache, this, _1, _2)); // todo: can be group???
|
||||
}
|
||||
}
|
||||
|
||||
void LLSpeaker::onNameCache(const LLUUID& id, const std::string& full_name, bool is_group)
|
||||
void LLSpeaker::onNameCache(const LLUUID& id, const LLAvatarName& av_name)
|
||||
{
|
||||
mDisplayName = full_name;
|
||||
mDisplayName = av_name.getUserName();
|
||||
}
|
||||
|
||||
bool LLSpeaker::isInVoiceChannel()
|
||||
|
|
|
|||
|
|
@ -34,6 +34,7 @@
|
|||
#include "llcoros.h"
|
||||
|
||||
class LLSpeakerMgr;
|
||||
class LLAvatarName;
|
||||
|
||||
// data for a given participant in a voice channel
|
||||
class LLSpeaker : public LLRefCount, public LLOldEvents::LLObservable, public LLHandleProvider<LLSpeaker>, public boost::signals2::trackable
|
||||
|
|
@ -61,7 +62,7 @@ public:
|
|||
~LLSpeaker() {};
|
||||
void lookupName();
|
||||
|
||||
void onNameCache(const LLUUID& id, const std::string& full_name, bool is_group);
|
||||
void onNameCache(const LLUUID& id, const LLAvatarName& full_name);
|
||||
|
||||
bool isInVoiceChannel();
|
||||
|
||||
|
|
|
|||
|
|
@ -56,6 +56,7 @@
|
|||
#include "llerrorcontrol.h"
|
||||
#include "llfloaterreg.h"
|
||||
#include "llfocusmgr.h"
|
||||
#include "llfloatergridstatus.h"
|
||||
#include "llfloaterimsession.h"
|
||||
#include "lllocationhistory.h"
|
||||
#include "llimageworker.h"
|
||||
|
|
@ -966,6 +967,8 @@ bool idle_startup()
|
|||
// Load media plugin cookies
|
||||
LLViewerMedia::loadCookieFile();
|
||||
|
||||
LLRenderMuteList::getInstance()->loadFromFile();
|
||||
|
||||
//-------------------------------------------------
|
||||
// Handle startup progress screen
|
||||
//-------------------------------------------------
|
||||
|
|
@ -1875,6 +1878,8 @@ bool idle_startup()
|
|||
|
||||
LLFloaterReg::showInitialVisibleInstances();
|
||||
|
||||
LLFloaterGridStatus::getInstance()->startGridStatusTimer();
|
||||
|
||||
display_startup();
|
||||
|
||||
display_startup();
|
||||
|
|
|
|||
|
|
@ -28,31 +28,21 @@
|
|||
|
||||
#include "lltoastscripttextbox.h"
|
||||
|
||||
#include "llfocusmgr.h"
|
||||
|
||||
#include "llbutton.h"
|
||||
#include "lllslconstants.h"
|
||||
#include "llnotifications.h"
|
||||
#include "llstyle.h"
|
||||
#include "lluiconstants.h"
|
||||
#include "llviewertexteditor.h"
|
||||
|
||||
#include "llavatarnamecache.h"
|
||||
#include "lluiconstants.h"
|
||||
#include "llui.h"
|
||||
#include "llviewercontrol.h"
|
||||
#include "lltrans.h"
|
||||
#include "llstyle.h"
|
||||
|
||||
#include "llglheaders.h"
|
||||
#include "llagent.h"
|
||||
|
||||
const S32 LLToastScriptTextbox::DEFAULT_MESSAGE_MAX_LINE_COUNT= 7;
|
||||
const S32 LLToastScriptTextbox::DEFAULT_MESSAGE_MAX_LINE_COUNT= 14;
|
||||
|
||||
LLToastScriptTextbox::LLToastScriptTextbox(const LLNotificationPtr& notification)
|
||||
: LLToastPanel(notification)
|
||||
{
|
||||
buildFromFile( "panel_notify_textbox.xml");
|
||||
|
||||
LLTextEditor* text_editorp = getChild<LLTextEditor>("text_editor_box");
|
||||
text_editorp->setValue(notification->getMessage());
|
||||
mInfoText = getChild<LLTextBox>("text_editor_box");
|
||||
mInfoText->setValue(notification->getMessage());
|
||||
|
||||
getChild<LLButton>("ignore_btn")->setClickedCallback(boost::bind(&LLToastScriptTextbox::onClickIgnore, this));
|
||||
|
||||
|
|
@ -73,13 +63,7 @@ LLToastScriptTextbox::LLToastScriptTextbox(const LLNotificationPtr& notification
|
|||
pSubmitBtn->setClickedCallback((boost::bind(&LLToastScriptTextbox::onClickSubmit, this)));
|
||||
setDefaultBtn(pSubmitBtn);
|
||||
|
||||
S32 maxLinesCount;
|
||||
std::istringstream ss( getString("message_max_lines_count") );
|
||||
if (!(ss >> maxLinesCount))
|
||||
{
|
||||
maxLinesCount = DEFAULT_MESSAGE_MAX_LINE_COUNT;
|
||||
}
|
||||
//snapToMessageHeight(pMessageText, maxLinesCount);
|
||||
snapToMessageHeight();
|
||||
}
|
||||
|
||||
// virtual
|
||||
|
|
@ -92,7 +76,6 @@ void LLToastScriptTextbox::close()
|
|||
die();
|
||||
}
|
||||
|
||||
#include "lllslconstants.h"
|
||||
void LLToastScriptTextbox::onClickSubmit()
|
||||
{
|
||||
LLViewerTextEditor* pMessageText = getChild<LLViewerTextEditor>("message");
|
||||
|
|
@ -119,3 +102,29 @@ void LLToastScriptTextbox::onClickIgnore()
|
|||
mNotification->respond(response);
|
||||
close();
|
||||
}
|
||||
|
||||
void LLToastScriptTextbox::snapToMessageHeight()
|
||||
{
|
||||
LLPanel* info_pan = getChild<LLPanel>("info_panel");
|
||||
if (!info_pan)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
S32 maxLinesCount;
|
||||
std::istringstream ss( getString("message_max_lines_count") );
|
||||
if (!(ss >> maxLinesCount))
|
||||
{
|
||||
maxLinesCount = DEFAULT_MESSAGE_MAX_LINE_COUNT;
|
||||
}
|
||||
|
||||
|
||||
S32 maxTextHeight = (mInfoText->getFont()->getLineHeight() * maxLinesCount);
|
||||
S32 oldTextHeight = mInfoText->getRect().getHeight();
|
||||
S32 newTextHeight = llmin(mInfoText->getTextBoundingRect().getHeight(), maxTextHeight);
|
||||
|
||||
S32 heightDelta = newTextHeight - oldTextHeight;
|
||||
|
||||
reshape( getRect().getWidth(), llmax(getRect().getHeight() + heightDelta, MIN_PANEL_HEIGHT));
|
||||
info_pan->reshape(info_pan->getRect().getWidth(),newTextHeight);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -48,9 +48,12 @@ public:
|
|||
|
||||
private:
|
||||
|
||||
LLTextBox* mInfoText;
|
||||
|
||||
void onClickSubmit();
|
||||
void onClickIgnore();
|
||||
|
||||
void snapToMessageHeight();
|
||||
static const S32 DEFAULT_MESSAGE_MAX_LINE_COUNT;
|
||||
};
|
||||
|
||||
|
|
|
|||
|
|
@ -1584,12 +1584,12 @@ static void show_object_sharing_confirmation(const std::string name,
|
|||
}
|
||||
|
||||
static void get_name_cb(const LLUUID& id,
|
||||
const std::string& full_name,
|
||||
const LLAvatarName& av_name,
|
||||
LLInventoryObject* inv_obj,
|
||||
const LLSD& dest,
|
||||
const LLUUID& dest_agent)
|
||||
{
|
||||
show_object_sharing_confirmation(full_name,
|
||||
show_object_sharing_confirmation(av_name.getUserName(),
|
||||
inv_obj,
|
||||
dest,
|
||||
id,
|
||||
|
|
@ -1634,17 +1634,17 @@ bool LLToolDragAndDrop::handleGiveDragAndDrop(LLUUID dest_agent, LLUUID session_
|
|||
// If no IM session found get the destination agent's name by id.
|
||||
if (NULL == session)
|
||||
{
|
||||
std::string fullname;
|
||||
LLAvatarName av_name;
|
||||
|
||||
// If destination agent's name is found in cash proceed to showing the confirmation dialog.
|
||||
// Otherwise set up a callback to show the dialog when the name arrives.
|
||||
if (gCacheName->getFullName(dest_agent, fullname))
|
||||
if (LLAvatarNameCache::get(dest_agent, &av_name))
|
||||
{
|
||||
show_object_sharing_confirmation(fullname, inv_obj, dest, dest_agent, LLUUID::null);
|
||||
show_object_sharing_confirmation(av_name.getUserName(), inv_obj, dest, dest_agent, LLUUID::null);
|
||||
}
|
||||
else
|
||||
{
|
||||
gCacheName->get(dest_agent, false, boost::bind(&get_name_cb, _1, _2, inv_obj, dest, dest_agent));
|
||||
LLAvatarNameCache::get(dest_agent, boost::bind(&get_name_cb, _1, _2, inv_obj, dest, dest_agent));
|
||||
}
|
||||
|
||||
return true;
|
||||
|
|
|
|||
|
|
@ -893,14 +893,19 @@ BOOL LLToolPie::handleTooltipLand(std::string line, std::string tooltip_msg)
|
|||
line.append(LLTrans::getString("RetrievingData"));
|
||||
}
|
||||
}
|
||||
else if(gCacheName->getFullName(owner, name))
|
||||
{
|
||||
line.append(name);
|
||||
}
|
||||
else
|
||||
{
|
||||
line.append(LLTrans::getString("RetrievingData"));
|
||||
}
|
||||
else
|
||||
{
|
||||
LLAvatarName av_name;
|
||||
if (LLAvatarNameCache::get(owner, &av_name))
|
||||
{
|
||||
name = av_name.getUserName();
|
||||
line.append(name);
|
||||
}
|
||||
else
|
||||
{
|
||||
line.append(LLTrans::getString("RetrievingData"));
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
|
|||
|
|
@ -38,6 +38,7 @@
|
|||
#include "llfloaterautoreplacesettings.h"
|
||||
#include "llfloateravatar.h"
|
||||
#include "llfloateravatarpicker.h"
|
||||
#include "llfloateravatarrendersettings.h"
|
||||
#include "llfloateravatartextures.h"
|
||||
#include "llfloaterbigpreview.h"
|
||||
#include "llfloaterbeacons.h"
|
||||
|
|
@ -70,6 +71,7 @@
|
|||
#include "llfloaterfonttest.h"
|
||||
#include "llfloatergesture.h"
|
||||
#include "llfloatergodtools.h"
|
||||
#include "llfloatergridstatus.h"
|
||||
#include "llfloatergroups.h"
|
||||
#include "llfloaterhelpbrowser.h"
|
||||
#include "llfloaterhoverheight.h"
|
||||
|
|
@ -193,6 +195,7 @@ void LLViewerFloaterReg::registerFloaters()
|
|||
LLFloaterReg::add("auction", "floater_auction.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterAuction>);
|
||||
LLFloaterReg::add("avatar", "floater_avatar.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterAvatar>);
|
||||
LLFloaterReg::add("avatar_picker", "floater_avatar_picker.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterAvatarPicker>);
|
||||
LLFloaterReg::add("avatar_render_settings", "floater_avatar_render_settings.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterAvatarRenderSettings>);
|
||||
LLFloaterReg::add("avatar_textures", "floater_avatar_textures.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterAvatarTextures>);
|
||||
|
||||
LLFloaterReg::add("beacons", "floater_beacons.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterBeacons>);
|
||||
|
|
@ -231,6 +234,7 @@ void LLViewerFloaterReg::registerFloaters()
|
|||
|
||||
LLFloaterReg::add("gestures", "floater_gesture.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterGesture>);
|
||||
LLFloaterReg::add("god_tools", "floater_god_tools.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterGodTools>);
|
||||
LLFloaterReg::add("grid_status", "floater_grid_status.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterGridStatus>);
|
||||
LLFloaterReg::add("group_picker", "floater_choose_group.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterGroupPicker>);
|
||||
|
||||
LLFloaterReg::add("help_browser", "floater_help_browser.xml", (LLFloaterBuildFunc)&LLFloaterReg::build<LLFloaterHelpBrowser>);
|
||||
|
|
|
|||
|
|
@ -1126,10 +1126,10 @@ void create_inventory_item(const LLUUID& agent_id, const LLUUID& session_id,
|
|||
void create_inventory_callingcard(const LLUUID& avatar_id, const LLUUID& parent /*= LLUUID::null*/, LLPointer<LLInventoryCallback> cb/*=NULL*/)
|
||||
{
|
||||
std::string item_desc = avatar_id.asString();
|
||||
std::string item_name;
|
||||
gCacheName->getFullName(avatar_id, item_name);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(avatar_id, &av_name);
|
||||
create_inventory_item(gAgent.getID(), gAgent.getSessionID(),
|
||||
parent, LLTransactionID::tnull, item_name, item_desc, LLAssetType::AT_CALLINGCARD,
|
||||
parent, LLTransactionID::tnull, av_name.getUserName(), item_desc, LLAssetType::AT_CALLINGCARD,
|
||||
LLInventoryType::IT_CALLINGCARD, NOT_WEARABLE, PERM_MOVE | PERM_TRANSFER, cb);
|
||||
}
|
||||
|
||||
|
|
@ -2071,9 +2071,9 @@ PermissionMask LLViewerInventoryItem::getPermissionMask() const
|
|||
|
||||
//----------
|
||||
|
||||
void LLViewerInventoryItem::onCallingCardNameLookup(const LLUUID& id, const std::string& name, bool is_group)
|
||||
void LLViewerInventoryItem::onCallingCardNameLookup(const LLUUID& id, const LLAvatarName& name)
|
||||
{
|
||||
rename(name);
|
||||
rename(name.getUserName());
|
||||
gInventory.addChangedMask(LLInventoryObserver::LABEL, getUUID());
|
||||
gInventory.notifyObservers();
|
||||
}
|
||||
|
|
|
|||
|
|
@ -39,6 +39,7 @@ class LLFolderView;
|
|||
class LLFolderBridge;
|
||||
class LLViewerInventoryCategory;
|
||||
class LLInventoryCallback;
|
||||
class LLAvatarName;
|
||||
|
||||
//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
// Class LLViewerInventoryItem
|
||||
|
|
@ -158,7 +159,7 @@ public:
|
|||
PermissionMask getPermissionMask() const;
|
||||
|
||||
// callback
|
||||
void onCallingCardNameLookup(const LLUUID& id, const std::string& name, bool is_group);
|
||||
void onCallingCardNameLookup(const LLUUID& id, const LLAvatarName& name);
|
||||
|
||||
// If this is a broken link, try to fix it and any other identical link.
|
||||
BOOL regenerateLink();
|
||||
|
|
|
|||
|
|
@ -4177,27 +4177,6 @@ class LLViewToggleUI : public view_listener_t
|
|||
}
|
||||
};
|
||||
|
||||
class LLEditDuplicate : public view_listener_t
|
||||
{
|
||||
bool handleEvent(const LLSD& userdata)
|
||||
{
|
||||
if(LLEditMenuHandler::gEditMenuHandler)
|
||||
{
|
||||
LLEditMenuHandler::gEditMenuHandler->duplicate();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
};
|
||||
|
||||
class LLEditEnableDuplicate : public view_listener_t
|
||||
{
|
||||
bool handleEvent(const LLSD& userdata)
|
||||
{
|
||||
bool new_value = LLEditMenuHandler::gEditMenuHandler && LLEditMenuHandler::gEditMenuHandler->canDuplicate();
|
||||
return new_value;
|
||||
}
|
||||
};
|
||||
|
||||
void handle_duplicate_in_place(void*)
|
||||
{
|
||||
LL_INFOS() << "handle_duplicate_in_place" << LL_ENDL;
|
||||
|
|
@ -6560,10 +6539,10 @@ class LLMuteParticle : public view_listener_t
|
|||
|
||||
if (id.notNull())
|
||||
{
|
||||
std::string name;
|
||||
gCacheName->getFullName(id, name);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(id, &av_name);
|
||||
|
||||
LLMute mute(id, name, LLMute::AGENT);
|
||||
LLMute mute(id, av_name.getUserName(), LLMute::AGENT);
|
||||
if (LLMuteList::getInstance()->isMuted(mute.mID))
|
||||
{
|
||||
LLMuteList::getInstance()->remove(mute);
|
||||
|
|
@ -8402,6 +8381,15 @@ class LLToolsSelectTool : public view_listener_t
|
|||
{
|
||||
LLToolMgr::getInstance()->getCurrentToolset()->selectToolByIndex(5);
|
||||
}
|
||||
|
||||
// Note: if floater is not visible LLViewerWindow::updateLayout() will
|
||||
// attempt to open it, but it won't bring it to front or de-minimize.
|
||||
if (gFloaterTools && (gFloaterTools->isMinimized() || !gFloaterTools->isShown() || !gFloaterTools->isFrontmost()))
|
||||
{
|
||||
gFloaterTools->setMinimized(FALSE);
|
||||
gFloaterTools->openFloater();
|
||||
gFloaterTools->setVisibleAndFrontmost(TRUE);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
};
|
||||
|
|
@ -8618,7 +8606,12 @@ public:
|
|||
|
||||
void handle_voice_morphing_subscribe()
|
||||
{
|
||||
LLWeb::loadURLExternal(LLTrans::getString("voice_morphing_url"));
|
||||
LLWeb::loadURL(LLTrans::getString("voice_morphing_url"));
|
||||
}
|
||||
|
||||
void handle_premium_voice_morphing_subscribe()
|
||||
{
|
||||
LLWeb::loadURL(LLTrans::getString("premium_voice_morphing_url"));
|
||||
}
|
||||
|
||||
class LLToggleUIHints : public view_listener_t
|
||||
|
|
@ -8696,7 +8689,6 @@ void initialize_edit_menu()
|
|||
view_listener_t::addMenu(new LLEditDelete(), "Edit.Delete");
|
||||
view_listener_t::addMenu(new LLEditSelectAll(), "Edit.SelectAll");
|
||||
view_listener_t::addMenu(new LLEditDeselect(), "Edit.Deselect");
|
||||
view_listener_t::addMenu(new LLEditDuplicate(), "Edit.Duplicate");
|
||||
view_listener_t::addMenu(new LLEditTakeOff(), "Edit.TakeOff");
|
||||
view_listener_t::addMenu(new LLEditEnableUndo(), "Edit.EnableUndo");
|
||||
view_listener_t::addMenu(new LLEditEnableRedo(), "Edit.EnableRedo");
|
||||
|
|
@ -8706,7 +8698,6 @@ void initialize_edit_menu()
|
|||
view_listener_t::addMenu(new LLEditEnableDelete(), "Edit.EnableDelete");
|
||||
view_listener_t::addMenu(new LLEditEnableSelectAll(), "Edit.EnableSelectAll");
|
||||
view_listener_t::addMenu(new LLEditEnableDeselect(), "Edit.EnableDeselect");
|
||||
view_listener_t::addMenu(new LLEditEnableDuplicate(), "Edit.EnableDuplicate");
|
||||
|
||||
}
|
||||
|
||||
|
|
@ -8814,6 +8805,8 @@ void initialize_menus()
|
|||
|
||||
// Communicate > Voice morphing > Subscribe...
|
||||
commit.add("Communicate.VoiceMorphing.Subscribe", boost::bind(&handle_voice_morphing_subscribe));
|
||||
// Communicate > Voice morphing > Premium perk...
|
||||
commit.add("Communicate.VoiceMorphing.PremiumPerk", boost::bind(&handle_premium_voice_morphing_subscribe));
|
||||
LLVivoxVoiceClient * voice_clientp = LLVivoxVoiceClient::getInstance();
|
||||
enable.add("Communicate.VoiceMorphing.NoVoiceMorphing.Check"
|
||||
, boost::bind(&LLVivoxVoiceClient::onCheckVoiceEffect, voice_clientp, "NoVoiceMorphing"));
|
||||
|
|
@ -9115,6 +9108,7 @@ void initialize_menus()
|
|||
view_listener_t::addMenu(new LLObjectAttachToAvatar(true), "Object.AttachToAvatar");
|
||||
view_listener_t::addMenu(new LLObjectAttachToAvatar(false), "Object.AttachAddToAvatar");
|
||||
view_listener_t::addMenu(new LLObjectReturn(), "Object.Return");
|
||||
commit.add("Object.Duplicate", boost::bind(&LLSelectMgr::duplicate, LLSelectMgr::getInstance()));
|
||||
view_listener_t::addMenu(new LLObjectReportAbuse(), "Object.ReportAbuse");
|
||||
view_listener_t::addMenu(new LLObjectMute(), "Object.Mute");
|
||||
|
||||
|
|
@ -9136,6 +9130,7 @@ void initialize_menus()
|
|||
enable.add("Object.EnableSit", boost::bind(&enable_object_sit, _1));
|
||||
|
||||
view_listener_t::addMenu(new LLObjectEnableReturn(), "Object.EnableReturn");
|
||||
enable.add("Object.EnableDuplicate", boost::bind(&LLSelectMgr::canDuplicate, LLSelectMgr::getInstance()));
|
||||
view_listener_t::addMenu(new LLObjectEnableReportAbuse(), "Object.EnableReportAbuse");
|
||||
|
||||
enable.add("Avatar.EnableMute", boost::bind(&enable_object_mute));
|
||||
|
|
|
|||
|
|
@ -1390,6 +1390,14 @@ void inventory_offer_mute_callback(const LLUUID& blocked_id,
|
|||
gSavedSettings.getString("NotificationChannelUUID")), OfferMatcher(blocked_id));
|
||||
}
|
||||
|
||||
|
||||
void inventory_offer_mute_avatar_callback(const LLUUID& blocked_id,
|
||||
const LLAvatarName& av_name)
|
||||
{
|
||||
inventory_offer_mute_callback(blocked_id, av_name.getUserName(), false);
|
||||
}
|
||||
|
||||
|
||||
std::string LLOfferInfo::mResponderType = "offer_info";
|
||||
|
||||
LLOfferInfo::LLOfferInfo()
|
||||
|
|
@ -1538,7 +1546,14 @@ bool LLOfferInfo::inventory_offer_callback(const LLSD& notification, const LLSD&
|
|||
{
|
||||
if (notification_ptr != NULL)
|
||||
{
|
||||
gCacheName->get(mFromID, mFromGroup, boost::bind(&inventory_offer_mute_callback, _1, _2, _3));
|
||||
if (mFromGroup)
|
||||
{
|
||||
gCacheName->getGroup(mFromID, boost::bind(&inventory_offer_mute_callback, _1, _2, _3));
|
||||
}
|
||||
else
|
||||
{
|
||||
LLAvatarNameCache::get(mFromID, boost::bind(&inventory_offer_mute_avatar_callback, _1, _2));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -1695,7 +1710,14 @@ bool LLOfferInfo::inventory_task_offer_callback(const LLSD& notification, const
|
|||
llassert(notification_ptr != NULL);
|
||||
if (notification_ptr != NULL)
|
||||
{
|
||||
gCacheName->get(mFromID, mFromGroup, boost::bind(&inventory_offer_mute_callback, _1, _2, _3));
|
||||
if (mFromGroup)
|
||||
{
|
||||
gCacheName->getGroup(mFromID, boost::bind(&inventory_offer_mute_callback, _1, _2, _3));
|
||||
}
|
||||
else
|
||||
{
|
||||
LLAvatarNameCache::get(mFromID, boost::bind(&inventory_offer_mute_avatar_callback, _1, _2));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -1744,12 +1766,12 @@ bool LLOfferInfo::inventory_task_offer_callback(const LLSD& notification, const
|
|||
}
|
||||
else
|
||||
{
|
||||
std::string full_name;
|
||||
if (gCacheName->getFullName(mFromID, full_name))
|
||||
LLAvatarName av_name;
|
||||
if (LLAvatarNameCache::get(mFromID, &av_name))
|
||||
{
|
||||
from_string = LLTrans::getString("InvOfferAnObjectNamed") + " "+ LLTrans::getString("'") + mFromName
|
||||
+ LLTrans::getString("'")+" " + LLTrans::getString("InvOfferOwnedBy") + full_name;
|
||||
chatHistory_string = mFromName + " " + LLTrans::getString("InvOfferOwnedBy") + " " + full_name;
|
||||
+ LLTrans::getString("'")+" " + LLTrans::getString("InvOfferOwnedBy") + av_name.getUserName();
|
||||
chatHistory_string = mFromName + " " + LLTrans::getString("InvOfferOwnedBy") + " " + av_name.getUserName();
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
@ -2601,9 +2623,9 @@ void process_improved_im(LLMessageSystem *msg, void **user_data)
|
|||
{
|
||||
original_name = original_name.substr(0, index);
|
||||
}
|
||||
|
||||
std::string legacy_name = gCacheName->buildLegacyName(original_name);
|
||||
LLUUID agent_id;
|
||||
gCacheName->getUUID(legacy_name, agent_id);
|
||||
LLUUID agent_id = LLAvatarNameCache::findIdByName(legacy_name);
|
||||
|
||||
if (agent_id.isNull())
|
||||
{
|
||||
|
|
@ -2662,6 +2684,7 @@ void process_improved_im(LLMessageSystem *msg, void **user_data)
|
|||
payload["subject"] = subj;
|
||||
payload["message"] = mes;
|
||||
payload["sender_name"] = name;
|
||||
payload["sender_id"] = agent_id;
|
||||
payload["group_id"] = group_id;
|
||||
payload["inventory_name"] = item_name;
|
||||
payload["received_time"] = LLDate::now();
|
||||
|
|
@ -3038,16 +3061,17 @@ void process_improved_im(LLMessageSystem *msg, void **user_data)
|
|||
{
|
||||
return;
|
||||
}
|
||||
else if (is_do_not_disturb)
|
||||
{
|
||||
send_do_not_disturb_message(msg, from_id);
|
||||
}
|
||||
else if (gSavedSettings.getBOOL("VoiceCallsFriendsOnly") && (LLAvatarTracker::instance().getBuddyInfo(from_id) == NULL))
|
||||
{
|
||||
return;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (is_do_not_disturb)
|
||||
{
|
||||
send_do_not_disturb_message(msg, from_id);
|
||||
}
|
||||
|
||||
LLVector3 pos, look_at;
|
||||
U64 region_handle(0);
|
||||
U8 region_access(SIM_ACCESS_MIN);
|
||||
|
|
@ -6182,7 +6206,7 @@ void handle_show_mean_events(void *)
|
|||
//LLFloaterBump::showInstance();
|
||||
}
|
||||
|
||||
void mean_name_callback(const LLUUID &id, const std::string& full_name, bool is_group)
|
||||
void mean_name_callback(const LLUUID &id, const LLAvatarName& av_name)
|
||||
{
|
||||
static const U32 max_collision_list_size = 20;
|
||||
if (gMeanCollisionList.size() > max_collision_list_size)
|
||||
|
|
@ -6199,7 +6223,7 @@ void mean_name_callback(const LLUUID &id, const std::string& full_name, bool is_
|
|||
LLMeanCollisionData *mcd = *iter;
|
||||
if (mcd->mPerp == id)
|
||||
{
|
||||
mcd->mFullName = full_name;
|
||||
mcd->mFullName = av_name.getUserName();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -6253,7 +6277,7 @@ void process_mean_collision_alert_message(LLMessageSystem *msgsystem, void **use
|
|||
{
|
||||
LLMeanCollisionData *mcd = new LLMeanCollisionData(gAgentID, perp, time, type, mag);
|
||||
gMeanCollisionList.push_front(mcd);
|
||||
gCacheName->get(perp, false, boost::bind(&mean_name_callback, _1, _2, _3));
|
||||
LLAvatarNameCache::get(perp, boost::bind(&mean_name_callback, _1, _2));
|
||||
}
|
||||
}
|
||||
LLFloaterBump* bumps_floater = LLFloaterBump::getInstance();
|
||||
|
|
@ -7030,10 +7054,10 @@ void send_lures(const LLSD& notification, const LLSD& response)
|
|||
|
||||
// Record the offer.
|
||||
{
|
||||
std::string target_name;
|
||||
gCacheName->getFullName(target_id, target_name); // for im log filenames
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(target_id, &av_name); // for im log filenames
|
||||
LLSD args;
|
||||
args["TO_NAME"] = LLSLURL("agent", target_id, "displayname").getSLURLString();;
|
||||
args["TO_NAME"] = LLSLURL("agent", target_id, "completename").getSLURLString();;
|
||||
|
||||
LLSD payload;
|
||||
|
||||
|
|
@ -7116,10 +7140,10 @@ bool teleport_request_callback(const LLSD& notification, const LLSD& response)
|
|||
return false;
|
||||
}
|
||||
|
||||
std::string from_name;
|
||||
gCacheName->getFullName(from_id, from_name);
|
||||
LLAvatarName av_name;
|
||||
LLAvatarNameCache::get(from_id, &av_name);
|
||||
|
||||
if(LLMuteList::getInstance()->isMuted(from_id) && !LLMuteList::getInstance()->isLinden(from_name))
|
||||
if(LLMuteList::getInstance()->isMuted(from_id) && !LLMuteList::getInstance()->isLinden(av_name.getUserName()))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
|
@ -7394,8 +7418,7 @@ bool callback_load_url(const LLSD& notification, const LLSD& response)
|
|||
}
|
||||
static LLNotificationFunctorRegistration callback_load_url_reg("LoadWebPage", callback_load_url);
|
||||
|
||||
|
||||
// We've got the name of the person who owns the object hurling the url.
|
||||
// We've got the name of the person or group that owns the object hurling the url.
|
||||
// Display confirmation dialog.
|
||||
void callback_load_url_name(const LLUUID& id, const std::string& full_name, bool is_group)
|
||||
{
|
||||
|
|
@ -7437,6 +7460,12 @@ void callback_load_url_name(const LLUUID& id, const std::string& full_name, bool
|
|||
}
|
||||
}
|
||||
|
||||
// We've got the name of the person who owns the object hurling the url.
|
||||
void callback_load_url_avatar_name(const LLUUID& id, const LLAvatarName& av_name)
|
||||
{
|
||||
callback_load_url_name(id, av_name.getUserName(), false);
|
||||
}
|
||||
|
||||
void process_load_url(LLMessageSystem* msg, void**)
|
||||
{
|
||||
LLUUID object_id;
|
||||
|
|
@ -7474,8 +7503,14 @@ void process_load_url(LLMessageSystem* msg, void**)
|
|||
// Add to list of pending name lookups
|
||||
gLoadUrlList.push_back(payload);
|
||||
|
||||
gCacheName->get(owner_id, owner_is_group,
|
||||
boost::bind(&callback_load_url_name, _1, _2, _3));
|
||||
if (owner_is_group)
|
||||
{
|
||||
gCacheName->getGroup(owner_id, boost::bind(&callback_load_url_name, _1, _2, _3));
|
||||
}
|
||||
else
|
||||
{
|
||||
LLAvatarNameCache::get(owner_id, boost::bind(&callback_load_url_avatar_name, _1, _2));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -2724,8 +2724,16 @@ BOOL LLViewerWindow::handleKey(KEY key, MASK mask)
|
|||
return TRUE;
|
||||
}
|
||||
|
||||
if ((gMenuBarView && gMenuBarView->handleAcceleratorKey(key, mask))
|
||||
||(gLoginMenuBarView && gLoginMenuBarView->handleAcceleratorKey(key, mask)))
|
||||
if (gAgent.isInitialized()
|
||||
&& (gAgent.getTeleportState() == LLAgent::TELEPORT_NONE || gAgent.getTeleportState() == LLAgent::TELEPORT_LOCAL)
|
||||
&& gMenuBarView
|
||||
&& gMenuBarView->handleAcceleratorKey(key, mask))
|
||||
{
|
||||
LLViewerEventRecorder::instance().logKeyEvent(key, mask);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
if (gLoginMenuBarView && gLoginMenuBarView->handleAcceleratorKey(key, mask))
|
||||
{
|
||||
LLViewerEventRecorder::instance().logKeyEvent(key,mask);
|
||||
return TRUE;
|
||||
|
|
@ -2855,8 +2863,16 @@ BOOL LLViewerWindow::handleKey(KEY key, MASK mask)
|
|||
}
|
||||
|
||||
// give menus a chance to handle unmodified accelerator keys
|
||||
if ((gMenuBarView && gMenuBarView->handleAcceleratorKey(key, mask))
|
||||
||(gLoginMenuBarView && gLoginMenuBarView->handleAcceleratorKey(key, mask)))
|
||||
if (gAgent.isInitialized()
|
||||
&& (gAgent.getTeleportState() == LLAgent::TELEPORT_NONE || gAgent.getTeleportState() == LLAgent::TELEPORT_LOCAL)
|
||||
&& gMenuBarView
|
||||
&& gMenuBarView->handleAcceleratorKey(key, mask))
|
||||
{
|
||||
LLViewerEventRecorder::instance().logKeyEvent(key, mask);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
if (gLoginMenuBarView && gLoginMenuBarView->handleAcceleratorKey(key, mask))
|
||||
{
|
||||
return TRUE;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -727,6 +727,8 @@ LLVOAvatar::LLVOAvatar(const LLUUID& id,
|
|||
{
|
||||
LLSceneMonitor::getInstance()->freezeAvatar((LLCharacter*)this);
|
||||
}
|
||||
|
||||
mVisuallyMuteSetting = LLVOAvatar::VisualMuteSettings(LLRenderMuteList::getInstance()->getSavedVisualMuteSetting(getID()));
|
||||
}
|
||||
|
||||
std::string LLVOAvatar::avString() const
|
||||
|
|
@ -7074,7 +7076,9 @@ BOOL LLVOAvatar::isFullyLoaded() const
|
|||
bool LLVOAvatar::isTooComplex() const
|
||||
{
|
||||
bool too_complex;
|
||||
if (isSelf() || mVisuallyMuteSetting == AV_ALWAYS_RENDER)
|
||||
bool render_friend = (LLAvatarTracker::instance().isBuddy(getID()) && gSavedSettings.getBOOL("AlwaysRenderFriends"));
|
||||
|
||||
if (isSelf() || render_friend || mVisuallyMuteSetting == AV_ALWAYS_RENDER)
|
||||
{
|
||||
too_complex = false;
|
||||
}
|
||||
|
|
@ -9232,8 +9236,9 @@ void LLVOAvatar::setVisualMuteSettings(VisualMuteSettings set)
|
|||
{
|
||||
mVisuallyMuteSetting = set;
|
||||
mNeedsImpostorUpdate = TRUE;
|
||||
}
|
||||
|
||||
LLRenderMuteList::getInstance()->saveVisualMuteSetting(getID(), S32(set));
|
||||
}
|
||||
|
||||
void LLVOAvatar::calcMutedAVColor()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -136,6 +136,7 @@ with the same filename but different name
|
|||
<texture name="Command_Facebook_Icon" file_name="toolbar_icons/facebook.png" preload="true" />
|
||||
<texture name="Command_Flickr_Icon" file_name="toolbar_icons/flickr.png" preload="true" />
|
||||
<texture name="Command_Gestures_Icon" file_name="toolbar_icons/gestures.png" preload="true" />
|
||||
<texture name="Command_Grid_Status_Icon" file_name="toolbar_icons/grid_status.png" preload="true" />
|
||||
<texture name="Command_HowTo_Icon" file_name="toolbar_icons/howto.png" preload="true" />
|
||||
<texture name="Command_Inventory_Icon" file_name="toolbar_icons/inventory.png" preload="true" />
|
||||
<texture name="Command_Map_Icon" file_name="toolbar_icons/map.png" preload="true" />
|
||||
|
|
|
|||
Binary file not shown.
|
After Width: | Height: | Size: 483 B |
|
|
@ -0,0 +1,66 @@
|
|||
<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
|
||||
<floater
|
||||
can_resize="true"
|
||||
positioning="cascading"
|
||||
height="200"
|
||||
min_height="100"
|
||||
min_width="230"
|
||||
layout="topleft"
|
||||
name="floater_avatar_render_settings"
|
||||
save_rect="true"
|
||||
single_instance="true"
|
||||
reuse_instance="true"
|
||||
title="AVATAR RENDER SETTINGS"
|
||||
width="300">
|
||||
<string
|
||||
name="av_never_render"
|
||||
value="Never"/>
|
||||
<string
|
||||
name="av_always_render"
|
||||
value="Always"/>
|
||||
<filter_editor
|
||||
follows="left|top|right"
|
||||
height="23"
|
||||
layout="topleft"
|
||||
left="8"
|
||||
right="-47"
|
||||
label="Filter People"
|
||||
max_length_chars="300"
|
||||
name="people_filter_input"
|
||||
text_color="Black"
|
||||
text_pad_left="10"
|
||||
top="4" />
|
||||
<menu_button
|
||||
follows="top|right"
|
||||
height="25"
|
||||
image_hover_unselected="Toolbar_Middle_Over"
|
||||
image_overlay="AddItem_Off"
|
||||
image_selected="Toolbar_Middle_Selected"
|
||||
image_unselected="Toolbar_Middle_Off"
|
||||
layout="topleft"
|
||||
left_pad="7"
|
||||
menu_filename="menu_avatar_rendering_settings_add.xml"
|
||||
menu_position="bottomleft"
|
||||
name="plus_btn"
|
||||
tool_tip="Actions on selected person"
|
||||
top="3"
|
||||
width="31" />
|
||||
<name_list
|
||||
bottom="-8"
|
||||
draw_heading="true"
|
||||
follows="all"
|
||||
left="8"
|
||||
multi_select="false"
|
||||
name="render_settings_list"
|
||||
right="-8"
|
||||
top="32">
|
||||
<name_list.columns
|
||||
label="Name"
|
||||
name="name"
|
||||
relative_width="0.65" />
|
||||
<name_list.columns
|
||||
label="Render setting"
|
||||
name="setting"
|
||||
relative_width="0.35" />
|
||||
</name_list>
|
||||
</floater>
|
||||
|
|
@ -9,7 +9,7 @@
|
|||
save_rect="true"
|
||||
single_instance="true"
|
||||
reuse_instance="true"
|
||||
title="UPLOAD TO FLICKR"
|
||||
title="SHARE TO FLICKR"
|
||||
height="590"
|
||||
width="272">
|
||||
<panel
|
||||
|
|
|
|||
|
|
@ -0,0 +1,18 @@
|
|||
<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
|
||||
<floater
|
||||
positioning="cascading"
|
||||
legacy_header_height="18"
|
||||
can_resize="true"
|
||||
height="775"
|
||||
layout="topleft"
|
||||
min_height="485"
|
||||
min_width="485"
|
||||
name="floater_grid_status"
|
||||
help_topic="floater_grid_status"
|
||||
save_rect="true"
|
||||
save_visibility="true"
|
||||
title=""
|
||||
initial_mime_type="text/html"
|
||||
width="780"
|
||||
tab_stop="true"
|
||||
filename="floater_web_content.xml"/>
|
||||
|
|
@ -70,7 +70,7 @@
|
|||
top="32"
|
||||
word_wrap="true"
|
||||
width="552">
|
||||
You will need to go to my.secondlife.com and log in to accept the Terms of Service before you can proceed. Thank you!
|
||||
You will need to go to https://my.secondlife.com and log in to accept the Terms of Service before you can proceed. Thank you!
|
||||
</text>
|
||||
<web_browser
|
||||
trusted_content="true"
|
||||
|
|
|
|||
|
|
@ -130,10 +130,13 @@
|
|||
</menu_item_call>
|
||||
|
||||
<menu_item_separator />
|
||||
|
||||
<context_menu
|
||||
label="Render Avatar"
|
||||
layout="topleft"
|
||||
name="Render Avatar">
|
||||
<menu_item_check
|
||||
name="RenderNormally"
|
||||
label="Render Normally">
|
||||
label="Default">
|
||||
<menu_item_check.on_check
|
||||
function="Avatar.CheckImpostorMode"
|
||||
parameter="0" />
|
||||
|
|
@ -141,19 +144,9 @@
|
|||
function="Avatar.SetImpostorMode"
|
||||
parameter="0" />
|
||||
</menu_item_check>
|
||||
<menu_item_check
|
||||
name="DoNotRender"
|
||||
label="Do Not Render">
|
||||
<menu_item_check.on_check
|
||||
function="Avatar.CheckImpostorMode"
|
||||
parameter="1" />
|
||||
<menu_item_check.on_click
|
||||
function="Avatar.SetImpostorMode"
|
||||
parameter="1" />
|
||||
</menu_item_check>
|
||||
<menu_item_check
|
||||
name="AlwaysRenderFully"
|
||||
label="Render Fully">
|
||||
label="Always">
|
||||
<menu_item_check.on_check
|
||||
function="Avatar.CheckImpostorMode"
|
||||
parameter="2" />
|
||||
|
|
@ -161,7 +154,17 @@
|
|||
function="Avatar.SetImpostorMode"
|
||||
parameter="2" />
|
||||
</menu_item_check>
|
||||
|
||||
<menu_item_check
|
||||
name="DoNotRender"
|
||||
label="Never">
|
||||
<menu_item_check.on_check
|
||||
function="Avatar.CheckImpostorMode"
|
||||
parameter="1" />
|
||||
<menu_item_check.on_click
|
||||
function="Avatar.SetImpostorMode"
|
||||
parameter="1" />
|
||||
</menu_item_check>
|
||||
</context_menu>
|
||||
<menu_item_separator
|
||||
layout="topleft" name="Impostor seperator"/>
|
||||
|
||||
|
|
|
|||
|
|
@ -121,9 +121,13 @@
|
|||
|
||||
<menu_item_separator />
|
||||
|
||||
<context_menu
|
||||
label="Render Avatar"
|
||||
layout="topleft"
|
||||
name="Render Avatar">
|
||||
<menu_item_check
|
||||
name="RenderNormally"
|
||||
label="Render Normally">
|
||||
label="Default">
|
||||
<menu_item_check.on_check
|
||||
function="Avatar.CheckImpostorMode"
|
||||
parameter="0" />
|
||||
|
|
@ -131,19 +135,9 @@
|
|||
function="Avatar.SetImpostorMode"
|
||||
parameter="0" />
|
||||
</menu_item_check>
|
||||
<menu_item_check
|
||||
name="DoNotRender"
|
||||
label="Do Not Render">
|
||||
<menu_item_check.on_check
|
||||
function="Avatar.CheckImpostorMode"
|
||||
parameter="1" />
|
||||
<menu_item_check.on_click
|
||||
function="Avatar.SetImpostorMode"
|
||||
parameter="1" />
|
||||
</menu_item_check>
|
||||
<menu_item_check
|
||||
name="AlwaysRenderFully"
|
||||
label="Render Fully">
|
||||
label="Always">
|
||||
<menu_item_check.on_check
|
||||
function="Avatar.CheckImpostorMode"
|
||||
parameter="2" />
|
||||
|
|
@ -151,6 +145,17 @@
|
|||
function="Avatar.SetImpostorMode"
|
||||
parameter="2" />
|
||||
</menu_item_check>
|
||||
<menu_item_check
|
||||
name="DoNotRender"
|
||||
label="Never">
|
||||
<menu_item_check.on_check
|
||||
function="Avatar.CheckImpostorMode"
|
||||
parameter="1" />
|
||||
<menu_item_check.on_click
|
||||
function="Avatar.SetImpostorMode"
|
||||
parameter="1" />
|
||||
</menu_item_check>
|
||||
</context_menu>
|
||||
|
||||
<menu_item_separator
|
||||
layout="topleft" name="Impostor seperator"/>
|
||||
|
|
|
|||
|
|
@ -0,0 +1,26 @@
|
|||
<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
|
||||
<context_menu
|
||||
layout="topleft"
|
||||
name="Settings">
|
||||
<menu_item_check
|
||||
label="Default"
|
||||
layout="topleft"
|
||||
name="default">
|
||||
<on_click function="Settings.SetRendering" parameter="default"/>
|
||||
<on_check function="Settings.IsSelected" parameter="default" />
|
||||
</menu_item_check>
|
||||
<menu_item_check
|
||||
label="Always render"
|
||||
layout="topleft"
|
||||
name="always_render">
|
||||
<on_click function="Settings.SetRendering" parameter="always"/>
|
||||
<on_check function="Settings.IsSelected" parameter="always" />
|
||||
</menu_item_check>
|
||||
<menu_item_check
|
||||
label="Never render"
|
||||
layout="topleft"
|
||||
name="never_render">
|
||||
<on_click function="Settings.SetRendering" parameter="never"/>
|
||||
<on_check function="Settings.IsSelected" parameter="never" />
|
||||
</menu_item_check>
|
||||
</context_menu>
|
||||
|
|
@ -0,0 +1,18 @@
|
|||
<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
|
||||
<toggleable_menu
|
||||
name="menu_settings_add.xml"
|
||||
left="0" bottom="0" visible="false"
|
||||
mouse_opaque="false">
|
||||
<menu_item_call
|
||||
label="Always Render a Resident..."
|
||||
name="add_avatar_always_render">
|
||||
<on_click
|
||||
function="Settings.AddNewEntry" parameter="always"/>
|
||||
</menu_item_call>
|
||||
<menu_item_call
|
||||
label="Never Render a Resident..."
|
||||
name="add_avatar_never_render">
|
||||
<on_click
|
||||
function="Settings.AddNewEntry" parameter="never"/>
|
||||
</menu_item_call>
|
||||
</toggleable_menu>
|
||||
|
|
@ -62,15 +62,6 @@
|
|||
<menu_item_call.on_enable
|
||||
function="Edit.EnableDelete" />
|
||||
</menu_item_call>
|
||||
<menu_item_call
|
||||
label="Duplicate"
|
||||
name="Duplicate"
|
||||
shortcut="control|D">
|
||||
<menu_item_call.on_click
|
||||
function="Edit.Duplicate" />
|
||||
<menu_item_call.on_enable
|
||||
function="Edit.EnableDuplicate" />
|
||||
</menu_item_call>
|
||||
<menu_item_separator/>
|
||||
<menu_item_call
|
||||
label="Select All"
|
||||
|
|
|
|||
|
|
@ -9,6 +9,7 @@
|
|||
<menu_item_call
|
||||
label="New Inventory Window"
|
||||
layout="topleft"
|
||||
shortcut="control|shift|I"
|
||||
name="new_window">
|
||||
<on_click
|
||||
function="Inventory.GearDefault.Custom.Action"
|
||||
|
|
|
|||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue