diff options
Diffstat (limited to '')
-rw-r--r-- | linden/indra/newview/llvoiceclient.cpp | 202 |
1 files changed, 124 insertions, 78 deletions
diff --git a/linden/indra/newview/llvoiceclient.cpp b/linden/indra/newview/llvoiceclient.cpp index 891ea73..6079447 100644 --- a/linden/indra/newview/llvoiceclient.cpp +++ b/linden/indra/newview/llvoiceclient.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -29,11 +29,11 @@ | |||
29 | * $/LicenseInfo$ | 29 | * $/LicenseInfo$ |
30 | */ | 30 | */ |
31 | 31 | ||
32 | #include <boost/tokenizer.hpp> | ||
33 | |||
34 | #include "llviewerprecompiledheaders.h" | 32 | #include "llviewerprecompiledheaders.h" |
35 | #include "llvoiceclient.h" | 33 | #include "llvoiceclient.h" |
36 | 34 | ||
35 | #include <boost/tokenizer.hpp> | ||
36 | |||
37 | #include "llsdutil.h" | 37 | #include "llsdutil.h" |
38 | 38 | ||
39 | #include "llvoavatar.h" | 39 | #include "llvoavatar.h" |
@@ -43,7 +43,6 @@ | |||
43 | #include "llcallbacklist.h" | 43 | #include "llcallbacklist.h" |
44 | #include "llviewerregion.h" | 44 | #include "llviewerregion.h" |
45 | #include "llviewernetwork.h" // for gGridChoice | 45 | #include "llviewernetwork.h" // for gGridChoice |
46 | #include "llfloateractivespeakers.h" // for LLSpeakerMgr | ||
47 | #include "llbase64.h" | 46 | #include "llbase64.h" |
48 | #include "llviewercontrol.h" | 47 | #include "llviewercontrol.h" |
49 | #include "llkeyboard.h" | 48 | #include "llkeyboard.h" |
@@ -532,7 +531,7 @@ void LLVivoxProtocolParser::CharData(const char *buffer, int length) | |||
532 | 531 | ||
533 | void LLVivoxProtocolParser::processResponse(std::string tag) | 532 | void LLVivoxProtocolParser::processResponse(std::string tag) |
534 | { | 533 | { |
535 | // llinfos << tag << llendl; | 534 | //llinfos << tag << llendl; |
536 | 535 | ||
537 | if (isEvent) | 536 | if (isEvent) |
538 | { | 537 | { |
@@ -768,7 +767,7 @@ static HANDLE sGatewayHandle = 0; | |||
768 | static bool isGatewayRunning() | 767 | static bool isGatewayRunning() |
769 | { | 768 | { |
770 | bool result = false; | 769 | bool result = false; |
771 | if(sGatewayHandle != 0) | 770 | if(sGatewayHandle != 0) |
772 | { | 771 | { |
773 | DWORD waitresult = WaitForSingleObject(sGatewayHandle, 0); | 772 | DWORD waitresult = WaitForSingleObject(sGatewayHandle, 0); |
774 | if(waitresult != WAIT_OBJECT_0) | 773 | if(waitresult != WAIT_OBJECT_0) |
@@ -854,7 +853,7 @@ LLVoiceClient::LLVoiceClient() | |||
854 | setPTTKey(keyString); | 853 | setPTTKey(keyString); |
855 | mPTTIsToggle = gSavedSettings.getBOOL("PushToTalkToggle"); | 854 | mPTTIsToggle = gSavedSettings.getBOOL("PushToTalkToggle"); |
856 | mEarLocation = gSavedSettings.getS32("VoiceEarLocation"); | 855 | mEarLocation = gSavedSettings.getS32("VoiceEarLocation"); |
857 | setVoiceVolume(gSavedSettings.getF32("AudioLevelVoice")); | 856 | setVoiceVolume(gSavedSettings.getBOOL("MuteVoice") ? 0.f : gSavedSettings.getF32("AudioLevelVoice")); |
858 | std::string captureDevice = gSavedSettings.getString("VoiceInputAudioDevice"); | 857 | std::string captureDevice = gSavedSettings.getString("VoiceInputAudioDevice"); |
859 | setCaptureDevice(captureDevice); | 858 | setCaptureDevice(captureDevice); |
860 | std::string renderDevice = gSavedSettings.getString("VoiceOutputAudioDevice"); | 859 | std::string renderDevice = gSavedSettings.getString("VoiceOutputAudioDevice"); |
@@ -876,7 +875,6 @@ LLVoiceClient::LLVoiceClient() | |||
876 | mTuningMicVolumeDirty = true; | 875 | mTuningMicVolumeDirty = true; |
877 | mTuningSpeakerVolume = 0; | 876 | mTuningSpeakerVolume = 0; |
878 | mTuningSpeakerVolumeDirty = true; | 877 | mTuningSpeakerVolumeDirty = true; |
879 | mTuningCaptureRunning = false; | ||
880 | 878 | ||
881 | // gMuteListp isn't set up at this point, so we defer this until later. | 879 | // gMuteListp isn't set up at this point, so we defer this until later. |
882 | // gMuteListp->addObserver(&mutelist_listener); | 880 | // gMuteListp->addObserver(&mutelist_listener); |
@@ -1138,14 +1136,15 @@ const char *LLVoiceClient::state2string(LLVoiceClient::state inState) | |||
1138 | CASE(stateConnectorStart); | 1136 | CASE(stateConnectorStart); |
1139 | CASE(stateConnectorStarting); | 1137 | CASE(stateConnectorStarting); |
1140 | CASE(stateConnectorStarted); | 1138 | CASE(stateConnectorStarted); |
1141 | CASE(stateMicTuningNoLogin); | ||
1142 | CASE(stateLoginRetry); | 1139 | CASE(stateLoginRetry); |
1143 | CASE(stateLoginRetryWait); | 1140 | CASE(stateLoginRetryWait); |
1144 | CASE(stateNeedsLogin); | 1141 | CASE(stateNeedsLogin); |
1145 | CASE(stateLoggingIn); | 1142 | CASE(stateLoggingIn); |
1146 | CASE(stateLoggedIn); | 1143 | CASE(stateLoggedIn); |
1147 | CASE(stateNoChannel); | 1144 | CASE(stateNoChannel); |
1148 | CASE(stateMicTuningLoggedIn); | 1145 | CASE(stateMicTuningStart); |
1146 | CASE(stateMicTuningRunning); | ||
1147 | CASE(stateMicTuningStop); | ||
1149 | CASE(stateSessionCreate); | 1148 | CASE(stateSessionCreate); |
1150 | CASE(stateSessionConnect); | 1149 | CASE(stateSessionConnect); |
1151 | CASE(stateJoiningSession); | 1150 | CASE(stateJoiningSession); |
@@ -1164,6 +1163,7 @@ const char *LLVoiceClient::state2string(LLVoiceClient::state inState) | |||
1164 | CASE(stateJoinSessionFailed); | 1163 | CASE(stateJoinSessionFailed); |
1165 | CASE(stateJoinSessionFailedWaiting); | 1164 | CASE(stateJoinSessionFailedWaiting); |
1166 | CASE(stateJail); | 1165 | CASE(stateJail); |
1166 | CASE(stateMicTuningNoLogin); | ||
1167 | } | 1167 | } |
1168 | 1168 | ||
1169 | #undef CASE | 1169 | #undef CASE |
@@ -1483,7 +1483,8 @@ void LLVoiceClient::stateMachine() | |||
1483 | } | 1483 | } |
1484 | else if(mTuningMode) | 1484 | else if(mTuningMode) |
1485 | { | 1485 | { |
1486 | setState(stateMicTuningNoLogin); | 1486 | mTuningExitState = stateConnectorStart; |
1487 | setState(stateMicTuningStart); | ||
1487 | } | 1488 | } |
1488 | break; | 1489 | break; |
1489 | 1490 | ||
@@ -1515,24 +1516,63 @@ void LLVoiceClient::stateMachine() | |||
1515 | } | 1516 | } |
1516 | break; | 1517 | break; |
1517 | 1518 | ||
1518 | case stateMicTuningNoLogin: | 1519 | case stateMicTuningStart: |
1519 | case stateMicTuningLoggedIn: | 1520 | if(mUpdateTimer.hasExpired()) |
1520 | { | 1521 | { |
1521 | // Both of these behave essentially the same. The only difference is where the exit transition goes to. | 1522 | if(mCaptureDeviceDirty || mRenderDeviceDirty) |
1522 | if(mTuningMode && mVoiceEnabled && !mSessionTerminateRequested) | 1523 | { |
1523 | { | 1524 | // These can't be changed while in tuning mode. Set them before starting. |
1524 | if(!mTuningCaptureRunning) | 1525 | std::ostringstream stream; |
1526 | |||
1527 | if(mCaptureDeviceDirty) | ||
1528 | { | ||
1529 | buildSetCaptureDevice(stream); | ||
1530 | } | ||
1531 | |||
1532 | if(mRenderDeviceDirty) | ||
1533 | { | ||
1534 | buildSetRenderDevice(stream); | ||
1535 | } | ||
1536 | |||
1537 | mCaptureDeviceDirty = false; | ||
1538 | mRenderDeviceDirty = false; | ||
1539 | |||
1540 | if(!stream.str().empty()) | ||
1541 | { | ||
1542 | writeString(stream.str()); | ||
1543 | } | ||
1544 | |||
1545 | // This will come around again in the same state and start the capture, after the timer expires. | ||
1546 | mUpdateTimer.start(); | ||
1547 | mUpdateTimer.setTimerExpirySec(UPDATE_THROTTLE_SECONDS); | ||
1548 | } | ||
1549 | else | ||
1525 | { | 1550 | { |
1526 | // duration parameter is currently unused, per Mike S. | 1551 | // duration parameter is currently unused, per Mike S. |
1527 | tuningCaptureStartSendMessage(10000); | 1552 | tuningCaptureStartSendMessage(10000); |
1553 | |||
1554 | setState(stateMicTuningRunning); | ||
1528 | } | 1555 | } |
1529 | 1556 | } | |
1530 | if(mTuningMicVolumeDirty || mTuningSpeakerVolumeDirty || mCaptureDeviceDirty || mRenderDeviceDirty) | 1557 | |
1558 | break; | ||
1559 | |||
1560 | case stateMicTuningRunning: | ||
1561 | if(!mTuningMode || !mVoiceEnabled || mSessionTerminateRequested || mCaptureDeviceDirty || mRenderDeviceDirty) | ||
1562 | { | ||
1563 | // All of these conditions make us leave tuning mode. | ||
1564 | setState(stateMicTuningStop); | ||
1565 | } | ||
1566 | else | ||
1567 | { | ||
1568 | // process mic/speaker volume changes | ||
1569 | if(mTuningMicVolumeDirty || mTuningSpeakerVolumeDirty) | ||
1531 | { | 1570 | { |
1532 | std::ostringstream stream; | 1571 | std::ostringstream stream; |
1533 | 1572 | ||
1534 | if(mTuningMicVolumeDirty) | 1573 | if(mTuningMicVolumeDirty) |
1535 | { | 1574 | { |
1575 | llinfos << "setting tuning mic level to " << mTuningMicVolume << llendl; | ||
1536 | stream | 1576 | stream |
1537 | << "<Request requestId=\"" << mCommandCookie++ << "\" action=\"Aux.SetMicLevel.1\">" | 1577 | << "<Request requestId=\"" << mCommandCookie++ << "\" action=\"Aux.SetMicLevel.1\">" |
1538 | << "<Level>" << mTuningMicVolume << "</Level>" | 1578 | << "<Level>" << mTuningMicVolume << "</Level>" |
@@ -1547,20 +1587,8 @@ void LLVoiceClient::stateMachine() | |||
1547 | << "</Request>\n\n\n"; | 1587 | << "</Request>\n\n\n"; |
1548 | } | 1588 | } |
1549 | 1589 | ||
1550 | if(mCaptureDeviceDirty) | ||
1551 | { | ||
1552 | buildSetCaptureDevice(stream); | ||
1553 | } | ||
1554 | |||
1555 | if(mRenderDeviceDirty) | ||
1556 | { | ||
1557 | buildSetRenderDevice(stream); | ||
1558 | } | ||
1559 | |||
1560 | mTuningMicVolumeDirty = false; | 1590 | mTuningMicVolumeDirty = false; |
1561 | mTuningSpeakerVolumeDirty = false; | 1591 | mTuningSpeakerVolumeDirty = false; |
1562 | mCaptureDeviceDirty = false; | ||
1563 | mRenderDeviceDirty = false; | ||
1564 | 1592 | ||
1565 | if(!stream.str().empty()) | 1593 | if(!stream.str().empty()) |
1566 | { | 1594 | { |
@@ -1568,23 +1596,19 @@ void LLVoiceClient::stateMachine() | |||
1568 | } | 1596 | } |
1569 | } | 1597 | } |
1570 | } | 1598 | } |
1571 | else | 1599 | break; |
1572 | { | 1600 | |
1573 | // transition out of mic tuning | 1601 | case stateMicTuningStop: |
1574 | if(mTuningCaptureRunning) | 1602 | { |
1575 | { | 1603 | // transition out of mic tuning |
1576 | tuningCaptureStopSendMessage(); | 1604 | tuningCaptureStopSendMessage(); |
1577 | } | 1605 | |
1578 | 1606 | setState(mTuningExitState); | |
1579 | if(getState() == stateMicTuningNoLogin) | 1607 | |
1580 | { | 1608 | // if we exited just to change devices, this will keep us from re-entering too fast. |
1581 | setState(stateConnectorStart); | 1609 | mUpdateTimer.start(); |
1582 | } | 1610 | mUpdateTimer.setTimerExpirySec(UPDATE_THROTTLE_SECONDS); |
1583 | else | 1611 | |
1584 | { | ||
1585 | setState(stateNoChannel); | ||
1586 | } | ||
1587 | } | ||
1588 | } | 1612 | } |
1589 | break; | 1613 | break; |
1590 | 1614 | ||
@@ -1654,7 +1678,8 @@ void LLVoiceClient::stateMachine() | |||
1654 | } | 1678 | } |
1655 | else if(mTuningMode) | 1679 | else if(mTuningMode) |
1656 | { | 1680 | { |
1657 | setState(stateMicTuningLoggedIn); | 1681 | mTuningExitState = stateNoChannel; |
1682 | setState(stateMicTuningStart); | ||
1658 | } | 1683 | } |
1659 | else if(!mNextSessionHandle.empty()) | 1684 | else if(!mNextSessionHandle.empty()) |
1660 | { | 1685 | { |
@@ -1880,6 +1905,12 @@ void LLVoiceClient::stateMachine() | |||
1880 | case stateJail: | 1905 | case stateJail: |
1881 | // We have given up. Do nothing. | 1906 | // We have given up. Do nothing. |
1882 | break; | 1907 | break; |
1908 | |||
1909 | case stateMicTuningNoLogin: | ||
1910 | // *TODO: Implement me. | ||
1911 | llwarns << "stateMicTuningNoLogin not handled" | ||
1912 | << llendl; | ||
1913 | break; | ||
1883 | } | 1914 | } |
1884 | 1915 | ||
1885 | if(mParticipantMapChanged) | 1916 | if(mParticipantMapChanged) |
@@ -2183,9 +2214,9 @@ bool LLVoiceClient::inTuningMode() | |||
2183 | bool result = false; | 2214 | bool result = false; |
2184 | switch(getState()) | 2215 | switch(getState()) |
2185 | { | 2216 | { |
2186 | case stateMicTuningNoLogin: | 2217 | case stateMicTuningRunning: |
2187 | case stateMicTuningLoggedIn: | ||
2188 | result = true; | 2218 | result = true; |
2219 | break; | ||
2189 | default: | 2220 | default: |
2190 | break; | 2221 | break; |
2191 | } | 2222 | } |
@@ -2193,10 +2224,7 @@ bool LLVoiceClient::inTuningMode() | |||
2193 | } | 2224 | } |
2194 | 2225 | ||
2195 | void LLVoiceClient::tuningRenderStartSendMessage(const std::string& name, bool loop) | 2226 | void LLVoiceClient::tuningRenderStartSendMessage(const std::string& name, bool loop) |
2196 | { | 2227 | { |
2197 | if(!inTuningMode()) | ||
2198 | return; | ||
2199 | |||
2200 | mTuningAudioFile = name; | 2228 | mTuningAudioFile = name; |
2201 | std::ostringstream stream; | 2229 | std::ostringstream stream; |
2202 | stream | 2230 | stream |
@@ -2210,9 +2238,6 @@ void LLVoiceClient::tuningRenderStartSendMessage(const std::string& name, bool l | |||
2210 | 2238 | ||
2211 | void LLVoiceClient::tuningRenderStopSendMessage() | 2239 | void LLVoiceClient::tuningRenderStopSendMessage() |
2212 | { | 2240 | { |
2213 | if(!inTuningMode()) | ||
2214 | return; | ||
2215 | |||
2216 | std::ostringstream stream; | 2241 | std::ostringstream stream; |
2217 | stream | 2242 | stream |
2218 | << "<Request requestId=\"" << mCommandCookie++ << "\" action=\"Aux.RenderAudioStop.1\">" | 2243 | << "<Request requestId=\"" << mCommandCookie++ << "\" action=\"Aux.RenderAudioStop.1\">" |
@@ -2224,9 +2249,8 @@ void LLVoiceClient::tuningRenderStopSendMessage() | |||
2224 | 2249 | ||
2225 | void LLVoiceClient::tuningCaptureStartSendMessage(int duration) | 2250 | void LLVoiceClient::tuningCaptureStartSendMessage(int duration) |
2226 | { | 2251 | { |
2227 | if(!inTuningMode()) | 2252 | llinfos << "sending CaptureAudioStart" << llendl; |
2228 | return; | 2253 | |
2229 | |||
2230 | std::ostringstream stream; | 2254 | std::ostringstream stream; |
2231 | stream | 2255 | stream |
2232 | << "<Request requestId=\"" << mCommandCookie++ << "\" action=\"Aux.CaptureAudioStart.1\">" | 2256 | << "<Request requestId=\"" << mCommandCookie++ << "\" action=\"Aux.CaptureAudioStart.1\">" |
@@ -2234,15 +2258,12 @@ void LLVoiceClient::tuningCaptureStartSendMessage(int duration) | |||
2234 | << "</Request>\n\n\n"; | 2258 | << "</Request>\n\n\n"; |
2235 | 2259 | ||
2236 | writeString(stream.str()); | 2260 | writeString(stream.str()); |
2237 | |||
2238 | mTuningCaptureRunning = true; | ||
2239 | } | 2261 | } |
2240 | 2262 | ||
2241 | void LLVoiceClient::tuningCaptureStopSendMessage() | 2263 | void LLVoiceClient::tuningCaptureStopSendMessage() |
2242 | { | 2264 | { |
2243 | if(!inTuningMode()) | 2265 | llinfos << "sending CaptureAudioStop" << llendl; |
2244 | return; | 2266 | |
2245 | |||
2246 | std::ostringstream stream; | 2267 | std::ostringstream stream; |
2247 | stream | 2268 | stream |
2248 | << "<Request requestId=\"" << mCommandCookie++ << "\" action=\"Aux.CaptureAudioStop.1\">" | 2269 | << "<Request requestId=\"" << mCommandCookie++ << "\" action=\"Aux.CaptureAudioStop.1\">" |
@@ -2250,7 +2271,7 @@ void LLVoiceClient::tuningCaptureStopSendMessage() | |||
2250 | 2271 | ||
2251 | writeString(stream.str()); | 2272 | writeString(stream.str()); |
2252 | 2273 | ||
2253 | mTuningCaptureRunning = false; | 2274 | mTuningEnergy = 0.0f; |
2254 | } | 2275 | } |
2255 | 2276 | ||
2256 | void LLVoiceClient::tuningSetMicVolume(float volume) | 2277 | void LLVoiceClient::tuningSetMicVolume(float volume) |
@@ -2914,12 +2935,16 @@ void LLVoiceClient::sessionNewEvent( | |||
2914 | LLUUID caller_id; | 2935 | LLUUID caller_id; |
2915 | if(IDFromName(nameString, caller_id)) | 2936 | if(IDFromName(nameString, caller_id)) |
2916 | { | 2937 | { |
2917 | gIMMgr->inviteToSession(LLIMMgr::computeSessionID(IM_SESSION_P2P_INVITE, caller_id), | 2938 | gIMMgr->inviteToSession( |
2918 | LLString::null, | 2939 | LLIMMgr::computeSessionID( |
2919 | caller_id, | 2940 | IM_SESSION_P2P_INVITE, |
2920 | LLString::null, | 2941 | caller_id), |
2921 | IM_SESSION_P2P_INVITE, | 2942 | LLString::null, |
2922 | eventSessionHandle); | 2943 | caller_id, |
2944 | LLString::null, | ||
2945 | IM_SESSION_P2P_INVITE, | ||
2946 | LLIMMgr::INVITATION_TYPE_VOICE, | ||
2947 | eventSessionHandle); | ||
2923 | } | 2948 | } |
2924 | else | 2949 | else |
2925 | { | 2950 | { |
@@ -2985,6 +3010,7 @@ void LLVoiceClient::participantPropertiesEvent( | |||
2985 | { | 3010 | { |
2986 | participant->mPTT = !isLocallyMuted; | 3011 | participant->mPTT = !isLocallyMuted; |
2987 | participant->mIsSpeaking = isSpeaking; | 3012 | participant->mIsSpeaking = isSpeaking; |
3013 | participant->mIsModeratorMuted = isModeratorMuted; | ||
2988 | if (isSpeaking) | 3014 | if (isSpeaking) |
2989 | { | 3015 | { |
2990 | participant->mSpeakingTimeout.reset(); | 3016 | participant->mSpeakingTimeout.reset(); |
@@ -3022,7 +3048,7 @@ void LLVoiceClient::muteListChanged() | |||
3022 | ///////////////////////////// | 3048 | ///////////////////////////// |
3023 | // Managing list of participants | 3049 | // Managing list of participants |
3024 | LLVoiceClient::participantState::participantState(const std::string &uri) : | 3050 | LLVoiceClient::participantState::participantState(const std::string &uri) : |
3025 | mURI(uri), mPTT(false), mIsSpeaking(false), mPower(0.0), mServiceType(serviceTypeUnknown), | 3051 | mURI(uri), mPTT(false), mIsSpeaking(false), mIsModeratorMuted(false), mPower(0.0), mServiceType(serviceTypeUnknown), |
3026 | mOnMuteList(false), mUserVolume(100), mVolumeDirty(false), mAvatarIDValid(false) | 3052 | mOnMuteList(false), mUserVolume(100), mVolumeDirty(false), mAvatarIDValid(false) |
3027 | { | 3053 | { |
3028 | } | 3054 | } |
@@ -3204,7 +3230,6 @@ void LLVoiceClient::parcelChanged() | |||
3204 | 3230 | ||
3205 | std::string url = gAgent.getRegion()->getCapability("ParcelVoiceInfoRequest"); | 3231 | std::string url = gAgent.getRegion()->getCapability("ParcelVoiceInfoRequest"); |
3206 | LLSD data; | 3232 | LLSD data; |
3207 | data["method"] = "call"; | ||
3208 | LLHTTPClient::post( | 3233 | LLHTTPClient::post( |
3209 | url, | 3234 | url, |
3210 | data, | 3235 | data, |
@@ -3265,6 +3290,7 @@ void LLVoiceClient::switchChannel( | |||
3265 | { | 3290 | { |
3266 | // Leave any channel we may be in | 3291 | // Leave any channel we may be in |
3267 | llinfos << "leaving channel" << llendl; | 3292 | llinfos << "leaving channel" << llendl; |
3293 | notifyStatusObservers(LLVoiceClientStatusObserver::STATUS_VOICE_DISABLED); | ||
3268 | } | 3294 | } |
3269 | else | 3295 | else |
3270 | { | 3296 | { |
@@ -3786,6 +3812,19 @@ BOOL LLVoiceClient::getIsSpeaking(const LLUUID& id) | |||
3786 | return result; | 3812 | return result; |
3787 | } | 3813 | } |
3788 | 3814 | ||
3815 | BOOL LLVoiceClient::getIsModeratorMuted(const LLUUID& id) | ||
3816 | { | ||
3817 | BOOL result = FALSE; | ||
3818 | |||
3819 | participantState *participant = findParticipantByID(id); | ||
3820 | if(participant) | ||
3821 | { | ||
3822 | result = participant->mIsModeratorMuted; | ||
3823 | } | ||
3824 | |||
3825 | return result; | ||
3826 | } | ||
3827 | |||
3789 | F32 LLVoiceClient::getCurrentPower(const LLUUID& id) | 3828 | F32 LLVoiceClient::getCurrentPower(const LLUUID& id) |
3790 | { | 3829 | { |
3791 | F32 result = 0; | 3830 | F32 result = 0; |
@@ -3956,7 +3995,14 @@ void LLVoiceClient::notifyStatusObservers(LLVoiceClientStatusObserver::EStatusTy | |||
3956 | { | 3995 | { |
3957 | case 20713: status = LLVoiceClientStatusObserver::ERROR_CHANNEL_FULL; break; | 3996 | case 20713: status = LLVoiceClientStatusObserver::ERROR_CHANNEL_FULL; break; |
3958 | case 20714: status = LLVoiceClientStatusObserver::ERROR_CHANNEL_LOCKED; break; | 3997 | case 20714: status = LLVoiceClientStatusObserver::ERROR_CHANNEL_LOCKED; break; |
3959 | case 20715: status = LLVoiceClientStatusObserver::ERROR_NOT_AVAILABLE; | 3998 | case 20715: |
3999 | //invalid channel, we may be using a set of poorly cached | ||
4000 | //info | ||
4001 | status = LLVoiceClientStatusObserver::ERROR_NOT_AVAILABLE; | ||
4002 | break; | ||
4003 | case 1009: | ||
4004 | //invalid username and password | ||
4005 | status = LLVoiceClientStatusObserver::ERROR_NOT_AVAILABLE; | ||
3960 | break; | 4006 | break; |
3961 | } | 4007 | } |
3962 | 4008 | ||