aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--ChangeLog.txt83
-rw-r--r--linden/indra/llmedia/llmediaimplllmozlib.cpp14
-rw-r--r--linden/indra/newview/app_settings/settings.xml2
-rw-r--r--linden/indra/newview/jcfloater_animation_list.cpp2
-rw-r--r--linden/indra/newview/jcfloater_animation_list.h2
-rw-r--r--linden/indra/newview/llagent.cpp4
-rw-r--r--linden/indra/newview/llappviewer.cpp2
-rw-r--r--linden/indra/newview/llassetuploadresponders.cpp2
-rw-r--r--linden/indra/newview/llchatbar.cpp18
-rw-r--r--linden/indra/newview/llfloatergroups.cpp15
-rw-r--r--linden/indra/newview/llfloatermap.cpp57
-rw-r--r--linden/indra/newview/llfloatermap.h6
-rw-r--r--linden/indra/newview/llfloaterworldmap.cpp2
-rw-r--r--linden/indra/newview/llinventorybridge.cpp2
-rw-r--r--linden/indra/newview/llpanelinventory.cpp2
-rw-r--r--linden/indra/newview/llpreview.cpp29
-rw-r--r--linden/indra/newview/llpreview.h1
-rw-r--r--linden/indra/newview/llstartup.cpp17
-rw-r--r--linden/indra/newview/llviewermenu.cpp34
-rw-r--r--linden/indra/newview/llviewermessage.cpp31
-rw-r--r--linden/indra/newview/llviewertexteditor.cpp2
-rw-r--r--linden/indra/newview/rlvdefines.h19
-rw-r--r--linden/indra/newview/rlvextensions.cpp34
-rw-r--r--linden/indra/newview/rlvextensions.h2
-rw-r--r--linden/indra/newview/rlvhandler.cpp122
-rw-r--r--linden/indra/newview/rlvhandler.h108
-rw-r--r--linden/indra/newview/rlvhelper.cpp67
-rw-r--r--linden/indra/newview/rlvhelper.h55
-rw-r--r--linden/indra/newview/skins/default/xui/de/floater_choose_group.xml3
-rw-r--r--linden/indra/newview/skins/default/xui/de/panel_groups.xml3
-rw-r--r--linden/indra/newview/skins/default/xui/en-us/floater_choose_group.xml3
-rw-r--r--linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml2
-rw-r--r--linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml7
-rw-r--r--linden/indra/newview/skins/default/xui/en-us/panel_groups.xml3
-rw-r--r--linden/indra/newview/skins/default/xui/ja/floater_choose_group.xml3
-rw-r--r--linden/indra/newview/skins/default/xui/ja/panel_groups.xml3
-rw-r--r--linden/indra/newview/skins/default/xui/ko/floater_choose_group.xml3
-rw-r--r--linden/indra/newview/skins/default/xui/ko/panel_groups.xml3
38 files changed, 562 insertions, 205 deletions
diff --git a/ChangeLog.txt b/ChangeLog.txt
index e4a0a2e..3a474b4 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -1,5 +1,88 @@
12009-10-21 McCabe Maxsted <hakushakukun@gmail.com>
2
3 * Added Advanced menu option for AllowMultipleViewers for testing purposes.
4
5 modified: linden/indra/newview/llviewermenu.cpp
6 modified: linden/indra/newview/skins/default/xui/en-us/menu_viewer.xml
7
8
92009-10-19 McCabe Maxsted <hakushakukun@gmail.com>
10
11 * Partial fix for avatar names not displaying at > 1024m
12 (won't be fixed until LL actually sends height in more than one byte -_-)
13
14 modified: linden/indra/newview/llfloatermap.cpp
15
16
17 * Clamp map teleporting at 4096 rather than 1000.
18
19 modified: linden/indra/newview/llfloaterworldmap.cpp
20
21
22 * Applied rlva_init-imprudence.patch (fixes RLVa not initializing in 1.2).
23
24 modified: linden/indra/newview/llappviewer.cpp
25 modified: linden/indra/newview/llstartup.cpp
26
27
282009-10-17 McCabe Maxsted <hakushakukun@gmail.com>
29
30 * Ported notecard security fix from LL's 1.23.5 viewer.
31
32 modified: linden/indra/newview/llassetuploadresponders.cpp
33 modified: linden/indra/newview/llpreview.cpp
34 modified: linden/indra/newview/llpreview.h
35
36
372009-10-16 McCabe Maxsted <hakushakukun@gmail.com>
38
39 * Applied RLVa-1.0.4e_20091010_SL-1.22.11-diff.patch.
40
41 modified: linden/indra/newview/app_settings/settings.xml
42 modified: linden/indra/newview/llagent.cpp
43 modified: linden/indra/newview/llchatbar.cpp
44 modified: linden/indra/newview/llinventorybridge.cpp
45 modified: linden/indra/newview/llpanelinventory.cpp
46 modified: linden/indra/newview/llviewermenu.cpp
47 modified: linden/indra/newview/llviewermessage.cpp
48 modified: linden/indra/newview/llviewertexteditor.cpp
49 modified: linden/indra/newview/rlvdefines.h
50 modified: linden/indra/newview/rlvextensions.cpp
51 modified: linden/indra/newview/rlvextensions.h
52 modified: linden/indra/newview/rlvhandler.cpp
53 modified: linden/indra/newview/rlvhandler.h
54 modified: linden/indra/newview/rlvhelper.cpp
55 modified: linden/indra/newview/rlvhelper.h
56
57
12009-10-13 McCabe Maxsted <hakushakukun@gmail.com> 582009-10-13 McCabe Maxsted <hakushakukun@gmail.com>
2 59
60 * Applied patch for VWR-6787 by Alissa Sabre - 'none' text in group window not translatable.
61
62 modified: indra/newview/llfloatergroups.cpp
63 modified: indra/newview/skins/default/xui/de/floater_choose_group.xml
64 modified: indra/newview/skins/default/xui/de/panel_groups.xml
65 modified: indra/newview/skins/default/xui/en-us/floater_choose_group.xml
66 modified: indra/newview/skins/default/xui/en-us/panel_groups.xml
67 modified: indra/newview/skins/default/xui/ja/floater_choose_group.xml
68 modified: indra/newview/skins/default/xui/ja/panel_groups.xml
69 modified: indra/newview/skins/default/xui/ko/floater_choose_group.xml
70 modified: indra/newview/skins/default/xui/ko/panel_groups.xml
71
72
73 * Combine the two mini-map mute buttons into one.
74
75 modified: linden/indra/newview/llfloatermap.cpp
76 modified: linden/indra/newview/skins/default/xui/en-us/floater_mini_map.xml
77
78
79 * Parcel highlighting when selecting a name in radar is less buggy.
80
81 modified: linden/indra/newview/llfloatermap.cpp
82 modified: linden/indra/newview/llfloatermap.h
83 modified: linden/indra/newview/llviewermessage.cpp
84
85
3 * Added history button for group chat as well. 86 * Added history button for group chat as well.
4 87
5 modified: linden/indra/newview/skins/default/xui/en-us/floater_instant_message_group.xml 88 modified: linden/indra/newview/skins/default/xui/en-us/floater_instant_message_group.xml
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
90bool LLMediaImplLLMozLib::startup( LLMediaManagerData* init_data ) 90bool 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 @@
61std::map<const LLUUID, LLFloaterGroupPicker*> LLFloaterGroupPicker::sInstances; 61std::map<const LLUUID, LLFloaterGroupPicker*> LLFloaterGroupPicker::sInstances;
62 62
63// helper functions 63// helper functions
64void init_group_list(LLScrollListCtrl* ctrl, const LLUUID& highlight_id, U64 powers_mask = GP_ALL_POWERS); 64void 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
117BOOL LLFloaterGroupPicker::postBuild() 117BOOL 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
460void init_group_list(LLScrollListCtrl* ctrl, const LLUUID& highlight_id, U64 powers_mask) 463void 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
400bool LLFloaterMap::getInChatList(LLUUID agent_id) 413bool 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
429bool LLFloaterMap::getIsTyping(LLUUID agent_id) 442bool 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
555BOOL LLFloaterMap::getKickable(const LLUUID &agent_id) 579BOOL 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()
770void LLFloaterWorldMap::trackURL(const std::string& region_name, S32 x_coord, S32 y_coord, S32 z_coord) 770void 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
600void 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
10376class 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
10387class 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
43const S32 RLV_VERSION_MAJOR = 1; 43const S32 RLV_VERSION_MAJOR = 1;
44const S32 RLV_VERSION_MINOR = 20; 44const S32 RLV_VERSION_MINOR = 21;
45const S32 RLV_VERSION_PATCH = 2; 45const S32 RLV_VERSION_PATCH = 0;
46const S32 RLV_VERSION_BUILD = 0;
46 47
47// Implementation version 48// Implementation version
48const S32 RLVa_VERSION_MAJOR = 1; 49const S32 RLVa_VERSION_MAJOR = 1;
49const S32 RLVa_VERSION_MINOR = 0; 50const S32 RLVa_VERSION_MINOR = 0;
50const S32 RLVa_VERSION_PATCH = 3; 51const S32 RLVa_VERSION_PATCH = 4;
51const S32 RLVa_VERSION_BUILD = 4; 52const 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
182enum 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
14std::map<std::string, S16> RlvExtGetSet::m_DbgAllowed; 14std::map<std::string, S16> RlvExtGetSet::m_DbgAllowed;
15std::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
17RlvExtGetSet::RlvExtGetSet() 18RlvExtGetSet::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
176std::string RlvExtGetSet::onGetPseudoDebug(const std::string& strSetting) 177std::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
188void RlvExtGetSet::onSetDebug(std::string strSetting, const std::string& strValue) 197void 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
239void 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:
33public: 34public:
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
341bool 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
349bool RlvHandler::hasBehaviourExcept(ERlvBehaviour eBehaviour, const std::string& strOption, const LLUUID& idObj) const 341bool 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
357bool 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
350bool 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 @@
18typedef std::map<LLUUID, RlvObject> rlv_object_map_t; 18typedef std::map<LLUUID, RlvObject> rlv_object_map_t;
19typedef std::multimap<S32, LLUUID> rlv_detach_map_t; 19typedef std::multimap<S32, LLUUID> rlv_detach_map_t;
20typedef std::map<S32, LLUUID> rlv_reattach_map_t; 20typedef std::map<S32, LLUUID> rlv_reattach_map_t;
21typedef std::multimap<LLUUID, ERlvBehaviour> rlv_exception_map_t; 21typedef std::multimap<ERlvBehaviour, RlvException> rlv_exception_map_t;
22 22
23class RlvHandler 23class 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 */
34public: 34public:
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() 54public:
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
278inline void RlvHandler::addException(ERlvBehaviour eBehaviour, const LLUUID& uuid) 279inline 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
325inline 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
325inline bool RlvHandler::hasAttachPointName(const LLInventoryItem *pItem, bool fStrict) const 331inline 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:
337inline bool RlvHandler::hasBehaviour(const std::string& strBehaviour) const
338{
339 return hasBehaviourExcept(strBehaviour, LLUUID::null);
340}
341
342// Checked:
343inline bool RlvHandler::hasBehaviour(const std::string& strBehaviour, const std::string& strOption) const
344{
345 return hasBehaviourExcept(strBehaviour, strOption, LLUUID::null);
346}
347
348// Checked:
349inline bool RlvHandler::hasBehaviourExcept(ERlvBehaviour eBehaviour, const LLUUID& idObj) const 343inline 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: 376inline bool RlvHandler::isPermissive(ERlvBehaviour eBhvr) const
383inline 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:
395inline 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
432inline void RlvHandler::removeException(ERlvBehaviour eBehaviour, const LLUUID &uuid) 415inline 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
25RlvCommand::RlvCommand(const std::string& strCommand) 25RlvCommand::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
167bool RlvObject::hasBehaviour(ERlvBehaviour eBehaviour) const 174bool 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
175bool 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
183bool 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
191bool RlvObject::hasBehaviour(const std::string& strBehaviour, const std::string& strOption) const 182bool 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
362BOOL RlvSettings::fShowNameTags = FALSE; 353BOOL RlvSettings::fShowNameTags = FALSE;
363 354
355BOOL 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
475BOOL 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
479S32 rlvGetDirectDescendentsCount(const LLInventoryCategory* pFolder, LLAssetType::EType type) 482S32 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();
37protected: 48protected:
@@ -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:
190typedef std::list<RlvRetainedCommand> rlv_retained_list_t; 200typedef std::list<RlvRetainedCommand> rlv_retained_list_t;
191 201
192// ============================================================================ 202// ============================================================================
203// RlvException
204//
205
206typedef boost::variant<std::string, LLUUID, S32, ERlvBehaviour> RlvExceptionOption;
207
208struct RlvException
209{
210public:
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) {}
216private:
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
291BOOL rlvAttachToEnabler(void* pParam); 319BOOL rlvAttachToEnabler(void* pParam);
292bool rlvCanDeleteOrReturn(); 320bool rlvCanDeleteOrReturn();
321BOOL rlvEnableWearEnabler(void* pParam);
293S32 rlvGetDirectDescendentsCount(const LLInventoryCategory* pFolder, LLAssetType::EType type); 322S32 rlvGetDirectDescendentsCount(const LLInventoryCategory* pFolder, LLAssetType::EType type);
294bool rlvIsEmote(const std::string& strUTF8Text); 323bool rlvIsEmote(const std::string& strUTF8Text);
295bool rlvIsValidReplyChannel(S32 nChannel); 324bool rlvIsValidReplyChannel(S32 nChannel);
@@ -344,6 +373,22 @@ inline void RlvCurrentlyWorn::fetchItem(const LLUUID& idItem)
344 } 373 }
345} 374}
346 375
376inline 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>