diff options
Diffstat (limited to '')
37 files changed, 479 insertions, 205 deletions
diff --git a/linden/indra/llmedia/llmediaimplllmozlib.cpp b/linden/indra/llmedia/llmediaimplllmozlib.cpp index 05d7220..93f4a64 100644 --- a/linden/indra/llmedia/llmediaimplllmozlib.cpp +++ b/linden/indra/llmedia/llmediaimplllmozlib.cpp | |||
@@ -49,9 +49,9 @@ | |||
49 | #include "GL/gl.h" | 49 | #include "GL/gl.h" |
50 | #endif | 50 | #endif |
51 | 51 | ||
52 | #if LL_LINUX | 52 | |
53 | #include <locale.h> | 53 | #include <locale.h> |
54 | #endif | 54 | |
55 | 55 | ||
56 | #include <iostream> | 56 | #include <iostream> |
57 | 57 | ||
@@ -89,23 +89,23 @@ LLMediaImplLLMozLib::LLMediaImplLLMozLib() : | |||
89 | // (static) super-initialization - called once at application startup | 89 | // (static) super-initialization - called once at application startup |
90 | bool LLMediaImplLLMozLib::startup( LLMediaManagerData* init_data ) | 90 | bool LLMediaImplLLMozLib::startup( LLMediaManagerData* init_data ) |
91 | { | 91 | { |
92 | #if LL_LINUX | 92 | |
93 | // Yuck, Mozilla's GTK callbacks play with the locale - push/pop | 93 | // Yuck, Mozilla's GTK callbacks play with the locale - push/pop |
94 | // the locale to protect it, as exotic/non-C locales | 94 | // the locale to protect it, as exotic/non-C locales |
95 | // causes our code lots of general critical weirdness | 95 | // causes our code lots of general critical weirdness |
96 | // and crashness. (SL-35450) | 96 | // and crashness. (SL-35450) |
97 | static std::string saved_locale; | 97 | static std::string saved_locale; |
98 | saved_locale = setlocale(LC_ALL, NULL); | 98 | saved_locale = setlocale(LC_ALL, NULL); |
99 | #endif // LL_LINUX | 99 | |
100 | 100 | ||
101 | bool result = LLMozLib::getInstance()->init( init_data->getBrowserApplicationDir(), | 101 | bool result = LLMozLib::getInstance()->init( init_data->getBrowserApplicationDir(), |
102 | init_data->getBrowserComponentDir(), | 102 | init_data->getBrowserComponentDir(), |
103 | init_data->getBrowserProfileDir(), | 103 | init_data->getBrowserProfileDir(), |
104 | init_data->getBrowserParentWindow() ); | 104 | init_data->getBrowserParentWindow() ); |
105 | 105 | ||
106 | #if LL_LINUX | 106 | |
107 | setlocale(LC_ALL, saved_locale.c_str() ); | 107 | setlocale(LC_ALL, saved_locale.c_str() ); |
108 | #endif // LL_LINUX | 108 | |
109 | 109 | ||
110 | return result; | 110 | return result; |
111 | } | 111 | } |
diff --git a/linden/indra/newview/app_settings/settings.xml b/linden/indra/newview/app_settings/settings.xml index 55e6131..15bb319 100644 --- a/linden/indra/newview/app_settings/settings.xml +++ b/linden/indra/newview/app_settings/settings.xml | |||
@@ -65,7 +65,7 @@ | |||
65 | <key>Type</key> | 65 | <key>Type</key> |
66 | <string>Boolean</string> | 66 | <string>Boolean</string> |
67 | <key>Value</key> | 67 | <key>Value</key> |
68 | <integer>0</integer> | 68 | <integer>1</integer> |
69 | </map> | 69 | </map> |
70 | <key>RLVaHideLockedLayers</key> | 70 | <key>RLVaHideLockedLayers</key> |
71 | <map> | 71 | <map> |
diff --git a/linden/indra/newview/jcfloater_animation_list.cpp b/linden/indra/newview/jcfloater_animation_list.cpp index 9f5c9bb..368e7d6 100644 --- a/linden/indra/newview/jcfloater_animation_list.cpp +++ b/linden/indra/newview/jcfloater_animation_list.cpp | |||
@@ -16,7 +16,7 @@ | |||
16 | * may be used to endorse or promote products derived from this | 16 | * may be used to endorse or promote products derived from this |
17 | * software without specific prior written permission. | 17 | * software without specific prior written permission. |
18 | * | 18 | * |
19 | * THIS SOFTWARE IS PROVIDED BY MODULAR SYSTEMS LTD AND CONTRIBUTORS AS IS | 19 | * THIS SOFTWARE IS PROVIDED BY MODULAR SYSTEMS LTD AND CONTRIBUTORS "AS IS" |
20 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, | 20 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, |
21 | * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 21 | * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
22 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MODULAR SYSTEMS OR CONTRIBUTORS | 22 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MODULAR SYSTEMS OR CONTRIBUTORS |
diff --git a/linden/indra/newview/jcfloater_animation_list.h b/linden/indra/newview/jcfloater_animation_list.h index d8262f0..61bf635 100644 --- a/linden/indra/newview/jcfloater_animation_list.h +++ b/linden/indra/newview/jcfloater_animation_list.h | |||
@@ -16,7 +16,7 @@ | |||
16 | * may be used to endorse or promote products derived from this | 16 | * may be used to endorse or promote products derived from this |
17 | * software without specific prior written permission. | 17 | * software without specific prior written permission. |
18 | * | 18 | * |
19 | * THIS SOFTWARE IS PROVIDED BY MODULAR SYSTEMS LTD AND CONTRIBUTORS AS IS | 19 | * THIS SOFTWARE IS PROVIDED BY MODULAR SYSTEMS LTD AND CONTRIBUTORS "AS IS" |
20 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, | 20 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, |
21 | * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 21 | * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
22 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MODULAR SYSTEMS OR CONTRIBUTORS | 22 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MODULAR SYSTEMS OR CONTRIBUTORS |
diff --git a/linden/indra/newview/llagent.cpp b/linden/indra/newview/llagent.cpp index 022e1cc..8b118e0 100644 --- a/linden/indra/newview/llagent.cpp +++ b/linden/indra/newview/llagent.cpp | |||
@@ -5991,7 +5991,7 @@ void LLAgent::teleportViaLandmark(const LLUUID& landmark_asset_id) | |||
5991 | { | 5991 | { |
5992 | // [RLVa:KB] - Checked: 2009-07-07 (RLVa-1.0.0d) | 5992 | // [RLVa:KB] - Checked: 2009-07-07 (RLVa-1.0.0d) |
5993 | if ( (rlv_handler_t::isEnabled()) && | 5993 | if ( (rlv_handler_t::isEnabled()) && |
5994 | ( (gRlvHandler.hasBehaviour("tplm")) || | 5994 | ( (gRlvHandler.hasBehaviour(RLV_BHVR_TPLM)) || |
5995 | ((gRlvHandler.hasBehaviour(RLV_BHVR_UNSIT)) && (mAvatarObject.notNull()) && (mAvatarObject->mIsSitting)) )) | 5995 | ((gRlvHandler.hasBehaviour(RLV_BHVR_UNSIT)) && (mAvatarObject.notNull()) && (mAvatarObject->mIsSitting)) )) |
5996 | { | 5996 | { |
5997 | return; | 5997 | return; |
@@ -6065,7 +6065,7 @@ void LLAgent::teleportViaLocation(const LLVector3d& pos_global) | |||
6065 | // [RLVa:KB] - Alternate: Snowglobe-1.0 | Checked: 2009-07-07 (RLVa-1.0.0d) | 6065 | // [RLVa:KB] - Alternate: Snowglobe-1.0 | Checked: 2009-07-07 (RLVa-1.0.0d) |
6066 | // If we're getting teleported due to @tpto we should disregard any @tploc=n or @unsit=n restrictions from the same object | 6066 | // If we're getting teleported due to @tpto we should disregard any @tploc=n or @unsit=n restrictions from the same object |
6067 | if ( (rlv_handler_t::isEnabled()) && | 6067 | if ( (rlv_handler_t::isEnabled()) && |
6068 | ( (gRlvHandler.hasBehaviourExcept("tploc", gRlvHandler.getCurrentObject())) || | 6068 | ( (gRlvHandler.hasBehaviourExcept(RLV_BHVR_TPLOC, gRlvHandler.getCurrentObject())) || |
6069 | ( (mAvatarObject.notNull()) && (mAvatarObject->mIsSitting) && | 6069 | ( (mAvatarObject.notNull()) && (mAvatarObject->mIsSitting) && |
6070 | (gRlvHandler.hasBehaviourExcept(RLV_BHVR_UNSIT, gRlvHandler.getCurrentObject()))) ) ) | 6070 | (gRlvHandler.hasBehaviourExcept(RLV_BHVR_UNSIT, gRlvHandler.getCurrentObject()))) ) ) |
6071 | { | 6071 | { |
diff --git a/linden/indra/newview/llappviewer.cpp b/linden/indra/newview/llappviewer.cpp index 448e26b..c432066 100644 --- a/linden/indra/newview/llappviewer.cpp +++ b/linden/indra/newview/llappviewer.cpp | |||
@@ -3927,7 +3927,7 @@ void LLAppViewer::handleLoginComplete() | |||
3927 | writeDebugInfo(); | 3927 | writeDebugInfo(); |
3928 | 3928 | ||
3929 | // [RLVa:KB] - Alternate: Snowglobe-1.0 | Checked: 2009-08-05 (RLVa-1.0.1e) | Modified: RLVa-1.0.1e | 3929 | // [RLVa:KB] - Alternate: Snowglobe-1.0 | Checked: 2009-08-05 (RLVa-1.0.1e) | Modified: RLVa-1.0.1e |
3930 | // TODO-RLVa: find some way to initialize the lookup table when we need them *and* support toggling RLVa at runtime | 3930 | // NOTE: this function isn't called in Imprudence so any changes need to go in idle_startup() instead |
3931 | gRlvHandler.initLookupTables(); | 3931 | gRlvHandler.initLookupTables(); |
3932 | 3932 | ||
3933 | if (rlv_handler_t::isEnabled()) | 3933 | if (rlv_handler_t::isEnabled()) |
diff --git a/linden/indra/newview/llassetuploadresponders.cpp b/linden/indra/newview/llassetuploadresponders.cpp index be3882e..311ff64 100644 --- a/linden/indra/newview/llassetuploadresponders.cpp +++ b/linden/indra/newview/llassetuploadresponders.cpp | |||
@@ -440,7 +440,6 @@ void LLUpdateTaskInventoryResponder::uploadComplete(const LLSD& content) | |||
440 | { | 440 | { |
441 | case LLAssetType::AT_NOTECARD: | 441 | case LLAssetType::AT_NOTECARD: |
442 | { | 442 | { |
443 | |||
444 | // Update the UI with the new asset. | 443 | // Update the UI with the new asset. |
445 | LLPreviewNotecard* nc; | 444 | LLPreviewNotecard* nc; |
446 | nc = (LLPreviewNotecard*)LLPreview::find(item_id); | 445 | nc = (LLPreviewNotecard*)LLPreview::find(item_id); |
@@ -459,6 +458,7 @@ void LLUpdateTaskInventoryResponder::uploadComplete(const LLSD& content) | |||
459 | LLAssetType::AT_NOTECARD); | 458 | LLAssetType::AT_NOTECARD); |
460 | } | 459 | } |
461 | 460 | ||
461 | nc->setAssetId(content["new_asset"].asUUID()); | ||
462 | nc->refreshFromInventory(); | 462 | nc->refreshFromInventory(); |
463 | } | 463 | } |
464 | } | 464 | } |
diff --git a/linden/indra/newview/llchatbar.cpp b/linden/indra/newview/llchatbar.cpp index 608fb54..710677a 100644 --- a/linden/indra/newview/llchatbar.cpp +++ b/linden/indra/newview/llchatbar.cpp | |||
@@ -634,11 +634,11 @@ void LLChatBar::sendChatFromViewer(const LLWString &wtext, EChatType type, BOOL | |||
634 | if ( (0 == channel) && (rlv_handler_t::isEnabled()) ) | 634 | if ( (0 == channel) && (rlv_handler_t::isEnabled()) ) |
635 | { | 635 | { |
636 | // Adjust the (public) chat "volume" on chat and gestures (also takes care of playing the proper animation) | 636 | // Adjust the (public) chat "volume" on chat and gestures (also takes care of playing the proper animation) |
637 | if ( ((CHAT_TYPE_SHOUT == type) || (CHAT_TYPE_NORMAL == type)) && (gRlvHandler.hasBehaviour("chatnormal")) ) | 637 | if ( ((CHAT_TYPE_SHOUT == type) || (CHAT_TYPE_NORMAL == type)) && (gRlvHandler.hasBehaviour(RLV_BHVR_CHATNORMAL)) ) |
638 | type = CHAT_TYPE_WHISPER; | 638 | type = CHAT_TYPE_WHISPER; |
639 | else if ( (CHAT_TYPE_SHOUT == type) && (gRlvHandler.hasBehaviour("chatshout")) ) | 639 | else if ( (CHAT_TYPE_SHOUT == type) && (gRlvHandler.hasBehaviour(RLV_BHVR_CHATSHOUT)) ) |
640 | type = CHAT_TYPE_NORMAL; | 640 | type = CHAT_TYPE_NORMAL; |
641 | else if ( (CHAT_TYPE_WHISPER == type) && (gRlvHandler.hasBehaviour("chatwhisper")) ) | 641 | else if ( (CHAT_TYPE_WHISPER == type) && (gRlvHandler.hasBehaviour(RLV_BHVR_CHATWHISPER)) ) |
642 | type = CHAT_TYPE_NORMAL; | 642 | type = CHAT_TYPE_NORMAL; |
643 | 643 | ||
644 | animate &= !gRlvHandler.hasBehaviour(RLV_BHVR_REDIRCHAT); | 644 | animate &= !gRlvHandler.hasBehaviour(RLV_BHVR_REDIRCHAT); |
@@ -692,11 +692,11 @@ void send_chat_from_viewer(std::string utf8_out_text, EChatType type, S32 channe | |||
692 | if (0 == channel) | 692 | if (0 == channel) |
693 | { | 693 | { |
694 | // (We already did this before, but LLChatHandler::handle() calls this directly) | 694 | // (We already did this before, but LLChatHandler::handle() calls this directly) |
695 | if ( ((CHAT_TYPE_SHOUT == type) || (CHAT_TYPE_NORMAL == type)) && (gRlvHandler.hasBehaviour("chatnormal")) ) | 695 | if ( ((CHAT_TYPE_SHOUT == type) || (CHAT_TYPE_NORMAL == type)) && (gRlvHandler.hasBehaviour(RLV_BHVR_CHATNORMAL)) ) |
696 | type = CHAT_TYPE_WHISPER; | 696 | type = CHAT_TYPE_WHISPER; |
697 | else if ( (CHAT_TYPE_SHOUT == type) && (gRlvHandler.hasBehaviour("chatshout")) ) | 697 | else if ( (CHAT_TYPE_SHOUT == type) && (gRlvHandler.hasBehaviour(RLV_BHVR_CHATSHOUT)) ) |
698 | type = CHAT_TYPE_NORMAL; | 698 | type = CHAT_TYPE_NORMAL; |
699 | else if ( (CHAT_TYPE_WHISPER == type) && (gRlvHandler.hasBehaviour("chatwhisper")) ) | 699 | else if ( (CHAT_TYPE_WHISPER == type) && (gRlvHandler.hasBehaviour(RLV_BHVR_CHATWHISPER)) ) |
700 | type = CHAT_TYPE_NORMAL; | 700 | type = CHAT_TYPE_NORMAL; |
701 | 701 | ||
702 | // Redirect chat if needed | 702 | // Redirect chat if needed |
@@ -707,20 +707,20 @@ void send_chat_from_viewer(std::string utf8_out_text, EChatType type, S32 channe | |||
707 | } | 707 | } |
708 | 708 | ||
709 | // Filter public chat if sendchat restricted (and filter anything that redirchat didn't redirect) | 709 | // Filter public chat if sendchat restricted (and filter anything that redirchat didn't redirect) |
710 | if ( (gRlvHandler.hasBehaviour("sendchat")) || (gRlvHandler.hasBehaviour(RLV_BHVR_REDIRCHAT)) ) | 710 | if ( (gRlvHandler.hasBehaviour(RLV_BHVR_SENDCHAT)) || (gRlvHandler.hasBehaviour(RLV_BHVR_REDIRCHAT)) ) |
711 | gRlvHandler.filterChat(utf8_out_text, true); | 711 | gRlvHandler.filterChat(utf8_out_text, true); |
712 | } | 712 | } |
713 | else | 713 | else |
714 | { | 714 | { |
715 | // Don't allow chat on a non-public channel if sendchannel restricted (unless the channel is an exception) | 715 | // Don't allow chat on a non-public channel if sendchannel restricted (unless the channel is an exception) |
716 | if ( (gRlvHandler.hasBehaviour("sendchannel")) && (!gRlvHandler.hasBehaviour("sendchannel", llformat("%d", channel))) ) | 716 | if ( (gRlvHandler.hasBehaviour(RLV_BHVR_SENDCHANNEL)) && (!gRlvHandler.isException(RLV_BHVR_SENDCHANNEL, channel)) ) |
717 | return; | 717 | return; |
718 | 718 | ||
719 | // Don't allow chat on debug channel if @sendchat, @redirchat or @rediremote restricted (shows as public chat on viewers) | 719 | // Don't allow chat on debug channel if @sendchat, @redirchat or @rediremote restricted (shows as public chat on viewers) |
720 | if (channel >= CHAT_CHANNEL_DEBUG) | 720 | if (channel >= CHAT_CHANNEL_DEBUG) |
721 | { | 721 | { |
722 | bool fIsEmote = rlvIsEmote(utf8_out_text); | 722 | bool fIsEmote = rlvIsEmote(utf8_out_text); |
723 | if ( (gRlvHandler.hasBehaviour("sendchat")) || | 723 | if ( (gRlvHandler.hasBehaviour(RLV_BHVR_SENDCHAT)) || |
724 | ((!fIsEmote) && (gRlvHandler.hasBehaviour(RLV_BHVR_REDIRCHAT))) || | 724 | ((!fIsEmote) && (gRlvHandler.hasBehaviour(RLV_BHVR_REDIRCHAT))) || |
725 | ((fIsEmote) && (gRlvHandler.hasBehaviour(RLV_BHVR_REDIREMOTE))) ) | 725 | ((fIsEmote) && (gRlvHandler.hasBehaviour(RLV_BHVR_REDIREMOTE))) ) |
726 | { | 726 | { |
diff --git a/linden/indra/newview/llfloatergroups.cpp b/linden/indra/newview/llfloatergroups.cpp index 23e2f4d..9599089 100644 --- a/linden/indra/newview/llfloatergroups.cpp +++ b/linden/indra/newview/llfloatergroups.cpp | |||
@@ -61,7 +61,7 @@ | |||
61 | std::map<const LLUUID, LLFloaterGroupPicker*> LLFloaterGroupPicker::sInstances; | 61 | std::map<const LLUUID, LLFloaterGroupPicker*> LLFloaterGroupPicker::sInstances; |
62 | 62 | ||
63 | // helper functions | 63 | // helper functions |
64 | void init_group_list(LLScrollListCtrl* ctrl, const LLUUID& highlight_id, U64 powers_mask = GP_ALL_POWERS); | 64 | void init_group_list(LLScrollListCtrl* ctrl, const LLUUID& highlight_id, const std::string& none_text, U64 powers_mask = GP_ALL_POWERS); |
65 | 65 | ||
66 | ///---------------------------------------------------------------------------- | 66 | ///---------------------------------------------------------------------------- |
67 | /// Class LLFloaterGroupPicker | 67 | /// Class LLFloaterGroupPicker |
@@ -116,7 +116,8 @@ void LLFloaterGroupPicker::setPowersMask(U64 powers_mask) | |||
116 | 116 | ||
117 | BOOL LLFloaterGroupPicker::postBuild() | 117 | BOOL LLFloaterGroupPicker::postBuild() |
118 | { | 118 | { |
119 | init_group_list(getChild<LLScrollListCtrl>("group list"), gAgent.getGroupID(), mPowersMask); | 119 | const std::string none_text = getString("none"); |
120 | init_group_list(getChild<LLScrollListCtrl>("group list"), gAgent.getGroupID(), none_text, mPowersMask); | ||
120 | 121 | ||
121 | childSetAction("OK", onBtnOK, this); | 122 | childSetAction("OK", onBtnOK, this); |
122 | 123 | ||
@@ -200,7 +201,8 @@ void LLPanelGroups::reset() | |||
200 | childSetTextArg("groupcount", "[COUNT]", llformat("%d",gAgent.mGroups.count())); | 201 | childSetTextArg("groupcount", "[COUNT]", llformat("%d",gAgent.mGroups.count())); |
201 | childSetTextArg("groupcount", "[MAX]", llformat("%d",MAX_AGENT_GROUPS)); | 202 | childSetTextArg("groupcount", "[MAX]", llformat("%d",MAX_AGENT_GROUPS)); |
202 | 203 | ||
203 | init_group_list(getChild<LLScrollListCtrl>("group list"), gAgent.getGroupID()); | 204 | const std::string none_text = getString("none"); |
205 | init_group_list(getChild<LLScrollListCtrl>("group list"), gAgent.getGroupID(), none_text); | ||
204 | enableButtons(); | 206 | enableButtons(); |
205 | } | 207 | } |
206 | 208 | ||
@@ -211,7 +213,8 @@ BOOL LLPanelGroups::postBuild() | |||
211 | childSetTextArg("groupcount", "[COUNT]", llformat("%d",gAgent.mGroups.count())); | 213 | childSetTextArg("groupcount", "[COUNT]", llformat("%d",gAgent.mGroups.count())); |
212 | childSetTextArg("groupcount", "[MAX]", llformat("%d",MAX_AGENT_GROUPS)); | 214 | childSetTextArg("groupcount", "[MAX]", llformat("%d",MAX_AGENT_GROUPS)); |
213 | 215 | ||
214 | init_group_list(getChild<LLScrollListCtrl>("group list"), gAgent.getGroupID()); | 216 | const std::string none_text = getString("none"); |
217 | init_group_list(getChild<LLScrollListCtrl>("group list"), gAgent.getGroupID(), none_text); | ||
215 | 218 | ||
216 | childSetAction("Activate", onBtnActivate, this); | 219 | childSetAction("Activate", onBtnActivate, this); |
217 | 220 | ||
@@ -457,7 +460,7 @@ void LLPanelGroups::onGroupList(LLUICtrl* ctrl, void* userdata) | |||
457 | if(self) self->enableButtons(); | 460 | if(self) self->enableButtons(); |
458 | } | 461 | } |
459 | 462 | ||
460 | void init_group_list(LLScrollListCtrl* ctrl, const LLUUID& highlight_id, U64 powers_mask) | 463 | void init_group_list(LLScrollListCtrl* ctrl, const LLUUID& highlight_id, const std::string& none_text, U64 powers_mask) |
461 | { | 464 | { |
462 | S32 count = gAgent.mGroups.count(); | 465 | S32 count = gAgent.mGroups.count(); |
463 | LLUUID id; | 466 | LLUUID id; |
@@ -499,7 +502,7 @@ void init_group_list(LLScrollListCtrl* ctrl, const LLUUID& highlight_id, U64 pow | |||
499 | LLSD element; | 502 | LLSD element; |
500 | element["id"] = LLUUID::null; | 503 | element["id"] = LLUUID::null; |
501 | element["columns"][0]["column"] = "name"; | 504 | element["columns"][0]["column"] = "name"; |
502 | element["columns"][0]["value"] = "none"; // *TODO: Translate | 505 | element["columns"][0]["value"] = none_text; |
503 | element["columns"][0]["font"] = "SANSSERIF"; | 506 | element["columns"][0]["font"] = "SANSSERIF"; |
504 | element["columns"][0]["font-style"] = style; | 507 | element["columns"][0]["font-style"] = style; |
505 | 508 | ||
diff --git a/linden/indra/newview/llfloatermap.cpp b/linden/indra/newview/llfloatermap.cpp index 49563a6..3807a90 100644 --- a/linden/indra/newview/llfloatermap.cpp +++ b/linden/indra/newview/llfloatermap.cpp | |||
@@ -279,25 +279,38 @@ void LLFloaterMap::populateRadar() | |||
279 | // [/RLVa:KB] | 279 | // [/RLVa:KB] |
280 | 280 | ||
281 | // check if they're in certain ranges and notify user if we've enabled that | 281 | // check if they're in certain ranges and notify user if we've enabled that |
282 | LLVector3d temp = positions[i] - current_pos; | 282 | LLVector3d temp = positions[i]; |
283 | F32 distance = llround((F32)temp.magVec(), 0.1f); | 283 | if (positions[i].mdV[VZ] == 0.0f) // LL only sends height value up to 1024m, try to work around it |
284 | /*char dist[32]; | 284 | { |
285 | sprintf(dist, "%.1f", distance); | 285 | LLViewerObject *av_obj = gObjectList.findObject(avatar_ids[i]); |
286 | std::string dist_string = dist;*/ | 286 | if (av_obj != NULL && av_obj->isAvatar()) |
287 | std::string dist_string = llformat("%.1f", distance); | 287 | { |
288 | LLVOAvatar* avatarp = (LLVOAvatar*)av_obj; | ||
289 | if (avatarp != NULL) | ||
290 | { | ||
291 | temp = avatarp->getPositionGlobal(); | ||
292 | } | ||
293 | } | ||
294 | } | ||
295 | F64 distance = dist_vec(temp, current_pos); | ||
296 | // we round for accuracy when avs tp in | ||
297 | std::string dist_string = llformat("%.1f", llround((F32)distance, 0.1f)); | ||
298 | |||
299 | /*llinfos << "Avatar :" << fullname << " Position: " << positions[i] << " Your Position: " | ||
300 | << current_pos << " Distance: " << distance << llendl;*/ | ||
288 | 301 | ||
289 | if (notify_chat) | 302 | if (notify_chat) |
290 | { | 303 | { |
291 | if (distance < 20.0f) | 304 | if (distance < 20.0f) |
292 | { | 305 | { |
293 | if (!getInChatList(avatar_ids[i])) | 306 | if (!isInChatList(avatar_ids[i])) |
294 | { | 307 | { |
295 | addToChatList(avatar_ids[i], dist_string); | 308 | addToChatList(avatar_ids[i], dist_string); |
296 | } | 309 | } |
297 | } | 310 | } |
298 | else | 311 | else |
299 | { | 312 | { |
300 | if (getInChatList(avatar_ids[i])) | 313 | if (isInChatList(avatar_ids[i])) |
301 | { | 314 | { |
302 | removeFromChatList(avatar_ids[i]); | 315 | removeFromChatList(avatar_ids[i]); |
303 | } | 316 | } |
@@ -311,7 +324,7 @@ void LLFloaterMap::populateRadar() | |||
311 | 324 | ||
312 | if (notify_sim) | 325 | if (notify_sim) |
313 | { | 326 | { |
314 | if (!getInChatList(avatar_ids[i]) && !getInSimAvList(avatar_ids[i])) | 327 | if (!isInChatList(avatar_ids[i]) && !getInSimAvList(avatar_ids[i])) |
315 | { | 328 | { |
316 | LLViewerObject *av_obj = gObjectList.findObject(avatar_ids[i]); | 329 | LLViewerObject *av_obj = gObjectList.findObject(avatar_ids[i]); |
317 | if (av_obj != NULL && av_obj->isAvatar()) | 330 | if (av_obj != NULL && av_obj->isAvatar()) |
@@ -338,7 +351,7 @@ void LLFloaterMap::populateRadar() | |||
338 | { | 351 | { |
339 | // append typing string | 352 | // append typing string |
340 | std::string typing = ""; | 353 | std::string typing = ""; |
341 | if (getIsTyping(avatar_ids[i])) | 354 | if (isTyping(avatar_ids[i])) |
342 | { | 355 | { |
343 | typing = getString("is_typing")+ " "; | 356 | typing = getString("is_typing")+ " "; |
344 | } | 357 | } |
@@ -397,7 +410,7 @@ void LLFloaterMap::updateChatList(std::vector<LLUUID> agent_ids) | |||
397 | } | 410 | } |
398 | } | 411 | } |
399 | 412 | ||
400 | bool LLFloaterMap::getInChatList(LLUUID agent_id) | 413 | bool LLFloaterMap::isInChatList(LLUUID agent_id) |
401 | { | 414 | { |
402 | if (mChatAvatars.count(agent_id) > 0) | 415 | if (mChatAvatars.count(agent_id) > 0) |
403 | { | 416 | { |
@@ -426,7 +439,7 @@ void LLFloaterMap::removeFromChatList(LLUUID agent_id) | |||
426 | mChatAvatars.erase(agent_id); | 439 | mChatAvatars.erase(agent_id); |
427 | } | 440 | } |
428 | 441 | ||
429 | bool LLFloaterMap::getIsTyping(LLUUID agent_id) | 442 | bool LLFloaterMap::isTyping(LLUUID agent_id) |
430 | { | 443 | { |
431 | if (mTypingAvatars.count(agent_id) > 0) | 444 | if (mTypingAvatars.count(agent_id) > 0) |
432 | { | 445 | { |
@@ -439,7 +452,7 @@ void LLFloaterMap::updateTypingList(LLUUID agent_id, bool remove) | |||
439 | { | 452 | { |
440 | if (remove) | 453 | if (remove) |
441 | { | 454 | { |
442 | if (getIsTyping(agent_id)) | 455 | if (isTyping(agent_id)) |
443 | { | 456 | { |
444 | mTypingAvatars.erase(agent_id); | 457 | mTypingAvatars.erase(agent_id); |
445 | } | 458 | } |
@@ -503,7 +516,7 @@ void LLFloaterMap::toggleButtons() | |||
503 | enable = mSelectedAvatar.notNull() ? visibleItemsSelected() : FALSE; | 516 | enable = mSelectedAvatar.notNull() ? visibleItemsSelected() : FALSE; |
504 | enable_unmute = mSelectedAvatar.notNull() ? LLMuteList::getInstance()->isMuted(mSelectedAvatar) : FALSE; | 517 | enable_unmute = mSelectedAvatar.notNull() ? LLMuteList::getInstance()->isMuted(mSelectedAvatar) : FALSE; |
505 | enable_track = gAgent.isGodlike() || is_agent_mappable(mSelectedAvatar); | 518 | enable_track = gAgent.isGodlike() || is_agent_mappable(mSelectedAvatar); |
506 | enable_estate = getKickable(mSelectedAvatar); | 519 | enable_estate = isKickable(mSelectedAvatar); |
507 | enable_friend = !is_agent_friend(mSelectedAvatar); | 520 | enable_friend = !is_agent_friend(mSelectedAvatar); |
508 | } | 521 | } |
509 | else | 522 | else |
@@ -520,10 +533,21 @@ void LLFloaterMap::toggleButtons() | |||
520 | childSetEnabled("freeze_btn", enable_estate); | 533 | childSetEnabled("freeze_btn", enable_estate); |
521 | childSetEnabled("eject_btn", enable_estate); | 534 | childSetEnabled("eject_btn", enable_estate); |
522 | childSetEnabled("mute_btn", enable); | 535 | childSetEnabled("mute_btn", enable); |
523 | childSetEnabled("unmute_btn", enable_unmute); | ||
524 | childSetEnabled("ar_btn", enable); | 536 | childSetEnabled("ar_btn", enable); |
525 | childSetEnabled("estate_eject_btn", enable_estate); | 537 | childSetEnabled("estate_eject_btn", enable_estate); |
526 | 538 | ||
539 | if (enable_unmute) | ||
540 | { | ||
541 | childSetVisible("mute_btn", false); | ||
542 | childSetEnabled("unmute_btn", true); | ||
543 | childSetVisible("unmute_btn", true); | ||
544 | } | ||
545 | else | ||
546 | { | ||
547 | childSetVisible("mute_btn", true); | ||
548 | childSetVisible("unmute_btn", false); | ||
549 | } | ||
550 | |||
527 | // [RLVa:KB] - Imprudence-1.2.0 | 551 | // [RLVa:KB] - Imprudence-1.2.0 |
528 | // Bit clumsy, but this way the RLV stuff is in its own separate block and keeps the code above clean - Kitty | 552 | // Bit clumsy, but this way the RLV stuff is in its own separate block and keeps the code above clean - Kitty |
529 | if ( (rlv_handler_t::isEnabled()) && (mSelectedAvatar.notNull()) ) | 553 | if ( (rlv_handler_t::isEnabled()) && (mSelectedAvatar.notNull()) ) |
@@ -552,7 +576,7 @@ void LLFloaterMap::toggleButtons() | |||
552 | // [/RLVa:KB] | 576 | // [/RLVa:KB] |
553 | } | 577 | } |
554 | 578 | ||
555 | BOOL LLFloaterMap::getKickable(const LLUUID &agent_id) | 579 | BOOL LLFloaterMap::isKickable(const LLUUID &agent_id) |
556 | { | 580 | { |
557 | if (agent_id.notNull()) | 581 | if (agent_id.notNull()) |
558 | { | 582 | { |
@@ -568,6 +592,7 @@ BOOL LLFloaterMap::getKickable(const LLUUID &agent_id) | |||
568 | if (LLWorld::getInstance()->positionRegionValidGlobal(pos_global)) | 592 | if (LLWorld::getInstance()->positionRegionValidGlobal(pos_global)) |
569 | { | 593 | { |
570 | LLParcel* parcel = LLViewerParcelMgr::getInstance()->selectParcelAt(pos_global)->getParcel(); | 594 | LLParcel* parcel = LLViewerParcelMgr::getInstance()->selectParcelAt(pos_global)->getParcel(); |
595 | LLViewerParcelMgr::getInstance()->deselectLand(); | ||
571 | 596 | ||
572 | BOOL new_value = (region != NULL); | 597 | BOOL new_value = (region != NULL); |
573 | 598 | ||
diff --git a/linden/indra/newview/llfloatermap.h b/linden/indra/newview/llfloatermap.h index af4d1cc..aedbcb8 100644 --- a/linden/indra/newview/llfloatermap.h +++ b/linden/indra/newview/llfloatermap.h | |||
@@ -52,7 +52,7 @@ public: | |||
52 | // returns true if agent_id belongs to a developer listed in llfloatermap.cpp | 52 | // returns true if agent_id belongs to a developer listed in llfloatermap.cpp |
53 | static bool isImpDev(LLUUID agent_id); | 53 | static bool isImpDev(LLUUID agent_id); |
54 | 54 | ||
55 | bool getIsTyping(LLUUID agent_id); | 55 | bool isTyping(LLUUID agent_id); |
56 | void updateTypingList(LLUUID agent_id, bool remove); | 56 | void updateTypingList(LLUUID agent_id, bool remove); |
57 | 57 | ||
58 | BOOL postBuild(); | 58 | BOOL postBuild(); |
@@ -85,12 +85,12 @@ private: | |||
85 | static void onList(LLUICtrl* ctrl, void* user_data); | 85 | static void onList(LLUICtrl* ctrl, void* user_data); |
86 | static void onRangeChange(LLFocusableElement* focus, void* user_data); | 86 | static void onRangeChange(LLFocusableElement* focus, void* user_data); |
87 | BOOL visibleItemsSelected() const; | 87 | BOOL visibleItemsSelected() const; |
88 | BOOL getKickable(const LLUUID &agent_id); | 88 | BOOL isKickable(const LLUUID &agent_id); |
89 | void toggleButtons(); | 89 | void toggleButtons(); |
90 | void populateRadar(); | 90 | void populateRadar(); |
91 | 91 | ||
92 | void updateChatList(std::vector<LLUUID> agent_ids); | 92 | void updateChatList(std::vector<LLUUID> agent_ids); |
93 | bool getInChatList(LLUUID agent_id); | 93 | bool isInChatList(LLUUID agent_id); |
94 | void addToChatList(LLUUID agent_id, std::string distance); | 94 | void addToChatList(LLUUID agent_id, std::string distance); |
95 | void removeFromChatList(LLUUID agent_id); | 95 | void removeFromChatList(LLUUID agent_id); |
96 | 96 | ||
diff --git a/linden/indra/newview/llfloaterworldmap.cpp b/linden/indra/newview/llfloaterworldmap.cpp index 70223c9..028ebf2 100644 --- a/linden/indra/newview/llfloaterworldmap.cpp +++ b/linden/indra/newview/llfloaterworldmap.cpp | |||
@@ -770,7 +770,7 @@ void LLFloaterWorldMap::updateLocation() | |||
770 | void LLFloaterWorldMap::trackURL(const std::string& region_name, S32 x_coord, S32 y_coord, S32 z_coord) | 770 | void LLFloaterWorldMap::trackURL(const std::string& region_name, S32 x_coord, S32 y_coord, S32 z_coord) |
771 | { | 771 | { |
772 | LLSimInfo* sim_info = LLWorldMap::getInstance()->simInfoFromName(region_name); | 772 | LLSimInfo* sim_info = LLWorldMap::getInstance()->simInfoFromName(region_name); |
773 | z_coord = llclamp(z_coord, 0, 1000); | 773 | z_coord = llclamp(z_coord, 0, 4096); |
774 | if (sim_info) | 774 | if (sim_info) |
775 | { | 775 | { |
776 | LLVector3 local_pos; | 776 | LLVector3 local_pos; |
diff --git a/linden/indra/newview/llinventorybridge.cpp b/linden/indra/newview/llinventorybridge.cpp index 0d5625c..5060d21 100644 --- a/linden/indra/newview/llinventorybridge.cpp +++ b/linden/indra/newview/llinventorybridge.cpp | |||
@@ -2943,7 +2943,7 @@ void open_notecard(LLViewerInventoryItem* inv_item, | |||
2943 | BOOL take_focus) | 2943 | BOOL take_focus) |
2944 | { | 2944 | { |
2945 | // [RLVa:KB] - Checked: 2009-07-06 (RLVa-1.0.0c) | 2945 | // [RLVa:KB] - Checked: 2009-07-06 (RLVa-1.0.0c) |
2946 | if ( (rlv_handler_t::isEnabled()) && (gRlvHandler.hasBehaviour("viewnote")) ) | 2946 | if ( (rlv_handler_t::isEnabled()) && (gRlvHandler.hasBehaviour(RLV_BHVR_VIEWNOTE)) ) |
2947 | { | 2947 | { |
2948 | return; | 2948 | return; |
2949 | } | 2949 | } |
diff --git a/linden/indra/newview/llpanelinventory.cpp b/linden/indra/newview/llpanelinventory.cpp index 7ab850f..0ae2aec 100644 --- a/linden/indra/newview/llpanelinventory.cpp +++ b/linden/indra/newview/llpanelinventory.cpp | |||
@@ -1377,7 +1377,7 @@ void LLTaskNotecardBridge::openItem() | |||
1377 | return; | 1377 | return; |
1378 | } | 1378 | } |
1379 | // [RLVa:KB] - Checked: 2009-07-06 (RLVa-1.0.0c) | 1379 | // [RLVa:KB] - Checked: 2009-07-06 (RLVa-1.0.0c) |
1380 | if ( (rlv_handler_t::isEnabled()) && ((gRlvHandler.hasBehaviour("viewnote")) || (!gRlvHandler.isDetachable(object))) ) | 1380 | if ( (rlv_handler_t::isEnabled()) && ((gRlvHandler.hasBehaviour(RLV_BHVR_VIEWNOTE)) || (!gRlvHandler.isDetachable(object))) ) |
1381 | { | 1381 | { |
1382 | return; | 1382 | return; |
1383 | } | 1383 | } |
diff --git a/linden/indra/newview/llpreview.cpp b/linden/indra/newview/llpreview.cpp index 1a6d2ca..055851b 100644 --- a/linden/indra/newview/llpreview.cpp +++ b/linden/indra/newview/llpreview.cpp | |||
@@ -596,3 +596,32 @@ void LLMultiPreview::setAutoOpenInstance(LLMultiPreview* previewp, const LLUUID& | |||
596 | sAutoOpenPreviewHandles[id] = previewp->getHandle(); | 596 | sAutoOpenPreviewHandles[id] = previewp->getHandle(); |
597 | } | 597 | } |
598 | } | 598 | } |
599 | |||
600 | void LLPreview::setAssetId(const LLUUID& asset_id) | ||
601 | { | ||
602 | const LLViewerInventoryItem* item = getItem(); | ||
603 | if(NULL == item) | ||
604 | { | ||
605 | return; | ||
606 | } | ||
607 | |||
608 | if(mObjectUUID.isNull()) | ||
609 | { | ||
610 | // Update avatar inventory asset_id. | ||
611 | LLPointer<LLViewerInventoryItem> new_item = new LLViewerInventoryItem(item); | ||
612 | new_item->setAssetUUID(asset_id); | ||
613 | gInventory.updateItem(new_item); | ||
614 | gInventory.notifyObservers(); | ||
615 | } | ||
616 | else | ||
617 | { | ||
618 | // Update object inventory asset_id. | ||
619 | LLViewerObject* object = gObjectList.findObject(mObjectUUID); | ||
620 | if(NULL == object) | ||
621 | { | ||
622 | llwarns << "LLPreview::setAssetId() called on unrecognized object, UUID : " << mObjectUUID << llendl; | ||
623 | return; | ||
624 | } | ||
625 | object->updateViewerInventoryAsset(item, asset_id); | ||
626 | } | ||
627 | } | ||
diff --git a/linden/indra/newview/llpreview.h b/linden/indra/newview/llpreview.h index 74daca6..4e159f3 100644 --- a/linden/indra/newview/llpreview.h +++ b/linden/indra/newview/llpreview.h | |||
@@ -83,6 +83,7 @@ public: | |||
83 | void setItemID(const LLUUID& item_id); | 83 | void setItemID(const LLUUID& item_id); |
84 | void setObjectID(const LLUUID& object_id); | 84 | void setObjectID(const LLUUID& object_id); |
85 | void setSourceID(const LLUUID& source_id); | 85 | void setSourceID(const LLUUID& source_id); |
86 | void setAssetId(const LLUUID& asset_id); | ||
86 | const LLViewerInventoryItem *getItem() const; // searches if not constructed with it | 87 | const LLViewerInventoryItem *getItem() const; // searches if not constructed with it |
87 | 88 | ||
88 | static LLPreview* find(const LLUUID& item_uuid); | 89 | static LLPreview* find(const LLUUID& item_uuid); |
diff --git a/linden/indra/newview/llstartup.cpp b/linden/indra/newview/llstartup.cpp index 346f7dd..d747bd2 100644 --- a/linden/indra/newview/llstartup.cpp +++ b/linden/indra/newview/llstartup.cpp | |||
@@ -2647,6 +2647,23 @@ bool idle_startup() | |||
2647 | 2647 | ||
2648 | LLAppViewer::instance()->initMainloopTimeout("Mainloop Init"); | 2648 | LLAppViewer::instance()->initMainloopTimeout("Mainloop Init"); |
2649 | 2649 | ||
2650 | // [RLVa:KB] - Alternate: Snowglobe-1.0 | Checked: 2009-08-05 (RLVa-1.0.1e) | Modified: RLVa-1.0.1e | ||
2651 | // RELEASE-RLVa: this should go in LLAppViewer::handleLoginComplete() but Imprudence doesn't call that function | ||
2652 | gRlvHandler.initLookupTables(); | ||
2653 | |||
2654 | if (rlv_handler_t::isEnabled()) | ||
2655 | { | ||
2656 | RlvCurrentlyWorn::fetchWorn(); | ||
2657 | rlv_handler_t::fetchSharedInventory(); | ||
2658 | |||
2659 | #ifdef RLV_EXTENSION_STARTLOCATION | ||
2660 | RlvSettings::updateLoginLastLocation(); | ||
2661 | #endif // RLV_EXTENSION_STARTLOCATION | ||
2662 | |||
2663 | gRlvHandler.processRetainedCommands(); | ||
2664 | } | ||
2665 | // [/RLVa:KB] | ||
2666 | |||
2650 | return TRUE; | 2667 | return TRUE; |
2651 | } | 2668 | } |
2652 | 2669 | ||
diff --git a/linden/indra/newview/llviewermenu.cpp b/linden/indra/newview/llviewermenu.cpp index ceb5d5f..d0e326c 100644 --- a/linden/indra/newview/llviewermenu.cpp +++ b/linden/indra/newview/llviewermenu.cpp | |||
@@ -1423,7 +1423,7 @@ void init_debug_rlva_menu(LLMenuGL* menu) | |||
1423 | 1423 | ||
1424 | #ifdef RLV_EXTENSION_ENABLE_WEAR | 1424 | #ifdef RLV_EXTENSION_ENABLE_WEAR |
1425 | if (gSavedSettings.controlExists(RLV_SETTING_ENABLEWEAR)) | 1425 | if (gSavedSettings.controlExists(RLV_SETTING_ENABLEWEAR)) |
1426 | menu->append(new LLMenuItemCheckGL("Enable Wear", menu_toggle_control, NULL, menu_check_control, (void*)RLV_SETTING_ENABLEWEAR)); | 1426 | menu->append(new LLMenuItemCheckGL("Enable Wear", menu_toggle_control, rlvEnableWearEnabler, menu_check_control, (void*)RLV_SETTING_ENABLEWEAR)); |
1427 | menu->appendSeparator(); | 1427 | menu->appendSeparator(); |
1428 | #endif // RLV_EXTENSION_ENABLE_WEAR | 1428 | #endif // RLV_EXTENSION_ENABLE_WEAR |
1429 | 1429 | ||
@@ -10368,6 +10368,35 @@ class LLAvatarReportAbuse : public view_listener_t | |||
10368 | 10368 | ||
10369 | 10369 | ||
10370 | 10370 | ||
10371 | //////////////////////////// | ||
10372 | // ALLOW MULTIPLE VIEWERS // | ||
10373 | //////////////////////////// | ||
10374 | |||
10375 | |||
10376 | class LLAdvancedToggleMultipleViewers : public view_listener_t | ||
10377 | { | ||
10378 | bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata) | ||
10379 | { | ||
10380 | BOOL cur_val = gSavedSettings.getBOOL("AllowMultipleViewers"); | ||
10381 | gSavedSettings.setBOOL("AllowMultipleViewers", !cur_val ); | ||
10382 | return true; | ||
10383 | } | ||
10384 | }; | ||
10385 | |||
10386 | |||
10387 | class LLAdvancedCheckMultipleViewers : public view_listener_t | ||
10388 | { | ||
10389 | bool handleEvent(LLPointer<LLEvent> event, const LLSD& userdata) | ||
10390 | { | ||
10391 | bool new_value = gSavedSettings.getBOOL("AllowMultipleViewers"); | ||
10392 | std::string control_name = userdata["control"].asString(); | ||
10393 | gMenuHolder->findControl(control_name)->setValue(new_value); | ||
10394 | return true; | ||
10395 | } | ||
10396 | }; | ||
10397 | |||
10398 | |||
10399 | |||
10371 | /////////////// | 10400 | /////////////// |
10372 | // RLVa Main // | 10401 | // RLVa Main // |
10373 | /////////////// | 10402 | /////////////// |
@@ -10793,7 +10822,8 @@ void initialize_menus() | |||
10793 | addMenu(new LLAdvancedCheckViewAdminOptions(), "Advanced.CheckViewAdminOptions"); | 10822 | addMenu(new LLAdvancedCheckViewAdminOptions(), "Advanced.CheckViewAdminOptions"); |
10794 | addMenu(new LLAdvancedRequestAdminStatus(), "Advanced.RequestAdminStatus"); | 10823 | addMenu(new LLAdvancedRequestAdminStatus(), "Advanced.RequestAdminStatus"); |
10795 | addMenu(new LLAdvancedLeaveAdminStatus(), "Advanced.LeaveAdminStatus"); | 10824 | addMenu(new LLAdvancedLeaveAdminStatus(), "Advanced.LeaveAdminStatus"); |
10796 | 10825 | addMenu(new LLAdvancedToggleMultipleViewers(), "Advanced.ToggleMultipleViewers"); | |
10826 | addMenu(new LLAdvancedCheckMultipleViewers(), "Advanced.CheckMultipleViewers"); | ||
10797 | 10827 | ||
10798 | // RLVa | 10828 | // RLVa |
10799 | addMenu(new RLVaMainToggle(), "RLVa.Main.Toggle"); | 10829 | addMenu(new RLVaMainToggle(), "RLVa.Main.Toggle"); |
diff --git a/linden/indra/newview/llviewermessage.cpp b/linden/indra/newview/llviewermessage.cpp index d784f52..eeef114 100644 --- a/linden/indra/newview/llviewermessage.cpp +++ b/linden/indra/newview/llviewermessage.cpp | |||
@@ -2485,7 +2485,7 @@ void process_chat_from_simulator(LLMessageSystem *msg, void **user_data) | |||
2485 | color.setVec(1.f,1.f,1.f,1.f); | 2485 | color.setVec(1.f,1.f,1.f,1.f); |
2486 | msg->getStringFast(_PREHASH_ChatData, _PREHASH_Message, mesg); | 2486 | msg->getStringFast(_PREHASH_ChatData, _PREHASH_Message, mesg); |
2487 | 2487 | ||
2488 | // [RLVa:KB] - Checked: 2009-08-04 (RLVa-1.0.1d) | Modified: RLVa-1.0.1d | 2488 | // [RLVa:KB] - Checked: 2009-10-06 (RLVa-1.0.4d) | Modified: RLVa-1.0.4d |
2489 | if ( (rlv_handler_t::isEnabled()) && | 2489 | if ( (rlv_handler_t::isEnabled()) && |
2490 | (CHAT_TYPE_START != chat.mChatType) && (CHAT_TYPE_STOP != chat.mChatType) && (CHAT_TYPE_OWNER != chat.mChatType) ) | 2490 | (CHAT_TYPE_START != chat.mChatType) && (CHAT_TYPE_STOP != chat.mChatType) && (CHAT_TYPE_OWNER != chat.mChatType) ) |
2491 | { | 2491 | { |
@@ -2495,7 +2495,8 @@ void process_chat_from_simulator(LLMessageSystem *msg, void **user_data) | |||
2495 | // Filtering "rules": | 2495 | // Filtering "rules": |
2496 | // avatar => filter all avie text (unless it's this avie or they're an exemption) | 2496 | // avatar => filter all avie text (unless it's this avie or they're an exemption) |
2497 | // objects => filter everything except attachments this avie owns | 2497 | // objects => filter everything except attachments this avie owns |
2498 | if ( ((CHAT_SOURCE_AGENT == chat.mSourceType) && (from_id != gAgent.getID())) || (!is_owned_by_me) || (!is_attachment) ) | 2498 | if ( ( (CHAT_SOURCE_AGENT == chat.mSourceType) && (from_id != gAgent.getID()) ) || |
2499 | ( (CHAT_SOURCE_OBJECT == chat.mSourceType) && ((!is_owned_by_me) || (!is_attachment)) ) ) | ||
2499 | { | 2500 | { |
2500 | if (!rlvIsEmote(mesg)) | 2501 | if (!rlvIsEmote(mesg)) |
2501 | { | 2502 | { |
@@ -2574,7 +2575,7 @@ void process_chat_from_simulator(LLMessageSystem *msg, void **user_data) | |||
2574 | 2575 | ||
2575 | if (LLFloaterMap::getInstance()) | 2576 | if (LLFloaterMap::getInstance()) |
2576 | { | 2577 | { |
2577 | if (LLFloaterMap::getInstance()->getIsTyping(from_id)) | 2578 | if (LLFloaterMap::getInstance()->isTyping(from_id)) |
2578 | { | 2579 | { |
2579 | LLFloaterMap::getInstance()->updateTypingList(from_id, true); | 2580 | LLFloaterMap::getInstance()->updateTypingList(from_id, true); |
2580 | } | 2581 | } |
@@ -4933,7 +4934,7 @@ void process_script_question(LLMessageSystem *msg, void **user_data) | |||
4933 | // [RLVa:KB] - Version: 1.22.11 | Checked: 2009-07-10 (RLVa-1.0.0g) | Modified: RLVa-0.2.0e | 4934 | // [RLVa:KB] - Version: 1.22.11 | Checked: 2009-07-10 (RLVa-1.0.0g) | Modified: RLVa-0.2.0e |
4934 | S32 rlvQuestionsOther = questions; | 4935 | S32 rlvQuestionsOther = questions; |
4935 | 4936 | ||
4936 | if ( (rlv_handler_t::isEnabled()) && (gRlvHandler.hasBehaviour("acceptpermission")) ) | 4937 | if ( (rlv_handler_t::isEnabled()) && (gRlvHandler.hasBehaviour(RLV_BHVR_ACCEPTPERMISSION)) ) |
4937 | { | 4938 | { |
4938 | LLViewerObject* pObj = gObjectList.findObject(taskid); | 4939 | LLViewerObject* pObj = gObjectList.findObject(taskid); |
4939 | if (pObj) | 4940 | if (pObj) |
@@ -5308,7 +5309,7 @@ void handle_lure(LLDynamicArray<LLUUID>& ids) | |||
5308 | for (LLDynamicArray<LLUUID>::iterator it = ids.begin(); it != ids.end(); ++it) | 5309 | for (LLDynamicArray<LLUUID>::iterator it = ids.begin(); it != ids.end(); ++it) |
5309 | { | 5310 | { |
5310 | const LLRelationship* pBuddyInfo = LLAvatarTracker::instance().getBuddyInfo(*it); | 5311 | const LLRelationship* pBuddyInfo = LLAvatarTracker::instance().getBuddyInfo(*it); |
5311 | if ( (!gRlvHandler.isException(RLV_BHVR_TPLURE, *it)) && | 5312 | if ( (!gRlvHandler.isException(RLV_BHVR_TPLURE, *it, RLV_CHECK_PERMISSIVE)) && |
5312 | ((!pBuddyInfo) || (!pBuddyInfo->isOnline()) || (!pBuddyInfo->isRightGrantedTo(LLRelationship::GRANT_MAP_LOCATION))) ) | 5313 | ((!pBuddyInfo) || (!pBuddyInfo->isOnline()) || (!pBuddyInfo->isRightGrantedTo(LLRelationship::GRANT_MAP_LOCATION))) ) |
5313 | { | 5314 | { |
5314 | delete userdata; | 5315 | delete userdata; |
@@ -5478,18 +5479,32 @@ void process_script_dialog(LLMessageSystem* msg, void**) | |||
5478 | 5479 | ||
5479 | // Don't show lldialog boxes from muted avs -- McCabe | 5480 | // Don't show lldialog boxes from muted avs -- McCabe |
5480 | std::string agent_name = first_name + " " + last_name; | 5481 | std::string agent_name = first_name + " " + last_name; |
5481 | if (!first_name.empty()) | 5482 | if (!last_name.empty()) |
5482 | { | 5483 | { |
5483 | std::vector<LLMute> mutes = LLMuteList::getInstance()->getMutes(); | 5484 | std::vector<LLMute> mutes = LLMuteList::getInstance()->getMutes(); |
5484 | for (U32 i = 0; i < mutes.size(); i++) | 5485 | for (U32 i = 0; i < mutes.size(); i++) |
5485 | { | 5486 | { |
5486 | if (mutes[i].mName == agent_name) | 5487 | //this is almost like saying (mutes[i].mType != LLMute::Object), but more verbose ... -Kaku |
5488 | if ( | ||
5489 | ((mutes[i].mType == LLMute::AGENT) | ||
5490 | && (mutes[i].mName == agent_name)) | ||
5491 | || ((mutes[i].mType == LLMute::GROUP) | ||
5492 | && (mutes[i].mName == last_name)) | ||
5493 | || ((mutes[i].mType == LLMute::BY_NAME) | ||
5494 | //don't mute groups by name in case a group has a last name as a group name. | ||
5495 | && ((mutes[i].mName == agent_name))) | ||
5496 | ) | ||
5487 | { | 5497 | { |
5488 | delete info; | 5498 | delete info; |
5489 | return; | 5499 | return; |
5490 | } | 5500 | } |
5491 | } | 5501 | } |
5492 | } | 5502 | } |
5503 | // or Scriptdialog boxes from muted objects -- Kakurady | ||
5504 | if (LLMuteList::getInstance()->isMuted(info->mObjectID, title)){ | ||
5505 | delete info; | ||
5506 | return; | ||
5507 | } | ||
5493 | 5508 | ||
5494 | // unused for now | 5509 | // unused for now |
5495 | LLUUID image_id; | 5510 | LLUUID image_id; |
diff --git a/linden/indra/newview/llviewertexteditor.cpp b/linden/indra/newview/llviewertexteditor.cpp index 76b752c..8f4a944 100644 --- a/linden/indra/newview/llviewertexteditor.cpp +++ b/linden/indra/newview/llviewertexteditor.cpp | |||
@@ -96,7 +96,7 @@ public: | |||
96 | else | 96 | else |
97 | { | 97 | { |
98 | // [RLVa:KB] - Checked: 2009-07-06 (RLVa-1.0.0c) | 98 | // [RLVa:KB] - Checked: 2009-07-06 (RLVa-1.0.0c) |
99 | if ( (rlv_handler_t::isEnabled()) && (gRlvHandler.hasBehaviour("viewnote")) ) | 99 | if ( (rlv_handler_t::isEnabled()) && (gRlvHandler.hasBehaviour(RLV_BHVR_VIEWNOTE)) ) |
100 | { | 100 | { |
101 | return; | 101 | return; |
102 | } | 102 | } |
diff --git a/linden/indra/newview/rlvdefines.h b/linden/indra/newview/rlvdefines.h index 4e6a4d4..118ba31 100644 --- a/linden/indra/newview/rlvdefines.h +++ b/linden/indra/newview/rlvdefines.h | |||
@@ -41,13 +41,14 @@ | |||
41 | 41 | ||
42 | // Version of the specifcation we support | 42 | // Version of the specifcation we support |
43 | const S32 RLV_VERSION_MAJOR = 1; | 43 | const S32 RLV_VERSION_MAJOR = 1; |
44 | const S32 RLV_VERSION_MINOR = 20; | 44 | const S32 RLV_VERSION_MINOR = 21; |
45 | const S32 RLV_VERSION_PATCH = 2; | 45 | const S32 RLV_VERSION_PATCH = 0; |
46 | const S32 RLV_VERSION_BUILD = 0; | ||
46 | 47 | ||
47 | // Implementation version | 48 | // Implementation version |
48 | const S32 RLVa_VERSION_MAJOR = 1; | 49 | const S32 RLVa_VERSION_MAJOR = 1; |
49 | const S32 RLVa_VERSION_MINOR = 0; | 50 | const S32 RLVa_VERSION_MINOR = 0; |
50 | const S32 RLVa_VERSION_PATCH = 3; | 51 | const S32 RLVa_VERSION_PATCH = 4; |
51 | const S32 RLVa_VERSION_BUILD = 4; | 52 | const S32 RLVa_VERSION_BUILD = 4; |
52 | 53 | ||
53 | // The official viewer version we're patching against | 54 | // The official viewer version we're patching against |
@@ -76,7 +77,7 @@ const S32 RLVa_VERSION_BUILD = 4; | |||
76 | #define RLV_ROOT_FOLDER "#RLV" | 77 | #define RLV_ROOT_FOLDER "#RLV" |
77 | #define RLV_CMD_PREFIX '@' | 78 | #define RLV_CMD_PREFIX '@' |
78 | #define RLV_PUTINV_PREFIX "#RLV/~" | 79 | #define RLV_PUTINV_PREFIX "#RLV/~" |
79 | #define RLV_SETROT_OFFSET F_PI_BY_TWO // @setrot is off by 90° with the rest of SL | 80 | #define RLV_SETROT_OFFSET F_PI_BY_TWO // @setrot is off by 90Β° with the rest of SL |
80 | 81 | ||
81 | #define RLV_FOLDER_FLAG_NOSTRIP "nostrip" | 82 | #define RLV_FOLDER_FLAG_NOSTRIP "nostrip" |
82 | #define RLV_FOLDER_PREFIX_HIDDEN '.' | 83 | #define RLV_FOLDER_PREFIX_HIDDEN '.' |
@@ -136,6 +137,7 @@ enum ERlvBehaviour { | |||
136 | RLV_BHVR_SHOWLOC, // "showloc" | 137 | RLV_BHVR_SHOWLOC, // "showloc" |
137 | RLV_BHVR_TPTO, // "tpto" | 138 | RLV_BHVR_TPTO, // "tpto" |
138 | RLV_BHVR_ACCEPTTP, // "accepttp" | 139 | RLV_BHVR_ACCEPTTP, // "accepttp" |
140 | RLV_BHVR_ACCEPTPERMISSION, // "acceptpermission" | ||
139 | RLV_BHVR_SHOWNAMES, // "shownames" | 141 | RLV_BHVR_SHOWNAMES, // "shownames" |
140 | RLV_BHVR_FLY, // "fly" | 142 | RLV_BHVR_FLY, // "fly" |
141 | RLV_BHVR_GETSITID, // "getsitid" | 143 | RLV_BHVR_GETSITID, // "getsitid" |
@@ -147,6 +149,9 @@ enum ERlvBehaviour { | |||
147 | RLV_BHVR_SHOWHOVERTEXTHUD, // "showhovertexthud" | 149 | RLV_BHVR_SHOWHOVERTEXTHUD, // "showhovertexthud" |
148 | RLV_BHVR_SHOWHOVERTEXT, // "showhovertext" | 150 | RLV_BHVR_SHOWHOVERTEXT, // "showhovertext" |
149 | RLV_BHVR_NOTIFY, // "notify" | 151 | RLV_BHVR_NOTIFY, // "notify" |
152 | RLV_BHVR_DEFAULTWEAR, // "defaultwear" | ||
153 | RLV_BHVR_VERSIONNUM, // "versionnum" | ||
154 | RLV_BHVR_PERMISSIVE, // "permissive" | ||
150 | 155 | ||
151 | RLV_BHVR_COUNT, | 156 | RLV_BHVR_COUNT, |
152 | RLV_BHVR_UNKNOWN | 157 | RLV_BHVR_UNKNOWN |
@@ -174,6 +179,12 @@ enum ERlvCmdRet { | |||
174 | RLV_RET_UNKNOWN // Command unkown | 179 | RLV_RET_UNKNOWN // Command unkown |
175 | }; | 180 | }; |
176 | 181 | ||
182 | enum ERlvExceptionCheck { | ||
183 | RLV_CHECK_PERMISSIVE, // Exception can be set by any object | ||
184 | RLV_CHECK_STRICT, // Exception must be set by all objects holding the restriction | ||
185 | RLV_CHECK_DEFAULT // Permissive or strict will be determined by currently enforced restrictions | ||
186 | }; | ||
187 | |||
177 | // ============================================================================ | 188 | // ============================================================================ |
178 | // Settings | 189 | // Settings |
179 | 190 | ||
diff --git a/linden/indra/newview/rlvextensions.cpp b/linden/indra/newview/rlvextensions.cpp index 10d1c46..f31c62e 100644 --- a/linden/indra/newview/rlvextensions.cpp +++ b/linden/indra/newview/rlvextensions.cpp | |||
@@ -12,13 +12,14 @@ | |||
12 | // ============================================================================ | 12 | // ============================================================================ |
13 | 13 | ||
14 | std::map<std::string, S16> RlvExtGetSet::m_DbgAllowed; | 14 | std::map<std::string, S16> RlvExtGetSet::m_DbgAllowed; |
15 | std::map<std::string, std::string> RlvExtGetSet::m_PseudoDebug; | ||
15 | 16 | ||
16 | // Checked: 2009-06-03 (RLVa-0.2.0h) | Modified: RLVa-0.2.0h | 17 | // Checked: 2009-06-03 (RLVa-0.2.0h) | Modified: RLVa-0.2.0h |
17 | RlvExtGetSet::RlvExtGetSet() | 18 | RlvExtGetSet::RlvExtGetSet() |
18 | { | 19 | { |
19 | if (!m_DbgAllowed.size()) // m_DbgAllowed is static and should only be initialized once | 20 | if (!m_DbgAllowed.size()) // m_DbgAllowed is static and should only be initialized once |
20 | { | 21 | { |
21 | m_DbgAllowed.insert(std::pair<std::string, S16>("AvatarSex", DBG_READ | DBG_PSEUDO)); | 22 | m_DbgAllowed.insert(std::pair<std::string, S16>("AvatarSex", DBG_READ | DBG_WRITE | DBG_PSEUDO)); |
22 | m_DbgAllowed.insert(std::pair<std::string, S16>("RenderResolutionDivisor", DBG_READ | DBG_WRITE)); | 23 | m_DbgAllowed.insert(std::pair<std::string, S16>("RenderResolutionDivisor", DBG_READ | DBG_WRITE)); |
23 | #ifdef RLV_EXTENSION_CMD_GETSETDEBUG_EX | 24 | #ifdef RLV_EXTENSION_CMD_GETSETDEBUG_EX |
24 | m_DbgAllowed.insert(std::pair<std::string, S16>(RLV_SETTING_FORBIDGIVETORLV, DBG_READ)); | 25 | m_DbgAllowed.insert(std::pair<std::string, S16>(RLV_SETTING_FORBIDGIVETORLV, DBG_READ)); |
@@ -172,19 +173,27 @@ std::string RlvExtGetSet::onGetDebug(std::string strSetting) | |||
172 | return std::string(); | 173 | return std::string(); |
173 | } | 174 | } |
174 | 175 | ||
175 | // Checked: 2009-06-03 (RLVa-0.2.0h) | Added: RLVa-0.2.0h | 176 | // Checked: 2009-10-03 (RLVa-1.0.4e) | Added: RLVa-1.0.4e |
176 | std::string RlvExtGetSet::onGetPseudoDebug(const std::string& strSetting) | 177 | std::string RlvExtGetSet::onGetPseudoDebug(const std::string& strSetting) |
177 | { | 178 | { |
178 | // Skip sanity checking because it's all done in RlvExtGetSet::onGetDebug() already | 179 | // Skip sanity checking because it's all done in RlvExtGetSet::onGetDebug() already |
179 | if ("AvatarSex" == strSetting) | 180 | if ("AvatarSex" == strSetting) |
180 | { | 181 | { |
181 | if (gAgent.getAvatarObject()) | 182 | std::map<std::string, std::string>::const_iterator itPseudo = m_PseudoDebug.find(strSetting); |
182 | return llformat("%d", (gAgent.getAvatarObject()->getSex() == SEX_MALE)); // [See LLFloaterCustomize::LLFloaterCustomize()] | 183 | if (itPseudo != m_PseudoDebug.end()) |
184 | { | ||
185 | return itPseudo->second; | ||
186 | } | ||
187 | else | ||
188 | { | ||
189 | if (gAgent.getAvatarObject()) | ||
190 | return llformat("%d", (gAgent.getAvatarObject()->getSex() == SEX_MALE)); // [See LLFloaterCustomize::LLFloaterCustomize()] | ||
191 | } | ||
183 | } | 192 | } |
184 | return std::string(); | 193 | return std::string(); |
185 | } | 194 | } |
186 | 195 | ||
187 | // Checked: 2009-06-03 (RLVa-0.2.0h) | Modified: RLVa-0.2.0h | 196 | // Checked: 2009-10-10 (RLVa-1.0.4e) | Modified: RLVa-1.0.4e |
188 | void RlvExtGetSet::onSetDebug(std::string strSetting, const std::string& strValue) | 197 | void RlvExtGetSet::onSetDebug(std::string strSetting, const std::string& strValue) |
189 | { | 198 | { |
190 | S16 dbgFlags; | 199 | S16 dbgFlags; |
@@ -219,6 +228,21 @@ void RlvExtGetSet::onSetDebug(std::string strSetting, const std::string& strValu | |||
219 | pSetting->setPersist( (pSetting->isDefault()) ? ((dbgFlags & DBG_PERSIST) == DBG_PERSIST) : false ); | 228 | pSetting->setPersist( (pSetting->isDefault()) ? ((dbgFlags & DBG_PERSIST) == DBG_PERSIST) : false ); |
220 | } | 229 | } |
221 | } | 230 | } |
231 | else | ||
232 | { | ||
233 | onSetPseudoDebug(strSetting, strValue); | ||
234 | } | ||
235 | } | ||
236 | } | ||
237 | |||
238 | // Checked: 2009-10-10 (RLVa-1.0.4e) | Modified: RLVa-1.0.4e | ||
239 | void RlvExtGetSet::onSetPseudoDebug(const std::string& strSetting, const std::string& strValue) | ||
240 | { | ||
241 | if ("AvatarSex" == strSetting) | ||
242 | { | ||
243 | BOOL fValue; | ||
244 | if (LLStringUtil::convertToBOOL(strValue, fValue)) | ||
245 | m_PseudoDebug[strSetting] = strValue; | ||
222 | } | 246 | } |
223 | } | 247 | } |
224 | 248 | ||
diff --git a/linden/indra/newview/rlvextensions.h b/linden/indra/newview/rlvextensions.h index 5c10c58..5720ba0 100644 --- a/linden/indra/newview/rlvextensions.h +++ b/linden/indra/newview/rlvextensions.h | |||
@@ -24,6 +24,7 @@ protected: | |||
24 | std::string onGetDebug(std::string strSetting); | 24 | std::string onGetDebug(std::string strSetting); |
25 | std::string onGetPseudoDebug(const std::string& strSetting); | 25 | std::string onGetPseudoDebug(const std::string& strSetting); |
26 | void onSetDebug(std::string strSetting, const std::string& strValue); | 26 | void onSetDebug(std::string strSetting, const std::string& strValue); |
27 | void onSetPseudoDebug(const std::string& strSetting, const std::string& strValue); | ||
27 | 28 | ||
28 | std::string onGetEnv(std::string strSetting); | 29 | std::string onGetEnv(std::string strSetting); |
29 | void onSetEnv(std::string strSetting, const std::string& strValue); | 30 | void onSetEnv(std::string strSetting, const std::string& strValue); |
@@ -33,6 +34,7 @@ protected: | |||
33 | public: | 34 | public: |
34 | enum { DBG_READ = 0x01, DBG_WRITE = 0x02, DBG_PERSIST = 0x04, DBG_PSEUDO = 0x08 }; | 35 | enum { DBG_READ = 0x01, DBG_WRITE = 0x02, DBG_PERSIST = 0x04, DBG_PSEUDO = 0x08 }; |
35 | static std::map<std::string, S16> m_DbgAllowed; | 36 | static std::map<std::string, S16> m_DbgAllowed; |
37 | static std::map<std::string, std::string> m_PseudoDebug; | ||
36 | 38 | ||
37 | static bool findDebugSetting(/*[in,out]*/ std::string& strSetting, /*[out]*/ S16& flags); | 39 | static bool findDebugSetting(/*[in,out]*/ std::string& strSetting, /*[out]*/ S16& flags); |
38 | static S16 getDebugSettingFlags(const std::string& strSetting); | 40 | static S16 getDebugSettingFlags(const std::string& strSetting); |
diff --git a/linden/indra/newview/rlvhandler.cpp b/linden/indra/newview/rlvhandler.cpp index 6044aa9..69e2e2f 100644 --- a/linden/indra/newview/rlvhandler.cpp +++ b/linden/indra/newview/rlvhandler.cpp | |||
@@ -286,7 +286,7 @@ bool RlvHandler::setDetachable(S32 idxAttachPt, const LLUUID& idRlvObj, bool fDe | |||
286 | if (!fDetachable) | 286 | if (!fDetachable) |
287 | { | 287 | { |
288 | #ifdef RLV_EXPERIMENTAL_FIRSTUSE | 288 | #ifdef RLV_EXPERIMENTAL_FIRSTUSE |
289 | LLFirstUse::useRlvDetach(); | 289 | //LLFirstUse::useRlvDetach(); |
290 | #endif // RLV_EXPERIMENTAL_FIRSTUSE | 290 | #endif // RLV_EXPERIMENTAL_FIRSTUSE |
291 | 291 | ||
292 | // NOTE: m_Attachments can contain duplicate <idxAttachPt, idRlvObj> pairs (ie @detach:spine=n,detach=n from an attachment on spine) | 292 | // NOTE: m_Attachments can contain duplicate <idxAttachPt, idRlvObj> pairs (ie @detach:spine=n,detach=n from an attachment on spine) |
@@ -338,27 +338,47 @@ bool RlvHandler::setDetachable(S32 idxAttachPt, const LLUUID& idRlvObj, bool fDe | |||
338 | // Behaviour related functions | 338 | // Behaviour related functions |
339 | // | 339 | // |
340 | 340 | ||
341 | bool RlvHandler::hasBehaviourExcept(const std::string& strBehaviour, const LLUUID& idObj) const | ||
342 | { | ||
343 | for (rlv_object_map_t::const_iterator itObj = m_Objects.begin(); itObj != m_Objects.end(); ++itObj) | ||
344 | if ( (idObj != itObj->second.m_UUID) && (itObj->second.hasBehaviour(strBehaviour)) ) | ||
345 | return true; | ||
346 | return false; | ||
347 | } | ||
348 | |||
349 | bool RlvHandler::hasBehaviourExcept(ERlvBehaviour eBehaviour, const std::string& strOption, const LLUUID& idObj) const | 341 | bool RlvHandler::hasBehaviourExcept(ERlvBehaviour eBehaviour, const std::string& strOption, const LLUUID& idObj) const |
350 | { | 342 | { |
351 | for (rlv_object_map_t::const_iterator itObj = m_Objects.begin(); itObj != m_Objects.end(); ++itObj) | 343 | for (rlv_object_map_t::const_iterator itObj = m_Objects.begin(); itObj != m_Objects.end(); ++itObj) |
352 | if ( (idObj != itObj->second.m_UUID) && (itObj->second.hasBehaviour(eBehaviour, strOption)) ) | 344 | if ( (idObj != itObj->second.m_UUID) && (itObj->second.hasBehaviour(eBehaviour, strOption, false)) ) |
353 | return true; | 345 | return true; |
354 | return false; | 346 | return false; |
355 | } | 347 | } |
356 | 348 | ||
357 | bool RlvHandler::hasBehaviourExcept(const std::string& strBehaviour, const std::string& strOption, const LLUUID& idObj) const | 349 | // Checked: 2009-10-04 (RLVa-1.0.4c) | Modified: RLVa-1.0.4c |
350 | bool RlvHandler::isException(ERlvBehaviour eBhvr, const RlvExceptionOption& varOption, ERlvExceptionCheck typeCheck) const | ||
358 | { | 351 | { |
359 | for (rlv_object_map_t::const_iterator itObj = m_Objects.begin(); itObj != m_Objects.end(); ++itObj) | 352 | // We need to "strict check" exceptions only if: the restriction is actually in place *and* (isPermissive(eBhvr) == FALSE) |
360 | if ( (idObj != itObj->second.m_UUID) && (itObj->second.hasBehaviour(strBehaviour, strOption)) ) | 353 | if (RLV_CHECK_DEFAULT == typeCheck) |
361 | return true; | 354 | typeCheck = ( (hasBehaviour(eBhvr)) && (!isPermissive(eBhvr)) ) ? RLV_CHECK_STRICT : RLV_CHECK_PERMISSIVE; |
355 | |||
356 | std::list<LLUUID> objList; | ||
357 | if (RLV_CHECK_STRICT == typeCheck) | ||
358 | { | ||
359 | // If we're "strict checking" then we need the UUID of every object that currently has 'eBhvr' restricted | ||
360 | for (rlv_object_map_t::const_iterator itObj = m_Objects.begin(); itObj != m_Objects.end(); ++itObj) | ||
361 | if (itObj->second.hasBehaviour(eBhvr, !hasBehaviour(RLV_BHVR_PERMISSIVE))) | ||
362 | objList.push_back(itObj->first); | ||
363 | } | ||
364 | |||
365 | for (rlv_exception_map_t::const_iterator itException = m_Exceptions.lower_bound(eBhvr), | ||
366 | endException = m_Exceptions.upper_bound(eBhvr); itException != endException; ++itException) | ||
367 | { | ||
368 | if (itException->second.varOption == varOption) | ||
369 | { | ||
370 | // For permissive checks we just return on the very first match | ||
371 | if (RLV_CHECK_PERMISSIVE == typeCheck) | ||
372 | return true; | ||
373 | |||
374 | // For strict checks we don't return until the list is empty (every object with 'eBhvr' restricted also contains the exception) | ||
375 | std::list<LLUUID>::iterator itList = std::find(objList.begin(), objList.end(), itException->second.idObject); | ||
376 | if (itList != objList.end()) | ||
377 | objList.erase(itList); | ||
378 | if (objList.empty()) | ||
379 | return true; | ||
380 | } | ||
381 | } | ||
362 | return false; | 382 | return false; |
363 | } | 383 | } |
364 | 384 | ||
@@ -509,7 +529,11 @@ BOOL RlvHandler::processAddCommand(const LLUUID& uuid, const RlvCommand& rlvCmd) | |||
509 | const std::string& strOption = rlvCmd.getOption(); | 529 | const std::string& strOption = rlvCmd.getOption(); |
510 | 530 | ||
511 | if ( (RLV_BHVR_UNKNOWN != eBehaviour) && (strOption.empty()) ) | 531 | if ( (RLV_BHVR_UNKNOWN != eBehaviour) && (strOption.empty()) ) |
532 | { | ||
533 | if (rlvCmd.isStrict()) | ||
534 | addException(uuid, RLV_BHVR_PERMISSIVE, eBehaviour); | ||
512 | m_Behaviours[eBehaviour]++; | 535 | m_Behaviours[eBehaviour]++; |
536 | } | ||
513 | 537 | ||
514 | switch (eBehaviour) | 538 | switch (eBehaviour) |
515 | { | 539 | { |
@@ -649,7 +673,7 @@ BOOL RlvHandler::processAddCommand(const LLUUID& uuid, const RlvCommand& rlvCmd) | |||
649 | case RLV_BHVR_FARTOUCH: | 673 | case RLV_BHVR_FARTOUCH: |
650 | { | 674 | { |
651 | #ifdef RLV_EXPERIMENTAL_FIRSTUSE | 675 | #ifdef RLV_EXPERIMENTAL_FIRSTUSE |
652 | LLFirstUse::useRlvFartouch(); | 676 | //LLFirstUse::useRlvFartouch(); |
653 | #endif // RLV_EXPERIMENTAL_FIRSTUSE | 677 | #endif // RLV_EXPERIMENTAL_FIRSTUSE |
654 | } | 678 | } |
655 | break; | 679 | break; |
@@ -695,9 +719,9 @@ BOOL RlvHandler::processAddCommand(const LLUUID& uuid, const RlvCommand& rlvCmd) | |||
695 | case RLV_BHVR_SHOWHOVERTEXT: // @showhovertext:<uuid>=n - Checked: 2009-07-09 (RLVa-0.2.2a) | Modified: RLVa-1.0.0f | 719 | case RLV_BHVR_SHOWHOVERTEXT: // @showhovertext:<uuid>=n - Checked: 2009-07-09 (RLVa-0.2.2a) | Modified: RLVa-1.0.0f |
696 | { | 720 | { |
697 | LLUUID idException(strOption); | 721 | LLUUID idException(strOption); |
698 | if (!idException.isNull()) // If there's an option it should be a valid UUID | 722 | if (idException.notNull()) // If there's an option it should be a valid UUID |
699 | { | 723 | { |
700 | addException(eBehaviour, LLUUID(strOption)); | 724 | addException(uuid, eBehaviour, idException); |
701 | 725 | ||
702 | // Clear the object's hover text | 726 | // Clear the object's hover text |
703 | LLViewerObject* pObj = gObjectList.findObject(idException); | 727 | LLViewerObject* pObj = gObjectList.findObject(idException); |
@@ -717,6 +741,13 @@ BOOL RlvHandler::processAddCommand(const LLUUID& uuid, const RlvCommand& rlvCmd) | |||
717 | } | 741 | } |
718 | } | 742 | } |
719 | break; | 743 | break; |
744 | case RLV_BHVR_SENDCHANNEL: // @sendchannel:<uuid>=add - Checked: 2009-10-05 (RLVa-1.0.4a) | Modified: RLVa-1.0.4a | ||
745 | { | ||
746 | S32 nChannel; // If there's an option it should be a valid (=positive and non-zero) chat channel | ||
747 | if ( (!strOption.empty()) && (LLStringUtil::convertToS32(strOption, nChannel)) && (nChannel > 0) ) | ||
748 | addException(uuid, eBehaviour, nChannel); | ||
749 | } | ||
750 | break; | ||
720 | case RLV_BHVR_RECVCHAT: // @recvchat:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 751 | case RLV_BHVR_RECVCHAT: // @recvchat:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
721 | case RLV_BHVR_RECVEMOTE: // @recvemote:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 752 | case RLV_BHVR_RECVEMOTE: // @recvemote:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
722 | case RLV_BHVR_RECVIM: // @recvim:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 753 | case RLV_BHVR_RECVIM: // @recvim:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
@@ -724,16 +755,20 @@ BOOL RlvHandler::processAddCommand(const LLUUID& uuid, const RlvCommand& rlvCmd) | |||
724 | case RLV_BHVR_TPLURE: // @tplure:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 755 | case RLV_BHVR_TPLURE: // @tplure:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
725 | case RLV_BHVR_ACCEPTTP: // @accepttp:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 756 | case RLV_BHVR_ACCEPTTP: // @accepttp:<uuid>=add - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
726 | { | 757 | { |
727 | addException(eBehaviour, LLUUID(strOption)); | 758 | LLUUID idException(strOption); |
759 | if (idException.notNull()) // If there's an option it should be a valid UUID | ||
760 | addException(uuid, eBehaviour, LLUUID(strOption)); | ||
728 | } | 761 | } |
729 | break; | 762 | break; |
730 | default: | 763 | case RLV_BHVR_UNKNOWN: |
731 | { | 764 | { |
732 | // Give our observers a chance to handle any command we don't | 765 | // Give our observers a chance to handle any command we don't |
733 | RlvEvent rlvEvent(uuid, rlvCmd); | 766 | RlvEvent rlvEvent(uuid, rlvCmd); |
734 | m_Emitter.update(&RlvObserver::onAddCommand, rlvEvent); | 767 | m_Emitter.update(&RlvObserver::onAddCommand, rlvEvent); |
735 | } | 768 | } |
736 | break; | 769 | break; |
770 | default: | ||
771 | break; | ||
737 | } | 772 | } |
738 | return TRUE; // Add command success/failure is decided by RlvObject::addCommand() | 773 | return TRUE; // Add command success/failure is decided by RlvObject::addCommand() |
739 | } | 774 | } |
@@ -756,7 +791,11 @@ BOOL RlvHandler::processRemoveCommand(const LLUUID& uuid, const RlvCommand& rlvC | |||
756 | const std::string& strOption = rlvCmd.getOption(); | 791 | const std::string& strOption = rlvCmd.getOption(); |
757 | 792 | ||
758 | if ( (RLV_BHVR_UNKNOWN != eBehaviour) && (strOption.empty()) ) | 793 | if ( (RLV_BHVR_UNKNOWN != eBehaviour) && (strOption.empty()) ) |
794 | { | ||
795 | if (rlvCmd.isStrict()) | ||
796 | removeException(uuid, RLV_BHVR_PERMISSIVE, eBehaviour); | ||
759 | m_Behaviours[eBehaviour]--; | 797 | m_Behaviours[eBehaviour]--; |
798 | } | ||
760 | 799 | ||
761 | switch (eBehaviour) | 800 | switch (eBehaviour) |
762 | { | 801 | { |
@@ -842,9 +881,9 @@ BOOL RlvHandler::processRemoveCommand(const LLUUID& uuid, const RlvCommand& rlvC | |||
842 | case RLV_BHVR_SHOWHOVERTEXT: // @showhovertext:<uuid>=y - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 881 | case RLV_BHVR_SHOWHOVERTEXT: // @showhovertext:<uuid>=y - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
843 | { | 882 | { |
844 | LLUUID idException(strOption); | 883 | LLUUID idException(strOption); |
845 | if (!idException.isNull()) // If there's an option it should be a valid UUID | 884 | if (idException.notNull()) // If there's an option it should be a valid UUID |
846 | { | 885 | { |
847 | removeException(eBehaviour, LLUUID(strOption)); | 886 | removeException(uuid, eBehaviour, idException); |
848 | 887 | ||
849 | // Restore the object's hover text | 888 | // Restore the object's hover text |
850 | LLViewerObject* pObj = gObjectList.findObject(idException); | 889 | LLViewerObject* pObj = gObjectList.findObject(idException); |
@@ -869,6 +908,13 @@ BOOL RlvHandler::processRemoveCommand(const LLUUID& uuid, const RlvCommand& rlvC | |||
869 | } | 908 | } |
870 | } | 909 | } |
871 | break; | 910 | break; |
911 | case RLV_BHVR_SENDCHANNEL: // @sendchannel:<uuid>=rem - Checked: 2009-10-05 (RLVa-1.0.4a) | Modified: RLVa-1.0.4a | ||
912 | { | ||
913 | S32 nChannel; // If there's an option it should be a valid (=positive and non-zero) chat channel | ||
914 | if ( (!strOption.empty()) && (LLStringUtil::convertToS32(strOption, nChannel)) && (nChannel > 0) ) | ||
915 | removeException(uuid, eBehaviour, nChannel); | ||
916 | } | ||
917 | break; | ||
872 | case RLV_BHVR_RECVCHAT: // @recvchat:<uuid>=rem - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 918 | case RLV_BHVR_RECVCHAT: // @recvchat:<uuid>=rem - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
873 | case RLV_BHVR_RECVEMOTE: // @recvemote:<uui>=red - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 919 | case RLV_BHVR_RECVEMOTE: // @recvemote:<uui>=red - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
874 | case RLV_BHVR_RECVIM: // @recvim:<uuid>=rem - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 920 | case RLV_BHVR_RECVIM: // @recvim:<uuid>=rem - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
@@ -876,16 +922,20 @@ BOOL RlvHandler::processRemoveCommand(const LLUUID& uuid, const RlvCommand& rlvC | |||
876 | case RLV_BHVR_TPLURE: // @recvim:<uuid>=rem - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 922 | case RLV_BHVR_TPLURE: // @recvim:<uuid>=rem - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
877 | case RLV_BHVR_ACCEPTTP: // @accepttp:<uuid>=rem - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 923 | case RLV_BHVR_ACCEPTTP: // @accepttp:<uuid>=rem - Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
878 | { | 924 | { |
879 | removeException(eBehaviour, LLUUID(strOption)); | 925 | LLUUID idException(strOption); |
926 | if (idException.notNull()) // If there's an option it should be a valid UUID | ||
927 | removeException(uuid, eBehaviour, LLUUID(strOption)); | ||
880 | } | 928 | } |
881 | break; | 929 | break; |
882 | default: | 930 | case RLV_BHVR_UNKNOWN: |
883 | { | 931 | { |
884 | // Give our observers a chance to handle any command we don't | 932 | // Give our observers a chance to handle any command we don't |
885 | RlvEvent rlvEvent(uuid, rlvCmd); | 933 | RlvEvent rlvEvent(uuid, rlvCmd); |
886 | m_Emitter.update(&RlvObserver::onRemoveCommand, rlvEvent); | 934 | m_Emitter.update(&RlvObserver::onRemoveCommand, rlvEvent); |
887 | } | 935 | } |
888 | break; | 936 | break; |
937 | default: | ||
938 | break; | ||
889 | } | 939 | } |
890 | return TRUE; // Remove commands don't fail, doesn't matter what we return here | 940 | return TRUE; // Remove commands don't fail, doesn't matter what we return here |
891 | } | 941 | } |
@@ -1006,13 +1056,15 @@ BOOL RlvHandler::processForceCommand(const LLUUID& idObj, const RlvCommand& rlvC | |||
1006 | } | 1056 | } |
1007 | } | 1057 | } |
1008 | break; | 1058 | break; |
1009 | default: | 1059 | case RLV_BHVR_UNKNOWN: |
1010 | { | 1060 | { |
1011 | // Give our observers a chance to handle any command we don't | 1061 | // Give our observers a chance to handle any command we don't |
1012 | RlvEvent rlvEvent(idObj, rlvCmd); | 1062 | RlvEvent rlvEvent(idObj, rlvCmd); |
1013 | fHandled = m_Emitter.update(&RlvObserver::onForceCommand, rlvEvent); | 1063 | fHandled = m_Emitter.update(&RlvObserver::onForceCommand, rlvEvent); |
1014 | } | 1064 | } |
1015 | break; | 1065 | break; |
1066 | default: | ||
1067 | break; | ||
1016 | } | 1068 | } |
1017 | return fHandled; // If we handled it then it'll still be TRUE; if an observer doesn't handle it'll be FALSE | 1069 | return fHandled; // If we handled it then it'll still be TRUE; if an observer doesn't handle it'll be FALSE |
1018 | } | 1070 | } |
@@ -1030,6 +1082,9 @@ BOOL RlvHandler::processReplyCommand(const LLUUID& uuid, const RlvCommand& rlvCm | |||
1030 | case RLV_BHVR_VERSION: // @version=<channel> - Checked: 2009-07-12 (RLVa-1.0.0h) | 1082 | case RLV_BHVR_VERSION: // @version=<channel> - Checked: 2009-07-12 (RLVa-1.0.0h) |
1031 | strReply = getVersionString(); | 1083 | strReply = getVersionString(); |
1032 | break; | 1084 | break; |
1085 | case RLV_BHVR_VERSIONNUM: // @versionnum=<channel> - Checked: 2009-10-04 (RLVa-1.0.4b) | Added: RLVa-1.0.4b | ||
1086 | strReply = getVersionNumString(); | ||
1087 | break; | ||
1033 | case RLV_BHVR_GETOUTFIT: // @getoufit[:<layer>]=<channel> - Checked: 2009-07-12 (RLVa-1.0.0h) | Modified: RLVa-0.2.0d | 1088 | case RLV_BHVR_GETOUTFIT: // @getoufit[:<layer>]=<channel> - Checked: 2009-07-12 (RLVa-1.0.0h) | Modified: RLVa-0.2.0d |
1034 | { | 1089 | { |
1035 | // (Quirk: RLV 1.16.1 will execute @getoutfit=<channel> if <layer> is invalid, so we need to as well) | 1090 | // (Quirk: RLV 1.16.1 will execute @getoutfit=<channel> if <layer> is invalid, so we need to as well) |
@@ -1225,13 +1280,15 @@ BOOL RlvHandler::processReplyCommand(const LLUUID& uuid, const RlvCommand& rlvCm | |||
1225 | strReply = uuid.asString(); | 1280 | strReply = uuid.asString(); |
1226 | } | 1281 | } |
1227 | break; | 1282 | break; |
1228 | default: | 1283 | case RLV_BHVR_UNKNOWN: |
1229 | { | 1284 | { |
1230 | // Give our observers a chance to handle any command we don't | 1285 | // Give our observers a chance to handle any command we don't |
1231 | RlvEvent rlvEvent(uuid, rlvCmd); | 1286 | RlvEvent rlvEvent(uuid, rlvCmd); |
1232 | return m_Emitter.update(&RlvObserver::onReplyCommand, rlvEvent); | 1287 | return m_Emitter.update(&RlvObserver::onReplyCommand, rlvEvent); |
1233 | } | 1288 | } |
1234 | break; | 1289 | break; |
1290 | default: | ||
1291 | break; | ||
1235 | } | 1292 | } |
1236 | 1293 | ||
1237 | if (fHandled) | 1294 | if (fHandled) |
@@ -1318,7 +1375,7 @@ void RlvHandler::onAttach(LLViewerJointAttachment* pAttachPt, bool fFullyLoaded) | |||
1318 | itObj->second.m_fLookup = true; | 1375 | itObj->second.m_fLookup = true; |
1319 | 1376 | ||
1320 | // In both cases we should check for "@detach=n" and actually lock down the attachment point it got attached to | 1377 | // In both cases we should check for "@detach=n" and actually lock down the attachment point it got attached to |
1321 | if (itObj->second.hasBehaviour(RLV_BHVR_DETACH)) | 1378 | if (itObj->second.hasBehaviour(RLV_BHVR_DETACH, false)) |
1322 | { | 1379 | { |
1323 | // (Copy/paste from processAddCommand) | 1380 | // (Copy/paste from processAddCommand) |
1324 | setDetachable(idxAttachPt, pObj->getID(), false); | 1381 | setDetachable(idxAttachPt, pObj->getID(), false); |
@@ -1569,7 +1626,7 @@ void RlvHandler::filterChat(std::string& strUTF8Text, bool fFilterEmote) const | |||
1569 | { | 1626 | { |
1570 | strUTF8Text = "..."; // Emote contains illegal character (or character sequence) | 1627 | strUTF8Text = "..."; // Emote contains illegal character (or character sequence) |
1571 | } | 1628 | } |
1572 | else if (!hasBehaviour("emote")) | 1629 | else if (!hasBehaviour(RLV_BHVR_EMOTE)) |
1573 | { | 1630 | { |
1574 | int idx = strUTF8Text.find('.'); // Truncate at 20 characters or at the dot (whichever is shorter) | 1631 | int idx = strUTF8Text.find('.'); // Truncate at 20 characters or at the dot (whichever is shorter) |
1575 | strUTF8Text = utf8str_chtruncate(strUTF8Text, ( (idx > 0) && (idx < 20) ) ? idx + 1 : 20); | 1632 | strUTF8Text = utf8str_chtruncate(strUTF8Text, ( (idx > 0) && (idx < 20) ) ? idx + 1 : 20); |
@@ -1674,17 +1731,18 @@ bool RlvHandler::redirectChatOrEmote(const std::string& strUTF8Text) const | |||
1674 | return false; // @sendchat wouldn't filter it so @redirchat won't redirect it either | 1731 | return false; // @sendchat wouldn't filter it so @redirchat won't redirect it either |
1675 | } | 1732 | } |
1676 | 1733 | ||
1677 | bool fSendChannel = hasBehaviour("sendchannel"); | 1734 | bool fSendChannel = hasBehaviour(RLV_BHVR_SENDCHANNEL); S32 nChannel = 0; |
1678 | for (rlv_object_map_t::const_iterator itObj = m_Objects.begin(); itObj != m_Objects.end(); ++itObj) | 1735 | for (rlv_object_map_t::const_iterator itObj = m_Objects.begin(); itObj != m_Objects.end(); ++itObj) |
1679 | { | 1736 | { |
1680 | for (rlv_command_list_t::const_iterator itCmd = itObj->second.m_Commands.begin(), | 1737 | for (rlv_command_list_t::const_iterator itCmd = itObj->second.m_Commands.begin(), |
1681 | endCmd = itObj->second.m_Commands.end(); itCmd != endCmd; ++itCmd) | 1738 | endCmd = itObj->second.m_Commands.end(); itCmd != endCmd; ++itCmd) |
1682 | { | 1739 | { |
1683 | if ( ( ((!fIsEmote) && (RLV_BHVR_REDIRCHAT == itCmd->getBehaviourType())) || | 1740 | if ( ( ((!fIsEmote) && (RLV_BHVR_REDIRCHAT == itCmd->getBehaviourType())) || // Redirect if: (not an emote and @redirchat |
1684 | ((fIsEmote) && (RLV_BHVR_REDIREMOTE == itCmd->getBehaviourType())) ) && | 1741 | ((fIsEmote) && (RLV_BHVR_REDIREMOTE == itCmd->getBehaviourType())) ) && // OR an emote and @rediremote) |
1685 | ( (!fSendChannel) || (hasBehaviour("sendchannel", itCmd->getOption())) ) ) | 1742 | (LLStringUtil::convertToS32(itCmd->getOption(), nChannel)) && // AND the channel is a number |
1743 | ( (!fSendChannel) || (isException(RLV_BHVR_SENDCHANNEL, nChannel)) ) ) // AND we're allowed to send to that channel | ||
1686 | { | 1744 | { |
1687 | rlvSendChatReply(itCmd->getOption(), strUTF8Text); | 1745 | rlvSendChatReply(nChannel, strUTF8Text); |
1688 | } | 1746 | } |
1689 | } | 1747 | } |
1690 | } | 1748 | } |
diff --git a/linden/indra/newview/rlvhandler.h b/linden/indra/newview/rlvhandler.h index 4470632..5295a72 100644 --- a/linden/indra/newview/rlvhandler.h +++ b/linden/indra/newview/rlvhandler.h | |||
@@ -18,7 +18,7 @@ | |||
18 | typedef std::map<LLUUID, RlvObject> rlv_object_map_t; | 18 | typedef std::map<LLUUID, RlvObject> rlv_object_map_t; |
19 | typedef std::multimap<S32, LLUUID> rlv_detach_map_t; | 19 | typedef std::multimap<S32, LLUUID> rlv_detach_map_t; |
20 | typedef std::map<S32, LLUUID> rlv_reattach_map_t; | 20 | typedef std::map<S32, LLUUID> rlv_reattach_map_t; |
21 | typedef std::multimap<LLUUID, ERlvBehaviour> rlv_exception_map_t; | 21 | typedef std::multimap<ERlvBehaviour, RlvException> rlv_exception_map_t; |
22 | 22 | ||
23 | class RlvHandler | 23 | class RlvHandler |
24 | { | 24 | { |
@@ -29,7 +29,7 @@ public: | |||
29 | // -------------------------------- | 29 | // -------------------------------- |
30 | 30 | ||
31 | /* | 31 | /* |
32 | * Rule checking functions | 32 | * Attachment point helper functions |
33 | */ | 33 | */ |
34 | public: | 34 | public: |
35 | // Returns a pointer to the attachment point for a supplied parameter | 35 | // Returns a pointer to the attachment point for a supplied parameter |
@@ -42,45 +42,45 @@ public: | |||
42 | S32 getAttachPointIndex(const LLViewerJointAttachment* pObj) const; | 42 | S32 getAttachPointIndex(const LLViewerJointAttachment* pObj) const; |
43 | bool hasAttachPointName(const LLInventoryItem* pItem, bool fStrict) const; | 43 | bool hasAttachPointName(const LLInventoryItem* pItem, bool fStrict) const; |
44 | 44 | ||
45 | // Returns TRUE is at least one object contains the specified behaviour (and optional parameter) | 45 | // -------------------------------- |
46 | |||
47 | /* | ||
48 | * Rule checking functions | ||
49 | */ | ||
46 | // NOTE: - to check @detach=n -> hasLockedAttachment() / hasLockedHUD() / isDetachable() | 50 | // NOTE: - to check @detach=n -> hasLockedAttachment() / hasLockedHUD() / isDetachable() |
51 | // - to check exceptions -> isException() | ||
47 | // - to check @addoutfit=n -> isWearable() | 52 | // - to check @addoutfit=n -> isWearable() |
48 | // - to check @remoutfit=n -> isRemovable() | 53 | // - to check @remoutfit=n -> isRemovable() |
49 | // - to check exceptions -> isException() | 54 | public: |
50 | // (You *can* use hasBehaviour(); the specialized ones just don't have to iterate over all the objects) | 55 | // Returns TRUE is at least one object contains the specified behaviour (and optional option) |
51 | bool hasBehaviour(ERlvBehaviour eBehaviour) const { return (eBehaviour < RLV_BHVR_COUNT) ? (0 != m_Behaviours[eBehaviour]) : false; } | 56 | bool hasBehaviour(ERlvBehaviour eBehaviour) const { return (eBehaviour < RLV_BHVR_COUNT) ? (0 != m_Behaviours[eBehaviour]) : false; } |
52 | bool hasBehaviour(const std::string& strBehaviour) const; | ||
53 | bool hasBehaviour(ERlvBehaviour eBehaviour, const std::string& strOption) const; | 57 | bool hasBehaviour(ERlvBehaviour eBehaviour, const std::string& strOption) const; |
54 | bool hasBehaviour(const std::string& strBehaviour, const std::string& strOption) const; | 58 | // Returns TRUE if at least one object (except the specified one) contains the specified behaviour (and optional option) |
55 | |||
56 | // Returns TRUE if at least one object (except the specified one) contains the specified behaviour | ||
57 | bool hasBehaviourExcept(ERlvBehaviour eBehaviour, const LLUUID& idObj) const; | 59 | bool hasBehaviourExcept(ERlvBehaviour eBehaviour, const LLUUID& idObj) const; |
58 | bool hasBehaviourExcept(const std::string& strBehaviour, const LLUUID& uuid) const; | ||
59 | bool hasBehaviourExcept(ERlvBehaviour eBehaviour, const std::string& strOption, const LLUUID& idObj) const; | 60 | bool hasBehaviourExcept(ERlvBehaviour eBehaviour, const std::string& strOption, const LLUUID& idObj) const; |
60 | bool hasBehaviourExcept(const std::string& strBehaviour, const std::string& strOption, const LLUUID& idObj) const; | ||
61 | 61 | ||
62 | // Returns TRUE if there is at least 1 undetachable attachment | 62 | // Returns TRUE if there is at least 1 non-detachable attachment |
63 | bool hasLockedAttachment() const { return (0 != m_Attachments.size()); } | 63 | bool hasLockedAttachment() const { return (0 != m_Attachments.size()); } |
64 | // Returns TRUE if there is at least 1 undetachable HUD attachment | 64 | // Returns TRUE if there is at least 1 non-detachable HUD attachment |
65 | bool hasLockedHUD() const; | 65 | bool hasLockedHUD() const; |
66 | |||
67 | // Returns TRUE if the specified attachment point is detachable | 66 | // Returns TRUE if the specified attachment point is detachable |
68 | bool isDetachable(S32 idxAttachPt) const { return (idxAttachPt) && (m_Attachments.find(idxAttachPt) == m_Attachments.end()); } | 67 | bool isDetachable(S32 idxAttachPt) const { return (idxAttachPt) && (m_Attachments.find(idxAttachPt) == m_Attachments.end()); } |
69 | bool isDetachable(const LLInventoryItem* pItem) const; | 68 | bool isDetachable(const LLInventoryItem* pItem) const; |
70 | bool isDetachable(LLViewerJointAttachment* pAttachPt) const; | 69 | bool isDetachable(LLViewerJointAttachment* pAttachPt) const; |
71 | bool isDetachable(LLViewerObject* pObj) const; | 70 | bool isDetachable(LLViewerObject* pObj) const; |
72 | // Returns TRUE if the specified attachment point is set undetachable by anything other than pObj (or one of its children) | 71 | // Returns TRUE if the specified attachment point is set non-detachable by anything other than pObj (or one of its children) |
73 | bool isDetachableExcept(S32 idxAttachPt, LLViewerObject* pObj) const; | 72 | bool isDetachableExcept(S32 idxAttachPt, LLViewerObject* pObj) const; |
74 | // Marks the specified attachment point as (un)detachable (return value indicates success ; used by unit tests) | 73 | // Marks the specified attachment point as (non-)detachable (return value indicates success ; used by unit tests) |
75 | bool setDetachable(S32 idxAttachPt, const LLUUID& idRlvObj, bool fDetachable); | 74 | bool setDetachable(S32 idxAttachPt, const LLUUID& idRlvObj, bool fDetachable); |
76 | bool setDetachable(LLViewerObject* pObj, const LLUUID& idRlvObj, bool fDetachable); | 75 | bool setDetachable(LLViewerObject* pObj, const LLUUID& idRlvObj, bool fDetachable); |
77 | 76 | ||
78 | // Adds or removes an exception for the specified restriction | 77 | // Adds or removes an exception for the specified behaviour |
79 | void addException(ERlvBehaviour eBehaviour, const LLUUID& uuid); | 78 | void addException(const LLUUID& idObj, ERlvBehaviour eBhvr, const RlvExceptionOption& varOption); |
80 | void removeException(ERlvBehaviour eBehaviour, const LLUUID& uuid); | 79 | void removeException(const LLUUID& idObj, ERlvBehaviour eBhvr, const RlvExceptionOption& varOption); |
81 | // Returns TRUE is the specified UUID is exempt from a restriction (tplure/sendim/recvim/etc) | 80 | // Returns TRUE if the specified option was added as an exception for the specified behaviour |
82 | bool isException(ERlvBehaviour eBehaviour, const LLUUID& uuid) const; | 81 | bool isException(ERlvBehaviour eBhvr, const RlvExceptionOption& varOption, ERlvExceptionCheck typeCheck = RLV_CHECK_DEFAULT) const; |
83 | bool isException(const std::string& strBehaviour, const LLUUID& uuid) const; | 82 | // Returns TRUE if the specified behaviour should behave "permissive" (rather than "strict"/"secure") |
83 | bool isPermissive(ERlvBehaviour eBhvr) const; | ||
84 | 84 | ||
85 | // Returns TRUE if the specified layer is removable (use hasBehaviour(RLV_BHVR_REMOUTFIT) for the general case) | 85 | // Returns TRUE if the specified layer is removable (use hasBehaviour(RLV_BHVR_REMOUTFIT) for the general case) |
86 | bool isRemovable(EWearableType type) const { return (type < WT_COUNT) ? (0 == m_LayersRem[type]) : true; } | 86 | bool isRemovable(EWearableType type) const { return (type < WT_COUNT) ? (0 == m_LayersRem[type]) : true; } |
@@ -121,6 +121,7 @@ public: | |||
121 | void filterNames(std::string& strUTF8Text) const; // @shownames | 121 | void filterNames(std::string& strUTF8Text) const; // @shownames |
122 | const std::string& getAnonym(const std::string& strName) const; // @shownames | 122 | const std::string& getAnonym(const std::string& strName) const; // @shownames |
123 | std::string getVersionString() const; // @version | 123 | std::string getVersionString() const; // @version |
124 | std::string getVersionNumString() const; // @versionnum | ||
124 | BOOL isAgentNearby(const LLUUID& uuid) const; // @shownames | 125 | BOOL isAgentNearby(const LLUUID& uuid) const; // @shownames |
125 | bool redirectChatOrEmote(const std::string& strUTF8Test) const; // @redirchat and @rediremote | 126 | bool redirectChatOrEmote(const std::string& strUTF8Test) const; // @redirchat and @rediremote |
126 | 127 | ||
@@ -274,11 +275,10 @@ extern rlv_handler_t gRlvHandler; | |||
274 | // Inlined member functions | 275 | // Inlined member functions |
275 | // | 276 | // |
276 | 277 | ||
277 | // Checked: 2009-07-09 (RLVa-1.0.0f) | 278 | // Checked: 2009-10-04 (RLVa-1.0.4a) | Modified: RLVa-1.0.4a |
278 | inline void RlvHandler::addException(ERlvBehaviour eBehaviour, const LLUUID& uuid) | 279 | inline void RlvHandler::addException(const LLUUID& idObj, ERlvBehaviour eBhvr, const RlvExceptionOption& varOption) |
279 | { | 280 | { |
280 | if (!uuid.isNull()) | 281 | m_Exceptions.insert(std::pair<ERlvBehaviour, RlvException>(eBhvr, RlvException(idObj, eBhvr, varOption))); |
281 | m_Exceptions.insert(std::pair<LLUUID, ERlvBehaviour>(uuid, eBehaviour)); | ||
282 | } | 282 | } |
283 | 283 | ||
284 | // Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f | 284 | // Checked: 2009-07-09 (RLVa-1.0.0f) | Modified: RLVa-1.0.0f |
@@ -288,7 +288,7 @@ inline bool RlvHandler::canShowHoverText(LLViewerObject *pObj) const | |||
288 | !( (hasBehaviour(RLV_BHVR_SHOWHOVERTEXTALL)) || | 288 | !( (hasBehaviour(RLV_BHVR_SHOWHOVERTEXTALL)) || |
289 | ( (hasBehaviour(RLV_BHVR_SHOWHOVERTEXTWORLD)) && (!pObj->isHUDAttachment()) ) || | 289 | ( (hasBehaviour(RLV_BHVR_SHOWHOVERTEXTWORLD)) && (!pObj->isHUDAttachment()) ) || |
290 | ( (hasBehaviour(RLV_BHVR_SHOWHOVERTEXTHUD)) && (pObj->isHUDAttachment()) ) || | 290 | ( (hasBehaviour(RLV_BHVR_SHOWHOVERTEXTHUD)) && (pObj->isHUDAttachment()) ) || |
291 | (isException(RLV_BHVR_SHOWHOVERTEXT, pObj->getID())) ) ); | 291 | (isException(RLV_BHVR_SHOWHOVERTEXT, pObj->getID(), RLV_CHECK_PERMISSIVE)) ) ); |
292 | } | 292 | } |
293 | 293 | ||
294 | // Checked: 2009-05-23 (RLVa-0.2.0d) | Modified: RLVa-0.2.0d | 294 | // Checked: 2009-05-23 (RLVa-0.2.0d) | Modified: RLVa-0.2.0d |
@@ -321,6 +321,12 @@ inline std::string RlvHandler::getVersionString() const | |||
321 | RLVa_VERSION_MAJOR, RLVa_VERSION_MINOR, RLVa_VERSION_PATCH); | 321 | RLVa_VERSION_MAJOR, RLVa_VERSION_MINOR, RLVa_VERSION_PATCH); |
322 | } | 322 | } |
323 | 323 | ||
324 | // Checked: 2009-10-04 (RLVa-1.0.4b) | Added: RLVa-1.0.4b | ||
325 | inline std::string RlvHandler::getVersionNumString() const | ||
326 | { | ||
327 | return llformat("%d%02d%02d%02d", RLV_VERSION_MAJOR, RLV_VERSION_MINOR, RLV_VERSION_PATCH, RLV_VERSION_BUILD); | ||
328 | } | ||
329 | |||
324 | // Checked: 2009-05-23 (RLVa-0.2.0d) | Modified: RLVa-0.2.0d | 330 | // Checked: 2009-05-23 (RLVa-0.2.0d) | Modified: RLVa-0.2.0d |
325 | inline bool RlvHandler::hasAttachPointName(const LLInventoryItem *pItem, bool fStrict) const | 331 | inline bool RlvHandler::hasAttachPointName(const LLInventoryItem *pItem, bool fStrict) const |
326 | { | 332 | { |
@@ -334,18 +340,6 @@ inline bool RlvHandler::hasBehaviour(ERlvBehaviour eBehaviour, const std::string | |||
334 | } | 340 | } |
335 | 341 | ||
336 | // Checked: | 342 | // Checked: |
337 | inline bool RlvHandler::hasBehaviour(const std::string& strBehaviour) const | ||
338 | { | ||
339 | return hasBehaviourExcept(strBehaviour, LLUUID::null); | ||
340 | } | ||
341 | |||
342 | // Checked: | ||
343 | inline bool RlvHandler::hasBehaviour(const std::string& strBehaviour, const std::string& strOption) const | ||
344 | { | ||
345 | return hasBehaviourExcept(strBehaviour, strOption, LLUUID::null); | ||
346 | } | ||
347 | |||
348 | // Checked: | ||
349 | inline bool RlvHandler::hasBehaviourExcept(ERlvBehaviour eBehaviour, const LLUUID& idObj) const | 343 | inline bool RlvHandler::hasBehaviourExcept(ERlvBehaviour eBehaviour, const LLUUID& idObj) const |
350 | { | 344 | { |
351 | return hasBehaviourExcept(eBehaviour, std::string(), idObj); | 345 | return hasBehaviourExcept(eBehaviour, std::string(), idObj); |
@@ -379,22 +373,11 @@ inline bool RlvHandler::isDetachable(LLViewerObject* pObj) const | |||
379 | return (pObj == NULL) || (!pObj->isAttachment()) || (isDetachable(getAttachPointIndex(pObj))); | 373 | return (pObj == NULL) || (!pObj->isAttachment()) || (isDetachable(getAttachPointIndex(pObj))); |
380 | } | 374 | } |
381 | 375 | ||
382 | // Checked: | 376 | inline bool RlvHandler::isPermissive(ERlvBehaviour eBhvr) const |
383 | inline bool RlvHandler::isException(ERlvBehaviour eBehaviour, const LLUUID& uuid) const | ||
384 | { | ||
385 | for (rlv_exception_map_t::const_iterator itException = m_Exceptions.lower_bound(uuid), | ||
386 | endException = m_Exceptions.upper_bound(uuid); itException != endException; ++itException) | ||
387 | { | ||
388 | if (itException->second == eBehaviour) | ||
389 | return true; | ||
390 | } | ||
391 | return false; | ||
392 | } | ||
393 | |||
394 | // Checked: | ||
395 | inline bool RlvHandler::isException(const std::string& strBehaviour, const LLUUID& uuid) const | ||
396 | { | 377 | { |
397 | return hasBehaviour(strBehaviour, uuid.asString()); | 378 | return (RlvCommand::hasStrictVariant(eBhvr)) |
379 | ? !((hasBehaviour(RLV_BHVR_PERMISSIVE)) || (isException(RLV_BHVR_PERMISSIVE, eBhvr, RLV_CHECK_PERMISSIVE))) | ||
380 | : true; | ||
398 | } | 381 | } |
399 | 382 | ||
400 | // Checked: 2009-07-29 (RLVa-1.0.1b) | Added: RLVa-1.0.1b | 383 | // Checked: 2009-07-29 (RLVa-1.0.1b) | Added: RLVa-1.0.1b |
@@ -428,19 +411,16 @@ inline bool RlvHandler::isRemovableExcept(EWearableType type, const LLUUID& idOb | |||
428 | } | 411 | } |
429 | #endif // RLV_EXTENSION_FLAG_NOSTRIP | 412 | #endif // RLV_EXTENSION_FLAG_NOSTRIP |
430 | 413 | ||
431 | // Checked: 2009-07-09 (RLVa-1.0.0f) | 414 | // Checked: 2009-10-04 (RLVa-1.0.4a) | Modified: RLVa-1.0.4a |
432 | inline void RlvHandler::removeException(ERlvBehaviour eBehaviour, const LLUUID &uuid) | 415 | inline void RlvHandler::removeException(const LLUUID& idObj, ERlvBehaviour eBhvr, const RlvExceptionOption& varOption) |
433 | { | 416 | { |
434 | if (!uuid.isNull()) | 417 | for (rlv_exception_map_t::iterator itException = m_Exceptions.lower_bound(eBhvr), |
418 | endException = m_Exceptions.upper_bound(eBhvr); itException != endException; ++itException) | ||
435 | { | 419 | { |
436 | for (rlv_exception_map_t::iterator itException = m_Exceptions.lower_bound(uuid), | 420 | if ( (itException->second.idObject == idObj) && (itException->second.varOption == varOption) ) |
437 | endException = m_Exceptions.upper_bound(uuid); itException != endException; ++itException) | ||
438 | { | 421 | { |
439 | if (itException->second == eBehaviour) | 422 | m_Exceptions.erase(itException); |
440 | { | 423 | break; |
441 | m_Exceptions.erase(itException); | ||
442 | break; | ||
443 | } | ||
444 | } | 424 | } |
445 | } | 425 | } |
446 | } | 426 | } |
diff --git a/linden/indra/newview/rlvhelper.cpp b/linden/indra/newview/rlvhelper.cpp index f495384..c8d430d 100644 --- a/linden/indra/newview/rlvhelper.cpp +++ b/linden/indra/newview/rlvhelper.cpp | |||
@@ -23,7 +23,7 @@ RlvCommand::RlvBhvrTable RlvCommand::m_BhvrMap; | |||
23 | 23 | ||
24 | // Checked: 2009-09-10 (RLVa-1.0.3a) | Modified: RLVa-1.0.3a | 24 | // Checked: 2009-09-10 (RLVa-1.0.3a) | Modified: RLVa-1.0.3a |
25 | RlvCommand::RlvCommand(const std::string& strCommand) | 25 | RlvCommand::RlvCommand(const std::string& strCommand) |
26 | : m_eBehaviour(RLV_BHVR_UNKNOWN), m_eParamType(RLV_TYPE_UNKNOWN) | 26 | : m_eBehaviour(RLV_BHVR_UNKNOWN), m_fStrict(false), m_eParamType(RLV_TYPE_UNKNOWN) |
27 | { | 27 | { |
28 | if ((m_fValid = parseCommand(strCommand, m_strBehaviour, m_strOption, m_strParam))) | 28 | if ((m_fValid = parseCommand(strCommand, m_strBehaviour, m_strOption, m_strParam))) |
29 | { | 29 | { |
@@ -51,8 +51,12 @@ RlvCommand::RlvCommand(const std::string& strCommand) | |||
51 | return; | 51 | return; |
52 | } | 52 | } |
53 | 53 | ||
54 | RlvBhvrTable::const_iterator itBhvr = m_BhvrMap.find(m_strBehaviour); | 54 | // Check if this is the "strict" (aka "secure") variation of a behaviour |
55 | if (itBhvr != m_BhvrMap.end()) | 55 | std::string::size_type idxStrict = m_strBehaviour.find("_sec"); |
56 | m_fStrict = (std::string::npos != idxStrict) && (idxStrict + 4 == m_strBehaviour.length()); | ||
57 | |||
58 | RlvBhvrTable::const_iterator itBhvr = m_BhvrMap.find( (!m_fStrict) ? m_strBehaviour : m_strBehaviour.substr(0, idxStrict)); | ||
59 | if ( (itBhvr != m_BhvrMap.end()) && ((!m_fStrict) || (hasStrictVariant(itBhvr->second))) ) | ||
56 | m_eBehaviour = itBhvr->second; | 60 | m_eBehaviour = itBhvr->second; |
57 | } | 61 | } |
58 | 62 | ||
@@ -104,8 +108,8 @@ void RlvCommand::initLookupTable() | |||
104 | "remoutfit", "getoutfit", "getattach", "showinv", "viewnote", "unsit", "sit", "sendchannel", "getstatus", "getstatusall", | 108 | "remoutfit", "getoutfit", "getattach", "showinv", "viewnote", "unsit", "sit", "sendchannel", "getstatus", "getstatusall", |
105 | "getinv", "getinvworn", "findfolder", "findfolders", "attach", "attachall", "detachall", "getpath", "attachthis", | 109 | "getinv", "getinvworn", "findfolder", "findfolders", "attach", "attachall", "detachall", "getpath", "attachthis", |
106 | "attachallthis", "detachthis", "detachallthis", "fartouch", "showworldmap", "showminimap", "showloc", "tpto", "accepttp", | 110 | "attachallthis", "detachthis", "detachallthis", "fartouch", "showworldmap", "showminimap", "showloc", "tpto", "accepttp", |
107 | "shownames", "fly", "getsitid", "setdebug", "setenv", "detachme", "showhovertextall", "showhovertextworld", | 111 | "acceptpermission", "shownames", "fly", "getsitid", "setdebug", "setenv", "detachme", "showhovertextall", |
108 | "showhovertexthud", "showhovertext", "notify" | 112 | "showhovertextworld", "showhovertexthud", "showhovertext", "notify", "defaultwear", "versionnum", "permissive" |
109 | }; | 113 | }; |
110 | 114 | ||
111 | for (int idxBvhr = 0; idxBvhr < RLV_BHVR_COUNT; idxBvhr++) | 115 | for (int idxBvhr = 0; idxBvhr < RLV_BHVR_COUNT; idxBvhr++) |
@@ -133,12 +137,14 @@ bool RlvObject::addCommand(const RlvCommand& rlvCmd) | |||
133 | return false; | 137 | return false; |
134 | 138 | ||
135 | // Don't add duplicate commands for this object (ie @detach=n followed by another @detach=n later on) | 139 | // Don't add duplicate commands for this object (ie @detach=n followed by another @detach=n later on) |
136 | bool fDuplicate = | 140 | for (rlv_command_list_t::iterator itCmd = m_Commands.begin(); itCmd != m_Commands.end(); ++itCmd) |
137 | (RLV_BHVR_UNKNOWN != rlvCmd.getBehaviourType()) | 141 | { |
138 | ? hasBehaviour(rlvCmd.getBehaviourType(), rlvCmd.getOption()) | 142 | if ( (itCmd->getBehaviour() == rlvCmd.getBehaviour()) && (itCmd->getOption() == rlvCmd.getOption()) && |
139 | : hasBehaviour(rlvCmd.getBehaviour(), rlvCmd.getOption()); | 143 | (itCmd->isStrict() == rlvCmd.isStrict() ) ) |
140 | if (fDuplicate) | 144 | { |
141 | return false; | 145 | return false; |
146 | } | ||
147 | } | ||
142 | 148 | ||
143 | // Now that we know it's not a duplicate, add it to the end of the list | 149 | // Now that we know it's not a duplicate, add it to the end of the list |
144 | m_Commands.push_back(rlvCmd); | 150 | m_Commands.push_back(rlvCmd); |
@@ -155,7 +161,8 @@ bool RlvObject::removeCommand(const RlvCommand& rlvCmd) | |||
155 | for (rlv_command_list_t::iterator itCmd = m_Commands.begin(); itCmd != m_Commands.end(); ++itCmd) | 161 | for (rlv_command_list_t::iterator itCmd = m_Commands.begin(); itCmd != m_Commands.end(); ++itCmd) |
156 | { | 162 | { |
157 | //if (*itCmd == rlvCmd) <- commands will never be equal since one is an add and the other is a remove *rolls eyes* | 163 | //if (*itCmd == rlvCmd) <- commands will never be equal since one is an add and the other is a remove *rolls eyes* |
158 | if ( (itCmd->getBehaviour() == rlvCmd.getBehaviour()) && (itCmd->getOption() == rlvCmd.getOption()) ) | 164 | if ( (itCmd->getBehaviour() == rlvCmd.getBehaviour()) && (itCmd->getOption() == rlvCmd.getOption()) && |
165 | (itCmd->isStrict() == rlvCmd.isStrict() ) ) | ||
159 | { | 166 | { |
160 | m_Commands.erase(itCmd); | 167 | m_Commands.erase(itCmd); |
161 | return true; | 168 | return true; |
@@ -164,34 +171,18 @@ bool RlvObject::removeCommand(const RlvCommand& rlvCmd) | |||
164 | return false; // Command was never added so nothing to remove now | 171 | return false; // Command was never added so nothing to remove now |
165 | } | 172 | } |
166 | 173 | ||
167 | bool RlvObject::hasBehaviour(ERlvBehaviour eBehaviour) const | 174 | bool RlvObject::hasBehaviour(ERlvBehaviour eBehaviour, bool fStrictOnly) const |
168 | { | ||
169 | for (rlv_command_list_t::const_iterator itCmd = m_Commands.begin(); itCmd != m_Commands.end(); ++itCmd) | ||
170 | if ( (itCmd->getBehaviourType() == eBehaviour) && (itCmd->getOption().empty()) ) | ||
171 | return true; | ||
172 | return false; | ||
173 | } | ||
174 | |||
175 | bool RlvObject::hasBehaviour(const std::string& strBehaviour) const | ||
176 | { | ||
177 | for (rlv_command_list_t::const_iterator itCmd = m_Commands.begin(); itCmd != m_Commands.end(); ++itCmd) | ||
178 | if ( (itCmd->getBehaviour() == strBehaviour) && (itCmd->getOption().empty()) ) | ||
179 | return true; | ||
180 | return false; | ||
181 | } | ||
182 | |||
183 | bool RlvObject::hasBehaviour(ERlvBehaviour eBehaviour, const std::string& strOption) const | ||
184 | { | 175 | { |
185 | for (rlv_command_list_t::const_iterator itCmd = m_Commands.begin(); itCmd != m_Commands.end(); ++itCmd) | 176 | for (rlv_command_list_t::const_iterator itCmd = m_Commands.begin(); itCmd != m_Commands.end(); ++itCmd) |
186 | if ( (itCmd->getBehaviourType() == eBehaviour) && (itCmd->getOption() == strOption) ) | 177 | if ( (itCmd->getBehaviourType() == eBehaviour) && (itCmd->getOption().empty()) && ((!fStrictOnly) || (itCmd->isStrict())) ) |
187 | return true; | 178 | return true; |
188 | return false; | 179 | return false; |
189 | } | 180 | } |
190 | 181 | ||
191 | bool RlvObject::hasBehaviour(const std::string& strBehaviour, const std::string& strOption) const | 182 | bool RlvObject::hasBehaviour(ERlvBehaviour eBehaviour, const std::string& strOption, bool fStrictOnly) const |
192 | { | 183 | { |
193 | for (rlv_command_list_t::const_iterator itCmd = m_Commands.begin(); itCmd != m_Commands.end(); ++itCmd) | 184 | for (rlv_command_list_t::const_iterator itCmd = m_Commands.begin(); itCmd != m_Commands.end(); ++itCmd) |
194 | if ( (itCmd->getBehaviour() == strBehaviour) && (itCmd->getOption() == strOption) ) | 185 | if ( (itCmd->getBehaviourType() == eBehaviour) && (itCmd->getOption() == strOption) && ((!fStrictOnly) || (itCmd->isStrict())) ) |
195 | return true; | 186 | return true; |
196 | return false; | 187 | return false; |
197 | } | 188 | } |
@@ -361,6 +352,11 @@ RlvWLSnapshot* RlvWLSnapshot::takeSnapshot() | |||
361 | 352 | ||
362 | BOOL RlvSettings::fShowNameTags = FALSE; | 353 | BOOL RlvSettings::fShowNameTags = FALSE; |
363 | 354 | ||
355 | BOOL RlvSettings::getEnableWear() | ||
356 | { | ||
357 | return rlvGetSettingBOOL(RLV_SETTING_ENABLEWEAR, TRUE) && (!gRlvHandler.hasBehaviour(RLV_BHVR_DEFAULTWEAR)); | ||
358 | } | ||
359 | |||
364 | #ifdef RLV_EXTENSION_STARTLOCATION | 360 | #ifdef RLV_EXTENSION_STARTLOCATION |
365 | // Checked: 2009-07-08 (RLVa-1.0.0e) | Modified: RLVa-0.2.1d | 361 | // Checked: 2009-07-08 (RLVa-1.0.0e) | Modified: RLVa-0.2.1d |
366 | void RlvSettings::updateLoginLastLocation() | 362 | void RlvSettings::updateLoginLastLocation() |
@@ -475,6 +471,13 @@ bool rlvCanDeleteOrReturn() | |||
475 | return fIsAllowed; | 471 | return fIsAllowed; |
476 | } | 472 | } |
477 | 473 | ||
474 | // Checked: 2009-10-04 (RLVa-1.0.4b) | Modified: RLVa-1.0.4b | ||
475 | BOOL rlvEnableWearEnabler(void* pParam) | ||
476 | { | ||
477 | // Visually disables the "Enable Wear" option when restricted from toggling it | ||
478 | return (!gRlvHandler.hasBehaviour(RLV_BHVR_DEFAULTWEAR)); | ||
479 | } | ||
480 | |||
478 | // Checked: 2009-05-26 (RLVa-0.2.0d) | Modified: RLVa-0.2.0d | 481 | // Checked: 2009-05-26 (RLVa-0.2.0d) | Modified: RLVa-0.2.0d |
479 | S32 rlvGetDirectDescendentsCount(const LLInventoryCategory* pFolder, LLAssetType::EType type) | 482 | S32 rlvGetDirectDescendentsCount(const LLInventoryCategory* pFolder, LLAssetType::EType type) |
480 | { | 483 | { |
diff --git a/linden/indra/newview/rlvhelper.h b/linden/indra/newview/rlvhelper.h index f36989b..42d10b8 100644 --- a/linden/indra/newview/rlvhelper.h +++ b/linden/indra/newview/rlvhelper.h | |||
@@ -9,6 +9,15 @@ | |||
9 | #include "llwlparamset.h" | 9 | #include "llwlparamset.h" |
10 | #include "rlvdefines.h" | 10 | #include "rlvdefines.h" |
11 | 11 | ||
12 | #ifdef LL_WINDOWS | ||
13 | #pragma warning (push) | ||
14 | #pragma warning (disable : 4702) // warning C4702: unreachable code | ||
15 | #endif | ||
16 | #include <boost/variant.hpp> | ||
17 | #ifdef LL_WINDOWS | ||
18 | #pragma warning (pop) | ||
19 | #endif | ||
20 | |||
12 | // ============================================================================ | 21 | // ============================================================================ |
13 | // RlvCommand | 22 | // RlvCommand |
14 | // | 23 | // |
@@ -28,10 +37,12 @@ public: | |||
28 | const std::string& getOption() const { return m_strOption; } | 37 | const std::string& getOption() const { return m_strOption; } |
29 | const std::string& getParam() const { return m_strParam; } | 38 | const std::string& getParam() const { return m_strParam; } |
30 | ERlvParamType getParamType() const { return m_eParamType; } | 39 | ERlvParamType getParamType() const { return m_eParamType; } |
40 | bool isStrict() const { return m_fStrict; } | ||
31 | bool isValid() const { return m_fValid; } | 41 | bool isValid() const { return m_fValid; } |
32 | 42 | ||
33 | static ERlvBehaviour getBehaviourFromString(const std::string& strBhvr); | 43 | static ERlvBehaviour getBehaviourFromString(const std::string& strBhvr); |
34 | static const std::string& getStringFromBehaviour(ERlvBehaviour eBhvr); | 44 | static const std::string& getStringFromBehaviour(ERlvBehaviour eBhvr); |
45 | static bool hasStrictVariant(ERlvBehaviour eBhvr); | ||
35 | 46 | ||
36 | static void initLookupTable(); | 47 | static void initLookupTable(); |
37 | protected: | 48 | protected: |
@@ -50,6 +61,7 @@ protected: | |||
50 | bool m_fValid; | 61 | bool m_fValid; |
51 | std::string m_strBehaviour; | 62 | std::string m_strBehaviour; |
52 | ERlvBehaviour m_eBehaviour; | 63 | ERlvBehaviour m_eBehaviour; |
64 | bool m_fStrict; | ||
53 | std::string m_strOption; | 65 | std::string m_strOption; |
54 | std::string m_strParam; | 66 | std::string m_strParam; |
55 | ERlvParamType m_eParamType; | 67 | ERlvParamType m_eParamType; |
@@ -78,10 +90,8 @@ public: | |||
78 | bool removeCommand(const RlvCommand& rlvCmd); | 90 | bool removeCommand(const RlvCommand& rlvCmd); |
79 | 91 | ||
80 | std::string getStatusString(const std::string& strMatch) const; | 92 | std::string getStatusString(const std::string& strMatch) const; |
81 | bool hasBehaviour(ERlvBehaviour eBehaviour) const; | 93 | bool hasBehaviour(ERlvBehaviour eBehaviour, bool fStrictOnly) const; |
82 | bool hasBehaviour(const std::string& strBehaviour) const; | 94 | bool hasBehaviour(ERlvBehaviour eBehaviour, const std::string& strOption, bool fStrictOnly) const; |
83 | bool hasBehaviour(ERlvBehaviour eBehaviour, const std::string& strOption) const; | ||
84 | bool hasBehaviour(const std::string& strBehaviour, const std::string& strOption) const; | ||
85 | 95 | ||
86 | const rlv_command_list_t* getCommandList() const { return &m_Commands; } | 96 | const rlv_command_list_t* getCommandList() const { return &m_Commands; } |
87 | 97 | ||
@@ -190,6 +200,24 @@ private: | |||
190 | typedef std::list<RlvRetainedCommand> rlv_retained_list_t; | 200 | typedef std::list<RlvRetainedCommand> rlv_retained_list_t; |
191 | 201 | ||
192 | // ============================================================================ | 202 | // ============================================================================ |
203 | // RlvException | ||
204 | // | ||
205 | |||
206 | typedef boost::variant<std::string, LLUUID, S32, ERlvBehaviour> RlvExceptionOption; | ||
207 | |||
208 | struct RlvException | ||
209 | { | ||
210 | public: | ||
211 | LLUUID idObject; // UUID of the object that added the exception | ||
212 | ERlvBehaviour eBehaviour; // Behaviour the exception applies to | ||
213 | RlvExceptionOption varOption; // Exception data (type is dependent on eBehaviour) | ||
214 | |||
215 | RlvException(const LLUUID& idObj, ERlvBehaviour eBhvr, const RlvExceptionOption& option) : idObject(idObj), eBehaviour(eBhvr), varOption(option) {} | ||
216 | private: | ||
217 | RlvException(); | ||
218 | }; | ||
219 | |||
220 | // ============================================================================ | ||
193 | // RlvWLSnapshot | 221 | // RlvWLSnapshot |
194 | // | 222 | // |
195 | 223 | ||
@@ -225,7 +253,7 @@ public: | |||
225 | static BOOL getDebug() { return rlvGetSettingBOOL(RLV_SETTING_DEBUG, FALSE); } | 253 | static BOOL getDebug() { return rlvGetSettingBOOL(RLV_SETTING_DEBUG, FALSE); } |
226 | static BOOL getForbidGiveToRLV() { return rlvGetSettingBOOL(RLV_SETTING_FORBIDGIVETORLV, TRUE); } | 254 | static BOOL getForbidGiveToRLV() { return rlvGetSettingBOOL(RLV_SETTING_FORBIDGIVETORLV, TRUE); } |
227 | 255 | ||
228 | static BOOL getEnableWear() { return rlvGetSettingBOOL(RLV_SETTING_ENABLEWEAR, FALSE); } | 256 | static BOOL getEnableWear(); |
229 | static BOOL getHideLockedLayers() { return rlvGetSettingBOOL(RLV_SETTING_HIDELOCKEDLAYER, FALSE); } | 257 | static BOOL getHideLockedLayers() { return rlvGetSettingBOOL(RLV_SETTING_HIDELOCKEDLAYER, FALSE); } |
230 | static BOOL getHideLockedAttach() { return rlvGetSettingBOOL(RLV_SETTING_HIDELOCKEDATTACH, FALSE); } | 258 | static BOOL getHideLockedAttach() { return rlvGetSettingBOOL(RLV_SETTING_HIDELOCKEDATTACH, FALSE); } |
231 | static BOOL getHideLockedInventory() { return rlvGetSettingBOOL(RLV_SETTING_HIDELOCKEDINVENTORY, FALSE); } | 259 | static BOOL getHideLockedInventory() { return rlvGetSettingBOOL(RLV_SETTING_HIDELOCKEDINVENTORY, FALSE); } |
@@ -290,6 +318,7 @@ struct RlvSelectIsSittingOn : public LLSelectedNodeFunctor | |||
290 | 318 | ||
291 | BOOL rlvAttachToEnabler(void* pParam); | 319 | BOOL rlvAttachToEnabler(void* pParam); |
292 | bool rlvCanDeleteOrReturn(); | 320 | bool rlvCanDeleteOrReturn(); |
321 | BOOL rlvEnableWearEnabler(void* pParam); | ||
293 | S32 rlvGetDirectDescendentsCount(const LLInventoryCategory* pFolder, LLAssetType::EType type); | 322 | S32 rlvGetDirectDescendentsCount(const LLInventoryCategory* pFolder, LLAssetType::EType type); |
294 | bool rlvIsEmote(const std::string& strUTF8Text); | 323 | bool rlvIsEmote(const std::string& strUTF8Text); |
295 | bool rlvIsValidReplyChannel(S32 nChannel); | 324 | bool rlvIsValidReplyChannel(S32 nChannel); |
@@ -344,6 +373,22 @@ inline void RlvCurrentlyWorn::fetchItem(const LLUUID& idItem) | |||
344 | } | 373 | } |
345 | } | 374 | } |
346 | 375 | ||
376 | inline bool RlvCommand::hasStrictVariant(ERlvBehaviour eBhvr) | ||
377 | { | ||
378 | switch (eBhvr) | ||
379 | { | ||
380 | case RLV_BHVR_RECVCHAT: | ||
381 | case RLV_BHVR_RECVEMOTE: | ||
382 | case RLV_BHVR_RECVIM: | ||
383 | case RLV_BHVR_SENDIM: | ||
384 | case RLV_BHVR_TPLURE: | ||
385 | case RLV_BHVR_SENDCHANNEL: | ||
386 | return true; | ||
387 | default: | ||
388 | return false; | ||
389 | } | ||
390 | } | ||
391 | |||
347 | // ============================================================================ | 392 | // ============================================================================ |
348 | // Inlined helper functions | 393 | // Inlined helper functions |
349 | // | 394 | // |
diff --git a/linden/indra/newview/skins/default/xui/de/floater_choose_group.xml b/linden/indra/newview/skins/default/xui/de/floater_choose_group.xml index dd29aa7..327cb02 100644 --- a/linden/indra/newview/skins/default/xui/de/floater_choose_group.xml +++ b/linden/indra/newview/skins/default/xui/de/floater_choose_group.xml | |||
@@ -5,4 +5,7 @@ | |||
5 | </text> | 5 | </text> |
6 | <button label="OK" label_selected="OK" name="OK" /> | 6 | <button label="OK" label_selected="OK" name="OK" /> |
7 | <button label="Abbrechen" label_selected="Abbrechen" name="Cancel" /> | 7 | <button label="Abbrechen" label_selected="Abbrechen" name="Cancel" /> |
8 | <string name="none"> | ||
9 | keine | ||
10 | </string> | ||
8 | </floater> | 11 | </floater> |
diff --git a/linden/indra/newview/skins/default/xui/de/panel_groups.xml b/linden/indra/newview/skins/default/xui/de/panel_groups.xml index 95a2ef1..a7d6f98 100644 --- a/linden/indra/newview/skins/default/xui/de/panel_groups.xml +++ b/linden/indra/newview/skins/default/xui/de/panel_groups.xml | |||
@@ -12,4 +12,7 @@ | |||
12 | <button label="Verlassen" name="Leave" /> | 12 | <button label="Verlassen" name="Leave" /> |
13 | <button label="Erstellen..." name="Create" /> | 13 | <button label="Erstellen..." name="Create" /> |
14 | <button label="Suchen..." name="Search..." /> | 14 | <button label="Suchen..." name="Search..." /> |
15 | <string name="none"> | ||
16 | keine | ||
17 | </string> | ||
15 | </panel> | 18 | </panel> |
diff --git a/linden/indra/newview/skins/default/xui/en-us/floater_choose_group.xml b/linden/indra/newview/skins/default/xui/en-us/floater_choose_group.xml index 02001e9..f438262 100644 --- a/linden/indra/newview/skins/default/xui/en-us/floater_choose_group.xml +++ b/linden/indra/newview/skins/default/xui/en-us/floater_choose_group.xml | |||
@@ -18,4 +18,7 @@ | |||
18 | <button bottom="-236" font="SansSerif" halign="center" height="20" label="Cancel" | 18 | <button bottom="-236" font="SansSerif" halign="center" height="20" label="Cancel" |
19 | label_selected="Cancel" left_delta="88" mouse_opaque="true" name="Cancel" | 19 | label_selected="Cancel" left_delta="88" mouse_opaque="true" name="Cancel" |
20 | width="80" /> | 20 | width="80" /> |
21 | <string name="none"> | ||
22 | none | ||
23 | </string> | ||
21 | </floater> | 24 | </floater> |
diff --git a/linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml b/linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml index 3c860e9..57f955f 100644 --- a/linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml +++ b/linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml | |||
@@ -70,7 +70,7 @@ | |||
70 | <button bottom_delta="-25" follows="top|right" height="22" label="Mute..." | 70 | <button bottom_delta="-25" follows="top|right" height="22" label="Mute..." |
71 | left_delta="0" name="mute_btn" | 71 | left_delta="0" name="mute_btn" |
72 | tool_tip="" width="80" /> | 72 | tool_tip="" width="80" /> |
73 | <button bottom_delta="-25" follows="top|right" height="22" label="Unmute..." | 73 | <button bottom_delta="0" follows="top|right" height="22" label="Unmute..." |
74 | left_delta="0" name="unmute_btn" | 74 | left_delta="0" name="unmute_btn" |
75 | tool_tip="" width="80" /> | 75 | tool_tip="" width="80" /> |
76 | <button bottom_delta="-25" follows="top|right" height="22" label="Report..." | 76 | <button bottom_delta="-25" follows="top|right" height="22" label="Report..." |
diff --git a/linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml b/linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml index 8d55a3b..222a9ad 100644 --- a/linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml +++ b/linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml | |||
@@ -2009,6 +2009,13 @@ | |||
2009 | <on_click function="Advanced.ToggleClothingFloater" | 2009 | <on_click function="Advanced.ToggleClothingFloater" |
2010 | userdata="" /> | 2010 | userdata="" /> |
2011 | </menu_item_check> | 2011 | </menu_item_check> |
2012 | <menu_item_check name="Allow Multiple Instances" | ||
2013 | label="Allow Multiple Instances"> | ||
2014 | <on_click function="Advanced.ToggleMultipleViewers" | ||
2015 | userdata="" /> | ||
2016 | <on_check function="Advanced.CheckMultipleViewers" | ||
2017 | userdata="" /> | ||
2018 | </menu_item_check> | ||
2012 | <menu_item_call name="Debug Settings" | 2019 | <menu_item_call name="Debug Settings" |
2013 | label="Debug Settings"> | 2020 | label="Debug Settings"> |
2014 | <on_click function="Advanced.ShowDebugSettings" | 2021 | <on_click function="Advanced.ShowDebugSettings" |
diff --git a/linden/indra/newview/skins/default/xui/en-us/panel_groups.xml b/linden/indra/newview/skins/default/xui/en-us/panel_groups.xml index c47985b..0bc7866 100644 --- a/linden/indra/newview/skins/default/xui/en-us/panel_groups.xml +++ b/linden/indra/newview/skins/default/xui/en-us/panel_groups.xml | |||
@@ -36,4 +36,7 @@ | |||
36 | label="Search..." name="Search..." width="80" /> | 36 | label="Search..." name="Search..." width="80" /> |
37 | <button bottom_delta="-25" follows="top|right" font="SansSerif" height="22" | 37 | <button bottom_delta="-25" follows="top|right" font="SansSerif" height="22" |
38 | label="Leave" name="Leave" width="80" /> | 38 | label="Leave" name="Leave" width="80" /> |
39 | <string name="none"> | ||
40 | none | ||
41 | </string> | ||
39 | </panel> | 42 | </panel> |
diff --git a/linden/indra/newview/skins/default/xui/ja/floater_choose_group.xml b/linden/indra/newview/skins/default/xui/ja/floater_choose_group.xml index 08c91f1..0e3153c 100644 --- a/linden/indra/newview/skins/default/xui/ja/floater_choose_group.xml +++ b/linden/indra/newview/skins/default/xui/ja/floater_choose_group.xml | |||
@@ -5,4 +5,7 @@ | |||
5 | </text> | 5 | </text> |
6 | <button label="OK" label_selected="OK" name="OK" /> | 6 | <button label="OK" label_selected="OK" name="OK" /> |
7 | <button label="εγζΆγ" label_selected="εγζΆγ" name="Cancel" /> | 7 | <button label="εγζΆγ" label_selected="εγζΆγ" name="Cancel" /> |
8 | <string name="none"> | ||
9 | γ°γ«γΌγγͺγ | ||
10 | </string> | ||
8 | </floater> | 11 | </floater> |
diff --git a/linden/indra/newview/skins/default/xui/ja/panel_groups.xml b/linden/indra/newview/skins/default/xui/ja/panel_groups.xml index 785fd86..adfdcd4 100644 --- a/linden/indra/newview/skins/default/xui/ja/panel_groups.xml +++ b/linden/indra/newview/skins/default/xui/ja/panel_groups.xml | |||
@@ -13,4 +13,7 @@ | |||
13 | <button label="ζγγ" name="Leave" /> | 13 | <button label="ζγγ" name="Leave" /> |
14 | <button label="δ½ζ..." name="Create" /> | 14 | <button label="δ½ζ..." name="Create" /> |
15 | <button label="ζ€η΄’..." name="Search..." /> | 15 | <button label="ζ€η΄’..." name="Search..." /> |
16 | <string name="none"> | ||
17 | γ°γ«γΌγγͺγ | ||
18 | </string> | ||
16 | </panel> | 19 | </panel> |
diff --git a/linden/indra/newview/skins/default/xui/ko/floater_choose_group.xml b/linden/indra/newview/skins/default/xui/ko/floater_choose_group.xml index 2cb821a..53bb889 100644 --- a/linden/indra/newview/skins/default/xui/ko/floater_choose_group.xml +++ b/linden/indra/newview/skins/default/xui/ko/floater_choose_group.xml | |||
@@ -5,4 +5,7 @@ | |||
5 | </text> | 5 | </text> |
6 | <button label="νμΈ" label_selected="νμΈ" name="OK" /> | 6 | <button label="νμΈ" label_selected="νμΈ" name="OK" /> |
7 | <button label="μ·¨μ" label_selected="μ·¨μ" name="Cancel" /> | 7 | <button label="μ·¨μ" label_selected="μ·¨μ" name="Cancel" /> |
8 | <string name="none"> | ||
9 | κ·Έλ£Ή μμ | ||
10 | </string> | ||
8 | </floater> | 11 | </floater> |
diff --git a/linden/indra/newview/skins/default/xui/ko/panel_groups.xml b/linden/indra/newview/skins/default/xui/ko/panel_groups.xml index cdd28a6..8e66006 100644 --- a/linden/indra/newview/skins/default/xui/ko/panel_groups.xml +++ b/linden/indra/newview/skins/default/xui/ko/panel_groups.xml | |||
@@ -13,4 +13,7 @@ | |||
13 | <button label="νν΄" name="Leave" width="90"/> | 13 | <button label="νν΄" name="Leave" width="90"/> |
14 | <button label="λ§λ€κΈ°" name="Create" width="90"/> | 14 | <button label="λ§λ€κΈ°" name="Create" width="90"/> |
15 | <button label="κ²μ" name="Search..." width="90"/> | 15 | <button label="κ²μ" name="Search..." width="90"/> |
16 | <string name="none"> | ||
17 | κ·Έλ£Ή μμ | ||
18 | </string> | ||
16 | </panel> | 19 | </panel> |