aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llstartup.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2008-08-15 23:45:02 -0500
committerJacek Antonelli2008-08-15 23:45:02 -0500
commitd644fc64407dcd14ffcee6a0e9fbe28ee3a4e9bd (patch)
tree7ed0c2c27d717801238a2e6b5749cd5bf88c3059 /linden/indra/newview/llstartup.cpp
parentSecond Life viewer sources 1.17.3.0 (diff)
downloadmeta-impy-d644fc64407dcd14ffcee6a0e9fbe28ee3a4e9bd.zip
meta-impy-d644fc64407dcd14ffcee6a0e9fbe28ee3a4e9bd.tar.gz
meta-impy-d644fc64407dcd14ffcee6a0e9fbe28ee3a4e9bd.tar.bz2
meta-impy-d644fc64407dcd14ffcee6a0e9fbe28ee3a4e9bd.tar.xz
Second Life viewer sources 1.18.0.6
Diffstat (limited to 'linden/indra/newview/llstartup.cpp')
-rw-r--r--linden/indra/newview/llstartup.cpp343
1 files changed, 54 insertions, 289 deletions
diff --git a/linden/indra/newview/llstartup.cpp b/linden/indra/newview/llstartup.cpp
index 0130edf..7dbb107 100644
--- a/linden/indra/newview/llstartup.cpp
+++ b/linden/indra/newview/llstartup.cpp
@@ -50,6 +50,7 @@
50#include "llerrorcontrol.h" 50#include "llerrorcontrol.h"
51#include "llfiltersd2xmlrpc.h" 51#include "llfiltersd2xmlrpc.h"
52#include "llfocusmgr.h" 52#include "llfocusmgr.h"
53#include "llhttpsender.h"
53#include "imageids.h" 54#include "imageids.h"
54#include "lllandmark.h" 55#include "lllandmark.h"
55#include "llloginflags.h" 56#include "llloginflags.h"
@@ -223,7 +224,6 @@ BOOL is_hex_string(U8* str, S32 len);
223void show_first_run_dialog(); 224void show_first_run_dialog();
224void first_run_dialog_callback(S32 option, void* userdata); 225void first_run_dialog_callback(S32 option, void* userdata);
225void set_startup_status(const F32 frac, const char* string, const char* msg); 226void set_startup_status(const F32 frac, const char* string, const char* msg);
226void on_userserver_name_resolved( BOOL success, const LLString& host_name, U32 ip, void* userdata );
227void login_alert_status(S32 option, void* user_data); 227void login_alert_status(S32 option, void* user_data);
228void update_app(BOOL mandatory, const std::string& message); 228void update_app(BOOL mandatory, const std::string& message);
229void update_dialog_callback(S32 option, void *userdata); 229void update_dialog_callback(S32 option, void *userdata);
@@ -236,7 +236,6 @@ void dialog_choose_gender_first_start();
236void callback_choose_gender(S32 option, void* userdata); 236void callback_choose_gender(S32 option, void* userdata);
237void init_start_screen(S32 location_id); 237void init_start_screen(S32 location_id);
238void release_start_screen(); 238void release_start_screen();
239void process_connect_to_userserver(LLMessageSystem* msg, void**);
240void reset_login(); 239void reset_login();
241 240
242// 241//
@@ -246,6 +245,21 @@ void reset_login();
246// 245//
247// local classes 246// local classes
248// 247//
248
249namespace
250{
251 class LLNullHTTPSender : public LLHTTPSender
252 {
253 virtual void send(const LLHost& host,
254 const char* message, const LLSD& body,
255 LLHTTPClient::ResponderPtr response) const
256 {
257 llwarns << " attemped to send " << message << " to " << host
258 << " with null sender" << llendl;
259 }
260 };
261}
262
249class LLGestureInventoryFetchObserver : public LLInventoryFetchObserver 263class LLGestureInventoryFetchObserver : public LLInventoryFetchObserver
250{ 264{
251public: 265public:
@@ -422,7 +436,7 @@ BOOL idle_startup()
422 port = gSavedSettings.getU32("ConnectionPort"); 436 port = gSavedSettings.getU32("ConnectionPort");
423 } 437 }
424 438
425 LLMessageConfig::initClass("viewer", gDirUtilp->getExpandedFilename(LL_PATH_APP_SETTINGS, "")); 439 LLHTTPSender::setDefaultSender(new LLNullHTTPSender());
426 if(!start_messaging_system( 440 if(!start_messaging_system(
427 message_template_path, 441 message_template_path,
428 port, 442 port,
@@ -435,6 +449,7 @@ BOOL idle_startup()
435 std::string msg = llformat("Unable to start networking, error %d", gMessageSystem->getErrorCode()); 449 std::string msg = llformat("Unable to start networking, error %d", gMessageSystem->getErrorCode());
436 app_early_exit(msg); 450 app_early_exit(msg);
437 } 451 }
452 LLMessageConfig::initClass("viewer", gDirUtilp->getExpandedFilename(LL_PATH_APP_SETTINGS, ""));
438 } 453 }
439 else 454 else
440 { 455 {
@@ -452,9 +467,13 @@ BOOL idle_startup()
452 msg->setExceptionFunc(MX_PACKET_TOO_SHORT, 467 msg->setExceptionFunc(MX_PACKET_TOO_SHORT,
453 invalid_message_callback, 468 invalid_message_callback,
454 NULL); 469 NULL);
455 msg->setExceptionFunc(MX_RAN_OFF_END_OF_PACKET, 470
471 // running off end of a packet is now valid in the case
472 // when a reader has a newer message template than
473 // the sender
474 /*msg->setExceptionFunc(MX_RAN_OFF_END_OF_PACKET,
456 invalid_message_callback, 475 invalid_message_callback,
457 NULL); 476 NULL);*/
458 msg->setExceptionFunc(MX_WROTE_PAST_BUFFER_SIZE, 477 msg->setExceptionFunc(MX_WROTE_PAST_BUFFER_SIZE,
459 invalid_message_callback, 478 invalid_message_callback,
460 NULL); 479 NULL);
@@ -476,7 +495,7 @@ BOOL idle_startup()
476 gXferManager->setUseAckThrottling(TRUE); 495 gXferManager->setUseAckThrottling(TRUE);
477 gXferManager->setAckThrottleBPS(xfer_throttle_bps); 496 gXferManager->setAckThrottleBPS(xfer_throttle_bps);
478 } 497 }
479 gAssetStorage = new LLViewerAssetStorage(msg, gXferManager, gVFS, gUserServer); 498 gAssetStorage = new LLViewerAssetStorage(msg, gXferManager, gVFS);
480 499
481 msg->mPacketRing.setDropPercentage(gPacketDropPercentage); 500 msg->mPacketRing.setDropPercentage(gPacketDropPercentage);
482 if (gInBandwidth != 0.f) 501 if (gInBandwidth != 0.f)
@@ -778,7 +797,6 @@ BOOL idle_startup()
778 gSavedSettings.setS32("ServerChoice", gUserServerChoice); 797 gSavedSettings.setS32("ServerChoice", gUserServerChoice);
779 if (gUserServerChoice == USERSERVER_OTHER) 798 if (gUserServerChoice == USERSERVER_OTHER)
780 { 799 {
781 gUserServer.setHostByName( server_label.c_str() );
782 snprintf(gUserServerName, MAX_STRING, "%s", server_label.c_str()); /* Flawfinder: ignore */ 800 snprintf(gUserServerName, MAX_STRING, "%s", server_label.c_str()); /* Flawfinder: ignore */
783 } 801 }
784 } 802 }
@@ -845,231 +863,15 @@ BOOL idle_startup()
845 // color init must be after saved settings loaded 863 // color init must be after saved settings loaded
846 init_colors(); 864 init_colors();
847 865
848 // Request userserver domain name 866 // skipping over STATE_UPDATE_CHECK because that just waits for input
849 set_startup_status(0.05f, "Finding Server Domain Name...", NULL); 867 gStartupState = STATE_LOGIN_AUTH_INIT;
850
851 // We're prematurely switching out of this state because the
852 // userserver name resolver can potentiallly occur before reaching the end of the
853 // switch statement. Also, if it's done at the bottom, sometimes we will
854 // skip the userserver resolved step (in the local cases) - djs 09/24/03
855 gStartupState++;
856 timeout.reset();
857
858 switch( gUserServerChoice )
859 {
860 case USERSERVER_AGNI:
861 gInProductionGrid = TRUE;
862 case USERSERVER_DMZ:
863 case USERSERVER_ADITI:
864 case USERSERVER_SIVA:
865 case USERSERVER_SHAKTI:
866 case USERSERVER_DURGA:
867 case USERSERVER_SOMA:
868 case USERSERVER_VAAK:
869 case USERSERVER_GANGA:
870 case USERSERVER_UMA:
871 {
872 const char* host_name = gUserServerDomainName[gUserServerChoice].mName;
873 snprintf(gUserServerName, MAX_STRING, "%s", host_name); /* Flawfinder: ignore */
874 llinfos << "Resolving " <<
875 gUserServerDomainName[gUserServerChoice].mLabel <<
876 " userserver domain name " << host_name << llendl;
877
878 BOOL requested_domain_name = gAsyncHostByName.startRequest( host_name, on_userserver_name_resolved, NULL );
879 if( !requested_domain_name )
880 //BOOL resolved_domain_name = gUserServer.setHostByName( host_name );
881 //if( !resolved_domain_name )
882 {
883 llwarns << "setHostByName failed" << llendl;
884
885 LLStringBase<char>::format_map_t args;
886 args["[HOST_NAME]"] = host_name;
887
888 gViewerWindow->alertXml("UnableToConnect", args, login_alert_done );
889 reset_login();
890 return FALSE;
891 }
892 break;
893 }
894
895 case USERSERVER_LOCAL:
896 llinfos << "Using local userserver" << llendl;
897 gUserServer.setAddress( LOOPBACK_ADDRESS_STRING );
898 gStartupState = STATE_USERSERVER_RESOLVED;
899 break;
900
901 case USERSERVER_OTHER:
902 llinfos << "Userserver set explicitly" << llendl;
903 gStartupState = STATE_USERSERVER_RESOLVED;
904 break;
905
906 case USERSERVER_NONE:
907 default:
908 llerrs << "No userserver IP address specified" << llendl;
909 break;
910 }
911 return do_normal_idle;
912 }
913
914 if (STATE_RESOLVING_USERSERVER == gStartupState)
915 {
916 // Don't do anything. Wait for LL_WM_HOST_RESOLVED which is handled by LLAsyncHostByName,
917 // which calls on_userserver_name_resolved, which will push us to the next state.
918 if (timeout.getElapsedTimeF32() > TIMEOUT_SECONDS*3.f)
919 {
920 // Cancel the pending asynchostbyname request
921
922 gViewerWindow->alertXml("CanNotFindServer",
923 login_alert_status, NULL);
924
925 // Back up to login screen
926 reset_login();
927 gViewerStats->incStat(LLViewerStats::ST_LOGIN_TIMEOUT_COUNT);
928 }
929 ms_sleep(1);
930 return do_normal_idle;
931 }
932
933 if (STATE_USERSERVER_RESOLVED == gStartupState)
934 {
935 if (!gUserServer.isOk())
936 {
937 LLStringBase<char>::format_map_t args;
938 args["[IP_ADDRESS]"] = u32_to_ip_string( gUserServer.getAddress() );
939
940 gViewerWindow->alertXml("PleaseSelectServer", args, login_alert_done );
941
942 reset_login();
943 return FALSE;
944 }
945
946 write_debug("Userserver: ");
947 char tmp_str[256]; /* Flawfinder: ignore */
948 gUserServer.getIPString(tmp_str, 256);
949 write_debug(tmp_str);
950 write_debug("\n");
951
952 gStartupState++;
953 }
954
955 if (STATE_MESSAGE_TEMPLATE_SEND == gStartupState)
956 {
957 set_startup_status(0.10f, "Verifying protocol version...", NULL);
958
959 LLHost mt_host;
960 if (!gRunLocal)
961 {
962 // open up user server circuit (trusted)
963 gMessageSystem->enableCircuit(gUserServer, TRUE);
964 mt_host = gUserServer;
965 }
966 else
967 {
968 mt_host = gAgentSimHost;
969 }
970
971 llinfos << "Verifying message template..." << llendl;
972 LLMessageSystem::sendSecureMessageTemplateChecksum(mt_host);
973
974 timeout.reset();
975 gStartupState++;
976 return do_normal_idle;
977 }
978
979 if (STATE_MESSAGE_TEMPLATE_WAIT == gStartupState)
980 {
981 LLMessageSystem* msg = gMessageSystem;
982 while (msg->checkAllMessages(gFrameCount, gServicePump))
983 {
984 if (msg->isTemplateConfirmed())
985 {
986 BOOL update_available = FALSE;
987 BOOL mandatory = FALSE;
988
989 if (!LLMessageSystem::doesTemplateMatch())
990 {
991 // Mandatory update -- message template checksum doesn't match
992 update_available = TRUE;
993 mandatory = TRUE;
994 }
995
996 BOOL quit = FALSE;
997 if (update_available)
998 {
999 if (show_connect_box)
1000 {
1001 update_app(mandatory, "");
1002 gStartupState = STATE_UPDATE_CHECK;
1003 return FALSE;
1004 }
1005 else
1006 {
1007 quit = TRUE;
1008 }
1009 }
1010
1011 // Bail out and clean up circuit
1012 if (quit)
1013 {
1014 msg->newMessageFast(_PREHASH_CloseCircuit);
1015 msg->sendMessage( msg->getSender() );
1016 app_force_quit(NULL);
1017 return FALSE;
1018 }
1019
1020 // If we get here, we've got a compatible message template
1021 if (!mandatory)
1022 {
1023 llinfos << "Message template is current!" << llendl;
1024 }
1025 gStartupState = STATE_LOGIN_AUTH_INIT;
1026 timeout.reset();
1027 // unregister with the message system so it knows we're no longer expecting this message
1028 msg->setHandlerFuncFast(_PREHASH_TemplateChecksumReply, NULL, NULL);
1029
1030 msg->newMessageFast(_PREHASH_CloseCircuit);
1031 msg->sendMessage(gUserServer);
1032 msg->disableCircuit(gUserServer);
1033 if (gRunLocal)
1034 {
1035 msg->enableCircuit(gAgentSimHost, TRUE);
1036
1037 // Don't use a session token, and generate a random user id
1038 gAgentID.generate();
1039 gAgentSessionID = LLUUID::null;
1040
1041 // Skip userserver queries.
1042 gStartupState = STATE_WORLD_INIT;
1043 }
1044 }
1045 }
1046 gMessageSystem->processAcks();
1047
1048 if (timeout.getElapsedTimeF32() > TIMEOUT_SECONDS)
1049 {
1050 if (timeout_count > MAX_TIMEOUT_COUNT)
1051 {
1052 gViewerWindow->alertXml("SystemMayBeDown",
1053 login_alert_status,
1054 NULL);
1055
1056 // Back up to login screen
1057 reset_login();
1058 gViewerStats->incStat(LLViewerStats::ST_LOGIN_TIMEOUT_COUNT);
1059 }
1060 else
1061 {
1062 llinfos << "Resending on timeout" << llendl;
1063 gStartupState--;
1064 timeout_count++;
1065 }
1066 }
1067 868
1068 return do_normal_idle; 869 return do_normal_idle;
1069 } 870 }
1070 871
1071 if (STATE_UPDATE_CHECK == gStartupState) 872 if (STATE_UPDATE_CHECK == gStartupState)
1072 { 873 {
874 // wait for user to give input via dialog box
1073 return do_normal_idle; 875 return do_normal_idle;
1074 } 876 }
1075 877
@@ -1677,9 +1479,7 @@ BOOL idle_startup()
1677 // 1479 //
1678 // Initialize classes w/graphics stuff. 1480 // Initialize classes w/graphics stuff.
1679 // 1481 //
1680 gImageList.doPrefetchImages(); 1482 gImageList.doPrefetchImages();
1681 update_texture_fetch();
1682
1683 LLSurface::initClasses(); 1483 LLSurface::initClasses();
1684 1484
1685 LLFace::initClass(); 1485 LLFace::initClass();
@@ -1710,6 +1510,7 @@ BOOL idle_startup()
1710 LLViewerRegion *regionp = gWorldp->getRegionFromHandle(first_sim_handle); 1510 LLViewerRegion *regionp = gWorldp->getRegionFromHandle(first_sim_handle);
1711 llinfos << "Adding initial simulator " << regionp->getOriginGlobal() << llendl; 1511 llinfos << "Adding initial simulator " << regionp->getOriginGlobal() << llendl;
1712 1512
1513 gStartupState = STATE_SEED_GRANTED_WAIT;
1713 regionp->setSeedCapability(first_sim_seed_cap); 1514 regionp->setSeedCapability(first_sim_seed_cap);
1714 1515
1715 // Set agent's initial region to be the one we just created. 1516 // Set agent's initial region to be the one we just created.
@@ -1725,9 +1526,32 @@ BOOL idle_startup()
1725 // VEFFECT: Login 1526 // VEFFECT: Login
1726 gWorldp->addRegion(0, gAgentSimHost); 1527 gWorldp->addRegion(0, gAgentSimHost);
1727 gAgent.setRegion(gWorldp->getRegionFromHandle(0)); 1528 gAgent.setRegion(gWorldp->getRegionFromHandle(0));
1529
1530 gStartupState = STATE_SEED_CAP_GRANTED;
1728 } 1531 }
1729 1532
1730 display_startup(); 1533 display_startup();
1534 return do_normal_idle;
1535 }
1536
1537
1538 //---------------------------------------------------------------------
1539 // Wait for Seed Cap Grant
1540 //---------------------------------------------------------------------
1541 if(STATE_SEED_GRANTED_WAIT == gStartupState)
1542 {
1543 llinfos << "Waiting for seed grant ...." << llendl;
1544 return do_normal_idle;
1545 }
1546
1547
1548 //---------------------------------------------------------------------
1549 // Seed Capability Granted
1550 // no newMessage calls should happen before this point
1551 //---------------------------------------------------------------------
1552 if (STATE_SEED_CAP_GRANTED == gStartupState)
1553 {
1554 update_texture_fetch();
1731 1555
1732 // Initialize UI 1556 // Initialize UI
1733 if (!gNoRender) 1557 if (!gNoRender)
@@ -2195,21 +2019,6 @@ BOOL idle_startup()
2195 return do_normal_idle; 2019 return do_normal_idle;
2196 } 2020 }
2197 2021
2198 //---------------------------------------------------------------------
2199 // Assert agent to userserver
2200 //---------------------------------------------------------------------
2201 if (STATE_CONNECT_USERSERVER == gStartupState)
2202 {
2203 LLMessageSystem* msg = gMessageSystem;
2204 msg->enableCircuit(gUserServer, TRUE);
2205 msg->newMessage("ConnectAgentToUserserver");
2206 msg->nextBlockFast(_PREHASH_AgentData);
2207 msg->addUUIDFast(_PREHASH_AgentID, gAgent.getID());
2208 msg->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID());
2209 msg->sendReliable(gUserServer);
2210 gStartupState++;
2211 return do_normal_idle;
2212 }
2213 2022
2214 //--------------------------------------------------------------------- 2023 //---------------------------------------------------------------------
2215 // Misc 2024 // Misc
@@ -2334,9 +2143,6 @@ BOOL idle_startup()
2334 msg->setHandlerFuncFast(_PREHASH_AttachedSound, process_attached_sound); 2143 msg->setHandlerFuncFast(_PREHASH_AttachedSound, process_attached_sound);
2335 msg->setHandlerFuncFast(_PREHASH_AttachedSoundGainChange, process_attached_sound_gain_change); 2144 msg->setHandlerFuncFast(_PREHASH_AttachedSoundGainChange, process_attached_sound_gain_change);
2336 //msg->setHandlerFuncFast(_PREHASH_AttachedSoundCutoffRadius, process_attached_sound_cutoff_radius); 2145 //msg->setHandlerFuncFast(_PREHASH_AttachedSoundCutoffRadius, process_attached_sound_cutoff_radius);
2337 msg->setHandlerFunc(
2338 "ConnectToUserserver",
2339 process_connect_to_userserver);
2340 2146
2341 llinfos << "Initialization complete" << llendl; 2147 llinfos << "Initialization complete" << llendl;
2342 gInitializationComplete = TRUE; 2148 gInitializationComplete = TRUE;
@@ -2776,31 +2582,6 @@ void set_startup_status(const F32 frac, const char *string, const char* msg)
2776 gViewerWindow->setProgressMessage(msg); 2582 gViewerWindow->setProgressMessage(msg);
2777} 2583}
2778 2584
2779void on_userserver_name_resolved( BOOL success, const LLString& host_name, U32 ip, void* userdata )
2780{
2781 if( STATE_RESOLVING_USERSERVER != gStartupState )
2782 {
2783 llwarns << "Userserver name callback returned during invalid state!" << llendl;
2784 return;
2785 }
2786
2787 if( success )
2788 {
2789 gUserServer.setAddress( ip );
2790 llinfos << "...Userserver resolved to " << gUserServer << llendl;
2791 gStartupState = STATE_USERSERVER_RESOLVED;
2792 }
2793 else
2794 {
2795 llwarns << "setHostByName failed" << llendl;
2796
2797 LLStringBase<char>::format_map_t args;
2798 args["[HOST_NAME]"] = host_name;
2799 gViewerWindow->alertXml("SetByHostFail", args, login_alert_done );
2800 reset_login();
2801 }
2802}
2803
2804void login_alert_status(S32 option, void* user_data) 2585void login_alert_status(S32 option, void* user_data)
2805{ 2586{
2806 if (0 == option) 2587 if (0 == option)
@@ -2924,8 +2705,6 @@ void update_dialog_callback(S32 option, void *userdata)
2924 LLURI update_url = LLURI::buildHTTP("secondlife.com", 80, "update.php", query_map); 2705 LLURI update_url = LLURI::buildHTTP("secondlife.com", 80, "update.php", query_map);
2925 2706
2926#if LL_WINDOWS 2707#if LL_WINDOWS
2927 char ip[MAX_STRING]; /* Flawfinder: ignore */
2928
2929 update_exe_path = gDirUtilp->getTempFilename(); 2708 update_exe_path = gDirUtilp->getTempFilename();
2930 if (update_exe_path.empty()) 2709 if (update_exe_path.empty())
2931 { 2710 {
@@ -2952,7 +2731,6 @@ void update_dialog_callback(S32 option, void *userdata)
2952 app_force_quit(NULL); 2731 app_force_quit(NULL);
2953 return; 2732 return;
2954 } 2733 }
2955 u32_to_ip_string(gUserServer.getAddress(), ip);
2956 2734
2957 // if a sim name was passed in via command line parameter (typically through a SLURL) 2735 // if a sim name was passed in via command line parameter (typically through a SLURL)
2958 if ( LLURLSimString::sInstance.mSimString.length() ) 2736 if ( LLURLSimString::sInstance.mSimString.length() )
@@ -3080,7 +2858,7 @@ void register_viewer_callbacks(LLMessageSystem* msg)
3080 msg->setHandlerFuncFast(_PREHASH_MeanCollisionAlert, process_mean_collision_alert_message, NULL); 2858 msg->setHandlerFuncFast(_PREHASH_MeanCollisionAlert, process_mean_collision_alert_message, NULL);
3081 msg->setHandlerFunc("ViewerFrozenMessage", process_frozen_message); 2859 msg->setHandlerFunc("ViewerFrozenMessage", process_frozen_message);
3082 2860
3083 msg->setHandlerFuncFast(_PREHASH_RequestAvatarInfo, process_avatar_info_request); 2861 //msg->setHandlerFuncFast(_PREHASH_RequestAvatarInfo, process_avatar_info_request);
3084 msg->setHandlerFuncFast(_PREHASH_NameValuePair, process_name_value); 2862 msg->setHandlerFuncFast(_PREHASH_NameValuePair, process_name_value);
3085 msg->setHandlerFuncFast(_PREHASH_RemoveNameValuePair, process_remove_name_value); 2863 msg->setHandlerFuncFast(_PREHASH_RemoveNameValuePair, process_remove_name_value);
3086 msg->setHandlerFuncFast(_PREHASH_AvatarAnimation, process_avatar_animation); 2864 msg->setHandlerFuncFast(_PREHASH_AvatarAnimation, process_avatar_animation);
@@ -3944,19 +3722,6 @@ void release_start_screen()
3944 gStartImageGL = NULL; 3722 gStartImageGL = NULL;
3945} 3723}
3946 3724
3947void process_connect_to_userserver(LLMessageSystem* msg, void**)
3948{
3949 // Sent unreliably since if we've become disconnected, the
3950 // userserver will get back to us eventually. By sending reliable,
3951 // we also may accidently induce two separate validations under
3952 // conditions where the userserver is already lagged.
3953 msg->newMessage("ConnectAgentToUserserver");
3954 msg->nextBlockFast(_PREHASH_AgentData);
3955 msg->addUUIDFast(_PREHASH_AgentID, gAgent.getID());
3956 msg->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID());
3957 msg->sendMessage(gUserServer);
3958}
3959
3960bool LLStartUp::canGoFullscreen() 3725bool LLStartUp::canGoFullscreen()
3961{ 3726{
3962 return gStartupState >= STATE_WORLD_INIT; 3727 return gStartupState >= STATE_WORLD_INIT;