diff options
Diffstat (limited to 'linden/indra/newview/llviewermessage.cpp')
-rw-r--r-- | linden/indra/newview/llviewermessage.cpp | 63 |
1 files changed, 36 insertions, 27 deletions
diff --git a/linden/indra/newview/llviewermessage.cpp b/linden/indra/newview/llviewermessage.cpp index c337044..2011275 100644 --- a/linden/indra/newview/llviewermessage.cpp +++ b/linden/indra/newview/llviewermessage.cpp | |||
@@ -129,8 +129,9 @@ | |||
129 | #include "llweb.h" | 129 | #include "llweb.h" |
130 | #include "llworld.h" | 130 | #include "llworld.h" |
131 | #include "pipeline.h" | 131 | #include "pipeline.h" |
132 | #include "viewer.h" | 132 | #include "llappviewer.h" |
133 | #include "llfloaterworldmap.h" | 133 | #include "llfloaterworldmap.h" |
134 | #include "llviewerdisplay.h" | ||
134 | #include "llkeythrottle.h" | 135 | #include "llkeythrottle.h" |
135 | 136 | ||
136 | #include <boost/tokenizer.hpp> | 137 | #include <boost/tokenizer.hpp> |
@@ -153,8 +154,6 @@ static const F32 LLREQUEST_PERMISSION_THROTTLE_INTERVAL = 10.0f; // seconds | |||
153 | 154 | ||
154 | extern BOOL gDebugClicks; | 155 | extern BOOL gDebugClicks; |
155 | 156 | ||
156 | extern void bad_network_handler(); | ||
157 | |||
158 | // function prototypes | 157 | // function prototypes |
159 | void open_offer(const std::vector<LLUUID>& items, const std::string& from_name); | 158 | void open_offer(const std::vector<LLUUID>& items, const std::string& from_name); |
160 | void friendship_offer_callback(S32 option, void* user_data); | 159 | void friendship_offer_callback(S32 option, void* user_data); |
@@ -209,8 +208,8 @@ void give_money(const LLUUID& uuid, LLViewerRegion* region, S32 amount, BOOL is_ | |||
209 | LLMessageSystem* msg = gMessageSystem; | 208 | LLMessageSystem* msg = gMessageSystem; |
210 | msg->newMessageFast(_PREHASH_MoneyTransferRequest); | 209 | msg->newMessageFast(_PREHASH_MoneyTransferRequest); |
211 | msg->nextBlockFast(_PREHASH_AgentData); | 210 | msg->nextBlockFast(_PREHASH_AgentData); |
212 | msg->addUUIDFast(_PREHASH_AgentID, agent_get_id()); | 211 | msg->addUUIDFast(_PREHASH_AgentID, gAgent.getID()); |
213 | msg->addUUIDFast(_PREHASH_SessionID, agent_get_session_id()); | 212 | msg->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID()); |
214 | msg->nextBlockFast(_PREHASH_MoneyData); | 213 | msg->nextBlockFast(_PREHASH_MoneyData); |
215 | msg->addUUIDFast(_PREHASH_SourceID, gAgent.getID() ); | 214 | msg->addUUIDFast(_PREHASH_SourceID, gAgent.getID() ); |
216 | msg->addUUIDFast(_PREHASH_DestID, uuid); | 215 | msg->addUUIDFast(_PREHASH_DestID, uuid); |
@@ -248,7 +247,7 @@ void process_logout_reply(LLMessageSystem* msg, void**) | |||
248 | msg->getUUID("AgentData", "AgentID", agent_id); | 247 | msg->getUUID("AgentData", "AgentID", agent_id); |
249 | LLUUID session_id; | 248 | LLUUID session_id; |
250 | msg->getUUID("AgentData", "SessionID", session_id); | 249 | msg->getUUID("AgentData", "SessionID", session_id); |
251 | if((agent_id != agent_get_id()) || (session_id != agent_get_session_id())) | 250 | if((agent_id != gAgent.getID()) || (session_id != gAgent.getSessionID())) |
252 | { | 251 | { |
253 | llwarns << "Bogus Logout Reply" << llendl; | 252 | llwarns << "Bogus Logout Reply" << llendl; |
254 | } | 253 | } |
@@ -285,7 +284,7 @@ void process_logout_reply(LLMessageSystem* msg, void**) | |||
285 | gInventory.accountForUpdate(parents); | 284 | gInventory.accountForUpdate(parents); |
286 | gInventory.notifyObservers(); | 285 | gInventory.notifyObservers(); |
287 | } | 286 | } |
288 | app_force_quit(NULL); | 287 | LLAppViewer::instance()->forceQuit(); |
289 | } | 288 | } |
290 | 289 | ||
291 | void process_layer_data(LLMessageSystem *mesgsys, void **user_data) | 290 | void process_layer_data(LLMessageSystem *mesgsys, void **user_data) |
@@ -789,7 +788,7 @@ bool check_offer_throttle(const std::string& from_name, bool check_only) | |||
789 | // Use the name of the last item giver, who is probably the person | 788 | // Use the name of the last item giver, who is probably the person |
790 | // spamming you. JC | 789 | // spamming you. JC |
791 | std::ostringstream message; | 790 | std::ostringstream message; |
792 | message << gSecondLife; | 791 | message << LLAppViewer::instance()->getSecondLifeTitle(); |
793 | if (!from_name.empty()) | 792 | if (!from_name.empty()) |
794 | { | 793 | { |
795 | message << ": Items coming in too fast from " << from_name; | 794 | message << ": Items coming in too fast from " << from_name; |
@@ -2715,7 +2714,7 @@ void process_agent_movement_complete(LLMessageSystem* msg, void**) | |||
2715 | << x << ":" << y | 2714 | << x << ":" << y |
2716 | << " current pos " << gAgent.getPositionGlobal() | 2715 | << " current pos " << gAgent.getPositionGlobal() |
2717 | << llendl; | 2716 | << llendl; |
2718 | do_disconnect("You were sent to an invalid region."); | 2717 | LLAppViewer::instance()->forceDisconnect("You were sent to an invalid region."); |
2719 | return; | 2718 | return; |
2720 | 2719 | ||
2721 | } | 2720 | } |
@@ -2895,7 +2894,7 @@ void send_agent_update(BOOL force_send, BOOL send_reliable) | |||
2895 | } | 2894 | } |
2896 | 2895 | ||
2897 | // We have already requested to log out. Don't send agent updates. | 2896 | // We have already requested to log out. Don't send agent updates. |
2898 | if(gLogoutRequestSent) | 2897 | if(LLAppViewer::instance()->logoutRequestSent()) |
2899 | { | 2898 | { |
2900 | return; | 2899 | return; |
2901 | } | 2900 | } |
@@ -3242,10 +3241,13 @@ void process_time_synch(LLMessageSystem *mesgsys, void **user_data) | |||
3242 | F32 phase; | 3241 | F32 phase; |
3243 | U64 space_time_usec; | 3242 | U64 space_time_usec; |
3244 | 3243 | ||
3244 | U32 seconds_per_day; | ||
3245 | U32 seconds_per_year; | ||
3246 | |||
3245 | // "SimulatorViewerTimeMessage" | 3247 | // "SimulatorViewerTimeMessage" |
3246 | mesgsys->getU64Fast(_PREHASH_TimeInfo, _PREHASH_UsecSinceStart, space_time_usec); | 3248 | mesgsys->getU64Fast(_PREHASH_TimeInfo, _PREHASH_UsecSinceStart, space_time_usec); |
3247 | mesgsys->getU32Fast(_PREHASH_TimeInfo, _PREHASH_SecPerDay, gSecondsPerDay); | 3249 | mesgsys->getU32Fast(_PREHASH_TimeInfo, _PREHASH_SecPerDay, seconds_per_day); |
3248 | mesgsys->getU32Fast(_PREHASH_TimeInfo, _PREHASH_SecPerYear, gSecondsPerYear); | 3250 | mesgsys->getU32Fast(_PREHASH_TimeInfo, _PREHASH_SecPerYear, seconds_per_year); |
3249 | 3251 | ||
3250 | // This should eventually be moved to an "UpdateHeavenlyBodies" message | 3252 | // This should eventually be moved to an "UpdateHeavenlyBodies" message |
3251 | mesgsys->getF32Fast(_PREHASH_TimeInfo, _PREHASH_SunPhase, phase); | 3253 | mesgsys->getF32Fast(_PREHASH_TimeInfo, _PREHASH_SunPhase, phase); |
@@ -3930,7 +3932,7 @@ void process_kick_user(LLMessageSystem *msg, void** /*user_data*/) | |||
3930 | 3932 | ||
3931 | msg->getStringFast(_PREHASH_UserInfo, _PREHASH_Reason, 2048, message); | 3933 | msg->getStringFast(_PREHASH_UserInfo, _PREHASH_Reason, 2048, message); |
3932 | 3934 | ||
3933 | do_disconnect(message); | 3935 | LLAppViewer::instance()->forceDisconnect(message); |
3934 | } | 3936 | } |
3935 | 3937 | ||
3936 | 3938 | ||
@@ -4069,18 +4071,18 @@ void process_alert_message(LLMessageSystem *msgsystem, void **user_data) | |||
4069 | process_alert_core(buffer, modal); | 4071 | process_alert_core(buffer, modal); |
4070 | } | 4072 | } |
4071 | 4073 | ||
4072 | void process_alert_core(const char* buffer, BOOL modal) | 4074 | void process_alert_core(const std::string& message, BOOL modal) |
4073 | { | 4075 | { |
4074 | // make sure the cursor is back to the usual default since the | 4076 | // make sure the cursor is back to the usual default since the |
4075 | // alert is probably due to some kind of error. | 4077 | // alert is probably due to some kind of error. |
4076 | gViewerWindow->getWindow()->resetBusyCount(); | 4078 | gViewerWindow->getWindow()->resetBusyCount(); |
4077 | 4079 | ||
4078 | // HACK -- handle callbacks for specific alerts | 4080 | // HACK -- handle callbacks for specific alerts |
4079 | if( !strcmp( buffer, "You died and have been teleported to your home location" ) ) | 4081 | if ( message == "You died and have been teleported to your home location") |
4080 | { | 4082 | { |
4081 | gViewerStats->incStat(LLViewerStats::ST_KILLED_COUNT); | 4083 | gViewerStats->incStat(LLViewerStats::ST_KILLED_COUNT); |
4082 | } | 4084 | } |
4083 | else if( !strcmp( buffer, "Home position set." ) ) | 4085 | else if( message == "Home position set." ) |
4084 | { | 4086 | { |
4085 | // save the home location image to disk | 4087 | // save the home location image to disk |
4086 | LLString snap_filename = gDirUtilp->getLindenUserDir(); | 4088 | LLString snap_filename = gDirUtilp->getLindenUserDir(); |
@@ -4089,19 +4091,26 @@ void process_alert_core(const char* buffer, BOOL modal) | |||
4089 | gViewerWindow->saveSnapshot(snap_filename, gViewerWindow->getWindowWidth(), gViewerWindow->getWindowHeight(), FALSE, FALSE); | 4091 | gViewerWindow->saveSnapshot(snap_filename, gViewerWindow->getWindowWidth(), gViewerWindow->getWindowHeight(), FALSE, FALSE); |
4090 | } | 4092 | } |
4091 | 4093 | ||
4092 | const char ALERT_PREFIX[] = "ALERT: "; | 4094 | const std::string ALERT_PREFIX("ALERT: "); |
4093 | const size_t ALERT_PREFIX_LEN = sizeof(ALERT_PREFIX) - 1; | 4095 | const std::string NOTIFY_PREFIX("NOTIFY: "); |
4094 | if (!strncmp(buffer, ALERT_PREFIX, ALERT_PREFIX_LEN)) | 4096 | if (message.find(ALERT_PREFIX) == 0) |
4095 | { | 4097 | { |
4096 | // Allow the server to spawn a named alert so that server alerts can be | 4098 | // Allow the server to spawn a named alert so that server alerts can be |
4097 | // translated out of English. JC | 4099 | // translated out of English. |
4098 | std::string alert_name(buffer + ALERT_PREFIX_LEN); | 4100 | std::string alert_name(message.substr(ALERT_PREFIX.length())); |
4099 | LLAlertDialog::showXml(alert_name); | 4101 | LLAlertDialog::showXml(alert_name); |
4100 | } | 4102 | } |
4101 | else if (buffer[0] == '/') | 4103 | else if (message.find(NOTIFY_PREFIX) == 0) |
4104 | { | ||
4105 | // Allow the server to spawn a named notification so that server notifications can be | ||
4106 | // translated out of English. | ||
4107 | std::string notify_name(message.substr(NOTIFY_PREFIX.length())); | ||
4108 | LLNotifyBox::showXml(notify_name); | ||
4109 | } | ||
4110 | else if (message[0] == '/') | ||
4102 | { | 4111 | { |
4103 | // System message is important, show in upper-right box not tip | 4112 | // System message is important, show in upper-right box not tip |
4104 | LLString text(buffer+1); | 4113 | LLString text(message.substr(1)); |
4105 | LLString::format_map_t args; | 4114 | LLString::format_map_t args; |
4106 | if (text.substr(0,17) == "RESTART_X_MINUTES") | 4115 | if (text.substr(0,17) == "RESTART_X_MINUTES") |
4107 | { | 4116 | { |
@@ -4128,14 +4137,14 @@ void process_alert_core(const char* buffer, BOOL modal) | |||
4128 | { | 4137 | { |
4129 | // *TODO:translate | 4138 | // *TODO:translate |
4130 | LLString::format_map_t args; | 4139 | LLString::format_map_t args; |
4131 | args["[ERROR_MESSAGE]"] = buffer; | 4140 | args["[ERROR_MESSAGE]"] = message; |
4132 | gViewerWindow->alertXml("ErrorMessage", args); | 4141 | gViewerWindow->alertXml("ErrorMessage", args); |
4133 | } | 4142 | } |
4134 | else | 4143 | else |
4135 | { | 4144 | { |
4136 | // *TODO:translate | 4145 | // *TODO:translate |
4137 | LLString::format_map_t args; | 4146 | LLString::format_map_t args; |
4138 | args["[MESSAGE]"] = buffer; | 4147 | args["[MESSAGE]"] = message; |
4139 | LLNotifyBox::showXml("SystemMessageTip", args); | 4148 | LLNotifyBox::showXml("SystemMessageTip", args); |
4140 | } | 4149 | } |
4141 | } | 4150 | } |
@@ -5365,7 +5374,7 @@ void invalid_message_callback(LLMessageSystem* msg, | |||
5365 | void*, | 5374 | void*, |
5366 | EMessageException exception) | 5375 | EMessageException exception) |
5367 | { | 5376 | { |
5368 | bad_network_handler(); | 5377 | LLAppViewer::instance()->badNetworkHandler(); |
5369 | } | 5378 | } |
5370 | 5379 | ||
5371 | // Please do not add more message handlers here. This file is huge. | 5380 | // Please do not add more message handlers here. This file is huge. |