aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llimpanel.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2008-09-06 18:24:57 -0500
committerJacek Antonelli2008-09-06 18:25:07 -0500
commit798d367d54a6c6379ad355bd8345fa40e31e7fe9 (patch)
tree1921f1708cd0240648c97bc02df2c2ab5f2fc41e /linden/indra/newview/llimpanel.cpp
parentSecond Life viewer sources 1.20.15 (diff)
downloadmeta-impy-798d367d54a6c6379ad355bd8345fa40e31e7fe9.zip
meta-impy-798d367d54a6c6379ad355bd8345fa40e31e7fe9.tar.gz
meta-impy-798d367d54a6c6379ad355bd8345fa40e31e7fe9.tar.bz2
meta-impy-798d367d54a6c6379ad355bd8345fa40e31e7fe9.tar.xz
Second Life viewer sources 1.21.0-RC
Diffstat (limited to 'linden/indra/newview/llimpanel.cpp')
-rw-r--r--linden/indra/newview/llimpanel.cpp235
1 files changed, 139 insertions, 96 deletions
diff --git a/linden/indra/newview/llimpanel.cpp b/linden/indra/newview/llimpanel.cpp
index ae8bd4b..c2b54f3 100644
--- a/linden/indra/newview/llimpanel.cpp
+++ b/linden/indra/newview/llimpanel.cpp
@@ -86,9 +86,9 @@ const U32 DEFAULT_RETRIES_COUNT = 3;
86// Statics 86// Statics
87// 87//
88// 88//
89static LLString sTitleString = "Instant Message with [NAME]"; 89static std::string sTitleString = "Instant Message with [NAME]";
90static LLString sTypingStartString = "[NAME]: ..."; 90static std::string sTypingStartString = "[NAME]: ...";
91static LLString sSessionStartString = "Starting session with [NAME] please wait."; 91static std::string sSessionStartString = "Starting session with [NAME] please wait.";
92 92
93LLVoiceChannel::voice_channel_map_t LLVoiceChannel::sVoiceChannelMap; 93LLVoiceChannel::voice_channel_map_t LLVoiceChannel::sVoiceChannelMap;
94LLVoiceChannel::voice_channel_map_uri_t LLVoiceChannel::sVoiceChannelURIMap; 94LLVoiceChannel::voice_channel_map_uri_t LLVoiceChannel::sVoiceChannelURIMap;
@@ -121,7 +121,7 @@ void session_starter_helper(
121 gAgent.buildFullname(name); 121 gAgent.buildFullname(name);
122 122
123 msg->addStringFast(_PREHASH_FromAgentName, name); 123 msg->addStringFast(_PREHASH_FromAgentName, name);
124 msg->addStringFast(_PREHASH_Message, LLString::null); 124 msg->addStringFast(_PREHASH_Message, LLStringUtil::null);
125 msg->addU32Fast(_PREHASH_ParentEstateID, 0); 125 msg->addU32Fast(_PREHASH_ParentEstateID, 0);
126 msg->addUUIDFast(_PREHASH_RegionID, LLUUID::null); 126 msg->addUUIDFast(_PREHASH_RegionID, LLUUID::null);
127 msg->addVector3Fast(_PREHASH_Position, gAgent.getPositionAgent()); 127 msg->addVector3Fast(_PREHASH_Position, gAgent.getPositionAgent());
@@ -342,7 +342,7 @@ void LLVoiceCallCapResponder::result(const LLSD& content)
342// 342//
343// LLVoiceChannel 343// LLVoiceChannel
344// 344//
345LLVoiceChannel::LLVoiceChannel(const LLUUID& session_id, const LLString& session_name) : 345LLVoiceChannel::LLVoiceChannel(const LLUUID& session_id, const std::string& session_name) :
346 mSessionID(session_id), 346 mSessionID(session_id),
347 mState(STATE_NO_CHANNEL_INFO), 347 mState(STATE_NO_CHANNEL_INFO),
348 mSessionName(session_name), 348 mSessionName(session_name),
@@ -373,8 +373,8 @@ LLVoiceChannel::~LLVoiceChannel()
373} 373}
374 374
375void LLVoiceChannel::setChannelInfo( 375void LLVoiceChannel::setChannelInfo(
376 const LLString& uri, 376 const std::string& uri,
377 const LLString& credentials) 377 const std::string& credentials)
378{ 378{
379 setURI(uri); 379 setURI(uri);
380 380
@@ -563,7 +563,7 @@ LLVoiceChannel* LLVoiceChannel::getChannelByID(const LLUUID& session_id)
563} 563}
564 564
565//static 565//static
566LLVoiceChannel* LLVoiceChannel::getChannelByURI(LLString uri) 566LLVoiceChannel* LLVoiceChannel::getChannelByURI(std::string uri)
567{ 567{
568 voice_channel_map_uri_t::iterator found_it = sVoiceChannelURIMap.find(uri); 568 voice_channel_map_uri_t::iterator found_it = sVoiceChannelURIMap.find(uri);
569 if (found_it == sVoiceChannelURIMap.end()) 569 if (found_it == sVoiceChannelURIMap.end())
@@ -584,7 +584,7 @@ void LLVoiceChannel::updateSessionID(const LLUUID& new_session_id)
584 sVoiceChannelMap.insert(std::make_pair(mSessionID, this)); 584 sVoiceChannelMap.insert(std::make_pair(mSessionID, this));
585} 585}
586 586
587void LLVoiceChannel::setURI(LLString uri) 587void LLVoiceChannel::setURI(std::string uri)
588{ 588{
589 sVoiceChannelURIMap.erase(mURI); 589 sVoiceChannelURIMap.erase(mURI);
590 mURI = uri; 590 mURI = uri;
@@ -654,7 +654,7 @@ void LLVoiceChannel::resume()
654// LLVoiceChannelGroup 654// LLVoiceChannelGroup
655// 655//
656 656
657LLVoiceChannelGroup::LLVoiceChannelGroup(const LLUUID& session_id, const LLString& session_name) : 657LLVoiceChannelGroup::LLVoiceChannelGroup(const LLUUID& session_id, const std::string& session_name) :
658 LLVoiceChannel(session_id, session_name) 658 LLVoiceChannel(session_id, session_name)
659{ 659{
660 mRetries = DEFAULT_RETRIES_COUNT; 660 mRetries = DEFAULT_RETRIES_COUNT;
@@ -701,8 +701,8 @@ void LLVoiceChannelGroup::getChannelInfo()
701} 701}
702 702
703void LLVoiceChannelGroup::setChannelInfo( 703void LLVoiceChannelGroup::setChannelInfo(
704 const LLString& uri, 704 const std::string& uri,
705 const LLString& credentials) 705 const std::string& credentials)
706{ 706{
707 setURI(uri); 707 setURI(uri);
708 708
@@ -795,7 +795,7 @@ void LLVoiceChannelGroup::handleError(EStatusType status)
795 { 795 {
796 LLNotifyBox::showXml(notify, mNotifyArgs); 796 LLNotifyBox::showXml(notify, mNotifyArgs);
797 // echo to im window 797 // echo to im window
798 gIMMgr->addMessage(mSessionID, LLUUID::null, SYSTEM_FROM, LLNotifyBox::getTemplateMessage(notify, mNotifyArgs).c_str()); 798 gIMMgr->addMessage(mSessionID, LLUUID::null, SYSTEM_FROM, LLNotifyBox::getTemplateMessage(notify, mNotifyArgs));
799 } 799 }
800 800
801 LLVoiceChannel::handleError(status); 801 LLVoiceChannel::handleError(status);
@@ -822,7 +822,7 @@ void LLVoiceChannelGroup::setState(EState state)
822// LLVoiceChannelProximal 822// LLVoiceChannelProximal
823// 823//
824LLVoiceChannelProximal::LLVoiceChannelProximal() : 824LLVoiceChannelProximal::LLVoiceChannelProximal() :
825 LLVoiceChannel(LLUUID::null, LLString::null) 825 LLVoiceChannel(LLUUID::null, LLStringUtil::null)
826{ 826{
827 activate(); 827 activate();
828} 828}
@@ -914,7 +914,7 @@ void LLVoiceChannelProximal::deactivate()
914// 914//
915// LLVoiceChannelP2P 915// LLVoiceChannelP2P
916// 916//
917LLVoiceChannelP2P::LLVoiceChannelP2P(const LLUUID& session_id, const LLString& session_name, const LLUUID& other_user_id) : 917LLVoiceChannelP2P::LLVoiceChannelP2P(const LLUUID& session_id, const std::string& session_name, const LLUUID& other_user_id) :
918 LLVoiceChannelGroup(session_id, session_name), 918 LLVoiceChannelGroup(session_id, session_name),
919 mOtherUserID(other_user_id), 919 mOtherUserID(other_user_id),
920 mReceivedCall(FALSE) 920 mReceivedCall(FALSE)
@@ -1000,7 +1000,7 @@ void LLVoiceChannelP2P::getChannelInfo()
1000} 1000}
1001 1001
1002// receiving session from other user who initiated call 1002// receiving session from other user who initiated call
1003void LLVoiceChannelP2P::setSessionHandle(const LLString& handle) 1003void LLVoiceChannelP2P::setSessionHandle(const std::string& handle)
1004{ 1004{
1005 BOOL needs_activate = FALSE; 1005 BOOL needs_activate = FALSE;
1006 if (callStarted()) 1006 if (callStarted())
@@ -1109,11 +1109,11 @@ LLFloaterIMPanel::LLFloaterIMPanel(
1109} 1109}
1110 1110
1111 1111
1112void LLFloaterIMPanel::init(const LLString& session_label) 1112void LLFloaterIMPanel::init(const std::string& session_label)
1113{ 1113{
1114 mSessionLabel = session_label; 1114 mSessionLabel = session_label;
1115 1115
1116 LLString xml_filename; 1116 std::string xml_filename;
1117 switch(mDialog) 1117 switch(mDialog)
1118 { 1118 {
1119 case IM_SESSION_GROUP_START: 1119 case IM_SESSION_GROUP_START:
@@ -1238,6 +1238,7 @@ BOOL LLFloaterIMPanel::postBuild()
1238 mInputEditor->setCallbackUserData(this); 1238 mInputEditor->setCallbackUserData(this);
1239 mInputEditor->setCommitOnFocusLost( FALSE ); 1239 mInputEditor->setCommitOnFocusLost( FALSE );
1240 mInputEditor->setRevertOnEsc( FALSE ); 1240 mInputEditor->setRevertOnEsc( FALSE );
1241 mInputEditor->setReplaceNewlinesWithSpaces( FALSE );
1241 1242
1242 childSetAction("profile_callee_btn", onClickProfile, this); 1243 childSetAction("profile_callee_btn", onClickProfile, this);
1243 childSetAction("group_info_btn", onClickGroupInfo, this); 1244 childSetAction("group_info_btn", onClickGroupInfo, this);
@@ -1460,7 +1461,7 @@ BOOL LLFloaterIMPanel::inviteToSession(const LLDynamicArray<LLUUID>& ids)
1460 return TRUE; 1461 return TRUE;
1461} 1462}
1462 1463
1463void LLFloaterIMPanel::addHistoryLine(const std::string &utf8msg, const LLColor4& color, bool log_to_file, const LLUUID& source, const char *name) 1464void LLFloaterIMPanel::addHistoryLine(const std::string &utf8msg, const LLColor4& color, bool log_to_file, const LLUUID& source, const std::string& name)
1464{ 1465{
1465 // start tab flashing when receiving im for background session from user 1466 // start tab flashing when receiving im for background session from user
1466 if (source != LLUUID::null) 1467 if (source != LLUUID::null)
@@ -1480,7 +1481,7 @@ void LLFloaterIMPanel::addHistoryLine(const std::string &utf8msg, const LLColor4
1480 removeTypingIndicator(NULL); 1481 removeTypingIndicator(NULL);
1481 1482
1482 // Actually add the line 1483 // Actually add the line
1483 LLString timestring; 1484 std::string timestring;
1484 bool prepend_newline = true; 1485 bool prepend_newline = true;
1485 if (gSavedSettings.getBOOL("IMShowTimestamps")) 1486 if (gSavedSettings.getBOOL("IMShowTimestamps"))
1486 { 1487 {
@@ -1489,10 +1490,10 @@ void LLFloaterIMPanel::addHistoryLine(const std::string &utf8msg, const LLColor4
1489 } 1490 }
1490 1491
1491 // 'name' is a sender name that we want to hotlink so that clicking on it opens a profile. 1492 // 'name' is a sender name that we want to hotlink so that clicking on it opens a profile.
1492 if (name != NULL) // If name exists, then add it to the front of the message. 1493 if (!name.empty()) // If name exists, then add it to the front of the message.
1493 { 1494 {
1494 // Don't hotlink any messages from the system (e.g. "Second Life:"), so just add those in plain text. 1495 // Don't hotlink any messages from the system (e.g. "Second Life:"), so just add those in plain text.
1495 if (!strcmp(name,SYSTEM_FROM)) 1496 if (name == SYSTEM_FROM)
1496 { 1497 {
1497 mHistoryEditor->appendColoredText(name,false,prepend_newline,color); 1498 mHistoryEditor->appendColoredText(name,false,prepend_newline,color);
1498 } 1499 }
@@ -1509,11 +1510,11 @@ void LLFloaterIMPanel::addHistoryLine(const std::string &utf8msg, const LLColor4
1509 if (log_to_file 1510 if (log_to_file
1510 && gSavedPerAccountSettings.getBOOL("LogInstantMessages") ) 1511 && gSavedPerAccountSettings.getBOOL("LogInstantMessages") )
1511 { 1512 {
1512 LLString histstr; 1513 std::string histstr;
1513 if (gSavedPerAccountSettings.getBOOL("IMLogTimestamp")) 1514 if (gSavedPerAccountSettings.getBOOL("IMLogTimestamp"))
1514 histstr = LLLogChat::timestamp(gSavedPerAccountSettings.getBOOL("LogTimestampDate")) + LLString(name) + utf8msg; 1515 histstr = LLLogChat::timestamp(gSavedPerAccountSettings.getBOOL("LogTimestampDate")) + name + utf8msg;
1515 else 1516 else
1516 histstr = LLString(name) + utf8msg; 1517 histstr = name + utf8msg;
1517 1518
1518 LLLogChat::saveHistory(getTitle(),histstr); 1519 LLLogChat::saveHistory(getTitle(),histstr);
1519 } 1520 }
@@ -1603,17 +1604,54 @@ BOOL LLFloaterIMPanel::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop,
1603 EDragAndDropType cargo_type, 1604 EDragAndDropType cargo_type,
1604 void* cargo_data, 1605 void* cargo_data,
1605 EAcceptance* accept, 1606 EAcceptance* accept,
1606 LLString& tooltip_msg) 1607 std::string& tooltip_msg)
1607{ 1608{
1608 BOOL accepted = FALSE; 1609 BOOL accepted = FALSE;
1609 switch(cargo_type) 1610 switch(cargo_type)
1610 { 1611 {
1611 case DAD_CALLINGCARD: 1612 case DAD_CALLINGCARD:
1612 accepted = dropCallingCard((LLInventoryItem*)cargo_data, drop); 1613 {
1613 break; 1614 accepted = dropCallingCard((LLInventoryItem*)cargo_data, drop);
1614 case DAD_CATEGORY: 1615 break;
1615 accepted = dropCategory((LLInventoryCategory*)cargo_data, drop); 1616 }
1616 break; 1617 case DAD_CATEGORY:
1618 {
1619 accepted = dropCategory((LLInventoryCategory*)cargo_data, drop);
1620 break;
1621 }
1622
1623 // See stdenums.h
1624 case DAD_TEXTURE:
1625 case DAD_SOUND:
1626 // DAD_CALLINGCARD above
1627 case DAD_LANDMARK:
1628 case DAD_SCRIPT:
1629 case DAD_CLOTHING:
1630 case DAD_OBJECT:
1631 case DAD_NOTECARD:
1632 // DAD_CATEGORY above
1633 case DAD_BODYPART:
1634 case DAD_ANIMATION:
1635 case DAD_GESTURE:
1636 {
1637 if (mDialog == IM_NOTHING_SPECIAL)
1638 {
1639 // See LLDropTarget for similar code.
1640 LLViewerInventoryItem* inv_item = (LLViewerInventoryItem*)cargo_data;
1641 if(gInventory.getItem(inv_item->getUUID())
1642 && LLToolDragAndDrop::isInventoryGiveAcceptable(inv_item))
1643 {
1644 accepted = true;
1645 if(drop)
1646 {
1647 LLToolDragAndDrop::giveInventory(mOtherParticipantUUID, inv_item);
1648 LLStringUtil::format_map_t args;
1649 gIMMgr->addSystemMessage(mSessionUUID, "inventory_item_offered", args);
1650 }
1651 }
1652 }
1653 break;
1654 }
1617 default: 1655 default:
1618 break; 1656 break;
1619 } 1657 }
@@ -1782,7 +1820,7 @@ void LLFloaterIMPanel::onInputEditorFocusLost(LLFocusableElement* caller, void*
1782void LLFloaterIMPanel::onInputEditorKeystroke(LLLineEditor* caller, void* userdata) 1820void LLFloaterIMPanel::onInputEditorKeystroke(LLLineEditor* caller, void* userdata)
1783{ 1821{
1784 LLFloaterIMPanel* self = (LLFloaterIMPanel*)userdata; 1822 LLFloaterIMPanel* self = (LLFloaterIMPanel*)userdata;
1785 LLString text = self->mInputEditor->getText(); 1823 std::string text = self->mInputEditor->getText();
1786 if (!text.empty()) 1824 if (!text.empty())
1787 { 1825 {
1788 self->setTyping(TRUE); 1826 self->setTyping(TRUE);
@@ -1808,8 +1846,8 @@ void LLFloaterIMPanel::onClose(bool app_quitting)
1808 FALSE, 1846 FALSE,
1809 gAgent.getSessionID(), 1847 gAgent.getSessionID(),
1810 mOtherParticipantUUID, 1848 mOtherParticipantUUID,
1811 name.c_str(), 1849 name,
1812 "", 1850 LLStringUtil::null,
1813 IM_ONLINE, 1851 IM_ONLINE,
1814 IM_SESSION_LEAVE, 1852 IM_SESSION_LEAVE,
1815 mSessionUUID); 1853 mSessionUUID);
@@ -1855,8 +1893,8 @@ void deliver_message(const std::string& utf8_text,
1855 FALSE, 1893 FALSE,
1856 gAgent.getSessionID(), 1894 gAgent.getSessionID(),
1857 other_participant_id, 1895 other_participant_id,
1858 name.c_str(), 1896 name,
1859 utf8_text.c_str(), 1897 utf8_text,
1860 offline, 1898 offline,
1861 (EInstantMessage)new_dialog, 1899 (EInstantMessage)new_dialog,
1862 im_session_id); 1900 im_session_id);
@@ -1888,8 +1926,6 @@ void deliver_message(const std::string& utf8_text,
1888 1926
1889void LLFloaterIMPanel::sendMsg() 1927void LLFloaterIMPanel::sendMsg()
1890{ 1928{
1891 LLWString text = mInputEditor->getWText();
1892 LLWString::trim(text);
1893 if (!gAgent.isGodlike() 1929 if (!gAgent.isGodlike()
1894 && (mDialog == IM_NOTHING_SPECIAL) 1930 && (mDialog == IM_NOTHING_SPECIAL)
1895 && mOtherParticipantUUID.isNull()) 1931 && mOtherParticipantUUID.isNull())
@@ -1897,64 +1933,65 @@ void LLFloaterIMPanel::sendMsg()
1897 llinfos << "Cannot send IM to everyone unless you're a god." << llendl; 1933 llinfos << "Cannot send IM to everyone unless you're a god." << llendl;
1898 return; 1934 return;
1899 } 1935 }
1900 if(text.length() > 0)
1901 {
1902 // Truncate and convert to UTF8 for transport
1903 std::string utf8_text = wstring_to_utf8str(text);
1904 utf8_text = utf8str_truncate(utf8_text, MAX_MSG_BUF_SIZE - 1);
1905 1936
1906 if ( mSessionInitialized ) 1937 if (mInputEditor)
1938 {
1939 LLWString text = mInputEditor->getConvertedText();
1940 if(!text.empty())
1907 { 1941 {
1908 deliver_message(utf8_text, 1942 // Truncate and convert to UTF8 for transport
1909 mSessionUUID, 1943 std::string utf8_text = wstring_to_utf8str(text);
1910 mOtherParticipantUUID, 1944 utf8_text = utf8str_truncate(utf8_text, MAX_MSG_BUF_SIZE - 1);
1911 mDialog); 1945
1912 1946 if ( mSessionInitialized )
1913 // local echo
1914 if((mDialog == IM_NOTHING_SPECIAL) &&
1915 (mOtherParticipantUUID.notNull()))
1916 { 1947 {
1917 std::string history_echo; 1948 deliver_message(utf8_text,
1918 gAgent.buildFullname(history_echo); 1949 mSessionUUID,
1919 1950 mOtherParticipantUUID,
1920 // Look for IRC-style emotes here. 1951 mDialog);
1921 char tmpstr[5]; /* Flawfinder: ignore */ 1952
1922 strncpy(tmpstr, 1953 // local echo
1923 utf8_text.substr(0,4).c_str(), 1954 if((mDialog == IM_NOTHING_SPECIAL) &&
1924 sizeof(tmpstr) -1); /* Flawfinder: ignore */ 1955 (mOtherParticipantUUID.notNull()))
1925 tmpstr[sizeof(tmpstr) -1] = '\0';
1926 if (!strncmp(tmpstr, "/me ", 4) ||
1927 !strncmp(tmpstr, "/me'", 4))
1928 { 1956 {
1929 utf8_text.replace(0,3,""); 1957 std::string history_echo;
1930 } 1958 gAgent.buildFullname(history_echo);
1931 else 1959
1932 { 1960 // Look for IRC-style emotes here.
1933 history_echo += ": "; 1961 std::string prefix = utf8_text.substr(0, 4);
1934 } 1962 if (prefix == "/me " || prefix == "/me'")
1935 history_echo += utf8_text; 1963 {
1936 1964 utf8_text.replace(0,3,"");
1937 BOOL other_was_typing = mOtherTyping; 1965 }
1966 else
1967 {
1968 history_echo += ": ";
1969 }
1970 history_echo += utf8_text;
1971
1972 BOOL other_was_typing = mOtherTyping;
1973
1974 addHistoryLine(history_echo, gSavedSettings.getColor("IMChatColor"), true, gAgent.getID());
1975
1976 if (other_was_typing)
1977 {
1978 addTypingIndicator(mOtherTypingName);
1979 }
1938 1980
1939 addHistoryLine(history_echo, gSavedSettings.getColor("IMChatColor"), true, gAgent.getID());
1940
1941 if (other_was_typing)
1942 {
1943 addTypingIndicator(mOtherTypingName);
1944 } 1981 }
1945
1946 } 1982 }
1947 } 1983 else
1948 else 1984 {
1949 { 1985 //queue up the message to send once the session is
1950 //queue up the message to send once the session is 1986 //initialized
1951 //initialized 1987 mQueuedMsgsForInit.append(utf8_text);
1952 mQueuedMsgsForInit.append(utf8_text); 1988 }
1953 } 1989 }
1954 1990
1955 LLViewerStats::getInstance()->incStat(LLViewerStats::ST_IM_COUNT); 1991 LLViewerStats::getInstance()->incStat(LLViewerStats::ST_IM_COUNT);
1992
1956 } 1993 }
1957 mInputEditor->setText(LLString::null); 1994 mInputEditor->setText(LLStringUtil::null);
1958 1995
1959 // Don't need to actually send the typing stop message, the other 1996 // Don't need to actually send the typing stop message, the other
1960 // client will infer it from receiving the message. 1997 // client will infer it from receiving the message.
@@ -1977,7 +2014,7 @@ void LLFloaterIMPanel::processSessionUpdate(const LLSD& session_update)
1977 2014
1978 if (voice_moderated) 2015 if (voice_moderated)
1979 { 2016 {
1980 setTitle(mSessionLabel + LLString(" ") + getString("moderated_chat_label")); 2017 setTitle(mSessionLabel + std::string(" ") + getString("moderated_chat_label"));
1981 } 2018 }
1982 else 2019 else
1983 { 2020 {
@@ -2074,8 +2111,8 @@ void LLFloaterIMPanel::sendTypingState(BOOL typing)
2074 FALSE, 2111 FALSE,
2075 gAgent.getSessionID(), 2112 gAgent.getSessionID(),
2076 mOtherParticipantUUID, 2113 mOtherParticipantUUID,
2077 name.c_str(), 2114 name,
2078 "typing", 2115 std::string("typing"),
2079 IM_ONLINE, 2116 IM_ONLINE,
2080 (typing ? IM_TYPING_START : IM_TYPING_STOP), 2117 (typing ? IM_TYPING_START : IM_TYPING_STOP),
2081 mSessionUUID); 2118 mSessionUUID);
@@ -2132,7 +2169,7 @@ void LLFloaterIMPanel::removeTypingIndicator(const LLIMInfo* im_info)
2132} 2169}
2133 2170
2134//static 2171//static
2135void LLFloaterIMPanel::chatFromLogFile(LLLogChat::ELogLineType type, LLString line, void* userdata) 2172void LLFloaterIMPanel::chatFromLogFile(LLLogChat::ELogLineType type, std::string line, void* userdata)
2136{ 2173{
2137 LLFloaterIMPanel* self = (LLFloaterIMPanel*)userdata; 2174 LLFloaterIMPanel* self = (LLFloaterIMPanel*)userdata;
2138 LLUIString message = line; 2175 LLUIString message = line;
@@ -2141,11 +2178,17 @@ void LLFloaterIMPanel::chatFromLogFile(LLLogChat::ELogLineType type, LLString li
2141 { 2178 {
2142 case LLLogChat::LOG_EMPTY: 2179 case LLLogChat::LOG_EMPTY:
2143 // add warning log enabled message 2180 // add warning log enabled message
2144 message = LLFloaterChat::getInstance()->getUIString("IM_logging_string"); 2181 if (gSavedPerAccountSettings.getBOOL("LogInstantMessages"))
2182 {
2183 message = LLFloaterChat::getInstance()->getUIString("IM_logging_string");
2184 }
2145 break; 2185 break;
2146 case LLLogChat::LOG_END: 2186 case LLLogChat::LOG_END:
2147 // add log end message 2187 // add log end message
2148 message = LLFloaterChat::getInstance()->getUIString("IM_logging_string"); 2188 if (gSavedPerAccountSettings.getBOOL("LogInstantMessages"))
2189 {
2190 message = LLFloaterChat::getInstance()->getUIString("IM_logging_string");
2191 }
2149 break; 2192 break;
2150 case LLLogChat::LOG_LINE: 2193 case LLLogChat::LOG_LINE:
2151 // just add normal lines from file 2194 // just add normal lines from file
@@ -2172,7 +2215,7 @@ void LLFloaterIMPanel::showSessionStartError(
2172 //their own XML file which would be read in by any LLIMPanel 2215 //their own XML file which would be read in by any LLIMPanel
2173 //post build function instead of repeating the same info 2216 //post build function instead of repeating the same info
2174 //in the group, adhoc and normal IM xml files. 2217 //in the group, adhoc and normal IM xml files.
2175 LLString::format_map_t args; 2218 LLStringUtil::format_map_t args;
2176 args["[REASON]"] = 2219 args["[REASON]"] =
2177 LLFloaterIM::sErrorStringsMap[error_string]; 2220 LLFloaterIM::sErrorStringsMap[error_string];
2178 args["[RECIPIENT]"] = getTitle(); 2221 args["[RECIPIENT]"] = getTitle();
@@ -2188,7 +2231,7 @@ void LLFloaterIMPanel::showSessionEventError(
2188 const std::string& event_string, 2231 const std::string& event_string,
2189 const std::string& error_string) 2232 const std::string& error_string)
2190{ 2233{
2191 LLString::format_map_t args; 2234 LLStringUtil::format_map_t args;
2192 args["[REASON]"] = 2235 args["[REASON]"] =
2193 LLFloaterIM::sErrorStringsMap[error_string]; 2236 LLFloaterIM::sErrorStringsMap[error_string];
2194 args["[EVENT]"] = 2237 args["[EVENT]"] =
@@ -2203,7 +2246,7 @@ void LLFloaterIMPanel::showSessionEventError(
2203void LLFloaterIMPanel::showSessionForceClose( 2246void LLFloaterIMPanel::showSessionForceClose(
2204 const std::string& reason_string) 2247 const std::string& reason_string)
2205{ 2248{
2206 LLString::format_map_t args; 2249 LLStringUtil::format_map_t args;
2207 2250
2208 args["[NAME]"] = getTitle(); 2251 args["[NAME]"] = getTitle();
2209 args["[REASON]"] = LLFloaterIM::sForceCloseSessionMap[reason_string]; 2252 args["[REASON]"] = LLFloaterIM::sForceCloseSessionMap[reason_string];
@@ -2212,7 +2255,7 @@ void LLFloaterIMPanel::showSessionForceClose(
2212 "ForceCloseChatterBoxSession", 2255 "ForceCloseChatterBoxSession",
2213 args, 2256 args,
2214 LLFloaterIMPanel::onConfirmForceCloseError, 2257 LLFloaterIMPanel::onConfirmForceCloseError,
2215 this); 2258 new LLUUID(mSessionUUID));
2216 2259
2217} 2260}
2218 2261