aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llstartup.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2008-08-15 23:45:19 -0500
committerJacek Antonelli2008-08-15 23:45:19 -0500
commitb235c59d60472f818a9142c0886b95a0ff4191d7 (patch)
treed323c55587584b19cc43a03f58a178823f12d3cd /linden/indra/newview/llstartup.cpp
parentSecond Life viewer sources 1.18.5.3 (diff)
downloadmeta-impy-b235c59d60472f818a9142c0886b95a0ff4191d7.zip
meta-impy-b235c59d60472f818a9142c0886b95a0ff4191d7.tar.gz
meta-impy-b235c59d60472f818a9142c0886b95a0ff4191d7.tar.bz2
meta-impy-b235c59d60472f818a9142c0886b95a0ff4191d7.tar.xz
Second Life viewer sources 1.18.6.0-RC
Diffstat (limited to '')
-rw-r--r--linden/indra/newview/llstartup.cpp338
1 files changed, 142 insertions, 196 deletions
diff --git a/linden/indra/newview/llstartup.cpp b/linden/indra/newview/llstartup.cpp
index dad8046..6c37341 100644
--- a/linden/indra/newview/llstartup.cpp
+++ b/linden/indra/newview/llstartup.cpp
@@ -134,6 +134,7 @@
134#include "llurlsimstring.h" 134#include "llurlsimstring.h"
135#include "llurlwhitelist.h" 135#include "llurlwhitelist.h"
136#include "lluserauth.h" 136#include "lluserauth.h"
137#include "llvieweraudio.h"
137#include "llviewerassetstorage.h" 138#include "llviewerassetstorage.h"
138#include "llviewercamera.h" 139#include "llviewercamera.h"
139#include "llviewerdisplay.h" 140#include "llviewerdisplay.h"
@@ -155,12 +156,16 @@
155#include "llworldmap.h" 156#include "llworldmap.h"
156#include "llxfermanager.h" 157#include "llxfermanager.h"
157#include "pipeline.h" 158#include "pipeline.h"
158#include "viewer.h" 159#include "llappviewer.h"
159#include "llmediaengine.h" 160#include "llmediaengine.h"
160#include "llfasttimerview.h" 161#include "llfasttimerview.h"
161#include "llfloatermap.h" 162#include "llfloatermap.h"
162#include "llweb.h" 163#include "llweb.h"
163#include "llvoiceclient.h" 164#include "llvoiceclient.h"
165#include "llnamelistctrl.h"
166#include "llnamebox.h"
167#include "llnameeditor.h"
168#include "llurlsimstring.h"
164 169
165#if LL_LIBXUL_ENABLED 170#if LL_LIBXUL_ENABLED
166#include "llmozlib.h" 171#include "llmozlib.h"
@@ -186,13 +191,7 @@
186// 191//
187// exported globals 192// exported globals
188// 193//
189 194BOOL gAgentMovementCompleted = FALSE;
190// HACK: Allow server to change sun and moon IDs.
191// I can't figure out how to pass the appropriate
192// information into the LLVOSky constructor. JC
193LLUUID gSunTextureID = IMG_SUN;
194LLUUID gMoonTextureID = IMG_MOON;
195LLUUID gCloudTextureID = IMG_CLOUD_POOF;
196 195
197const char* SCREEN_HOME_FILENAME = "screen_home.bmp"; 196const char* SCREEN_HOME_FILENAME = "screen_home.bmp";
198const char* SCREEN_LAST_FILENAME = "screen_last.bmp"; 197const char* SCREEN_LAST_FILENAME = "screen_last.bmp";
@@ -202,7 +201,6 @@ const char* SCREEN_LAST_FILENAME = "screen_last.bmp";
202// 201//
203extern S32 gStartImageWidth; 202extern S32 gStartImageWidth;
204extern S32 gStartImageHeight; 203extern S32 gStartImageHeight;
205extern std::string gSerialNumber;
206 204
207// 205//
208// local globals 206// local globals
@@ -250,6 +248,17 @@ void init_start_screen(S32 location_id);
250void release_start_screen(); 248void release_start_screen();
251void reset_login(); 249void reset_login();
252 250
251void callback_cache_name(const LLUUID& id, const char* firstname, const char* lastname, BOOL is_group, void* data)
252{
253 LLNameListCtrl::refreshAll(id, firstname, lastname, is_group);
254 LLNameBox::refreshAll(id, firstname, lastname, is_group);
255 LLNameEditor::refreshAll(id, firstname, lastname, is_group);
256
257 // TODO: Actually be intelligent about the refresh.
258 // For now, just brute force refresh the dialogs.
259 dialog_refresh_all();
260}
261
253// 262//
254// exported functionality 263// exported functionality
255// 264//
@@ -288,9 +297,9 @@ public:
288 297
289void update_texture_fetch() 298void update_texture_fetch()
290{ 299{
291 gTextureCache->update(1); // unpauses the texture cache thread 300 LLAppViewer::getTextureCache()->update(1); // unpauses the texture cache thread
292 gImageDecodeThread->update(1); // unpauses the image thread 301 LLAppViewer::getImageDecodeThread()->update(1); // unpauses the image thread
293 gTextureFetch->update(1); // unpauses the texture fetch thread 302 LLAppViewer::getTextureFetch()->update(1); // unpauses the texture fetch thread
294 gImageList.updateImages(0.10f); 303 gImageList.updateImages(0.10f);
295} 304}
296 305
@@ -320,6 +329,7 @@ BOOL idle_startup()
320 static std::string auth_message; 329 static std::string auth_message;
321 static LLString firstname; 330 static LLString firstname;
322 static LLString lastname; 331 static LLString lastname;
332 static LLUUID web_login_key;
323 static LLString password; 333 static LLString password;
324 static std::vector<const char*> requested_options; 334 static std::vector<const char*> requested_options;
325 335
@@ -339,7 +349,6 @@ BOOL idle_startup()
339 static S32 location_which = START_LOCATION_ID_LAST; 349 static S32 location_which = START_LOCATION_ID_LAST;
340 350
341 static BOOL show_connect_box = TRUE; 351 static BOOL show_connect_box = TRUE;
342 static BOOL remember_password = TRUE;
343 352
344 static BOOL stipend_since_login = FALSE; 353 static BOOL stipend_since_login = FALSE;
345 354
@@ -372,7 +381,7 @@ BOOL idle_startup()
372 381
373 ///////////////////////////////////////////////// 382 /////////////////////////////////////////////////
374 // 383 //
375 // Initialize stuff that doesn't need data from userserver/simulators 384 // Initialize stuff that doesn't need data from simulators
376 // 385 //
377 386
378 if (gFeatureManagerp->isSafe()) 387 if (gFeatureManagerp->isSafe())
@@ -412,7 +421,7 @@ BOOL idle_startup()
412 // *TODO:translate (maybe - very unlikely error message) 421 // *TODO:translate (maybe - very unlikely error message)
413 // Note: alerts.xml may be invalid - if this gets translated it will need to be in the code 422 // Note: alerts.xml may be invalid - if this gets translated it will need to be in the code
414 LLString bad_xui_msg = "An error occured while updating Second Life. Please download the latest version from www.secondlife.com."; 423 LLString bad_xui_msg = "An error occured while updating Second Life. Please download the latest version from www.secondlife.com.";
415 app_early_exit(bad_xui_msg); 424 LLAppViewer::instance()->earlyExit(bad_xui_msg);
416 } 425 }
417 // 426 //
418 // Statistics stuff 427 // Statistics stuff
@@ -465,13 +474,13 @@ BOOL idle_startup()
465 std::string())) 474 std::string()))
466 { 475 {
467 std::string msg = llformat("Unable to start networking, error %d", gMessageSystem->getErrorCode()); 476 std::string msg = llformat("Unable to start networking, error %d", gMessageSystem->getErrorCode());
468 app_early_exit(msg); 477 LLAppViewer::instance()->earlyExit(msg);
469 } 478 }
470 LLMessageConfig::initClass("viewer", gDirUtilp->getExpandedFilename(LL_PATH_APP_SETTINGS, "")); 479 LLMessageConfig::initClass("viewer", gDirUtilp->getExpandedFilename(LL_PATH_APP_SETTINGS, ""));
471 } 480 }
472 else 481 else
473 { 482 {
474 app_early_exit("Unable to initialize communications."); 483 LLAppViewer::instance()->earlyExit("Unable to initialize communications.");
475 } 484 }
476 485
477 if(gMessageSystem && gMessageSystem->isOK()) 486 if(gMessageSystem && gMessageSystem->isOK())
@@ -625,37 +634,42 @@ BOOL idle_startup()
625 // 634 //
626 // Log on to system 635 // Log on to system
627 // 636 //
628 if( !gCmdLineFirstName.empty() 637 if ((!gLoginHandler.mFirstName.empty() &&
638 !gLoginHandler.mLastName.empty() &&
639 !gLoginHandler.mWebLoginKey.isNull())
640 || gLoginHandler.parseDirectLogin(LLStartUp::sSLURLCommand) )
641 {
642 firstname = gLoginHandler.mFirstName;
643 lastname = gLoginHandler.mLastName;
644 web_login_key = gLoginHandler.mWebLoginKey;
645
646 show_connect_box = FALSE;
647 }
648 else if( !gCmdLineFirstName.empty()
629 && !gCmdLineLastName.empty() 649 && !gCmdLineLastName.empty()
630 && !gCmdLinePassword.empty()) 650 && !gCmdLinePassword.empty())
631 { 651 {
632 firstname = gCmdLineFirstName; 652 firstname = gCmdLineFirstName;
633 lastname = gCmdLineLastName; 653 lastname = gCmdLineLastName;
634 654
635 LLMD5 pass((unsigned char*)gCmdLinePassword.c_str()); 655 show_connect_box = TRUE;
636 char md5pass[33]; /* Flawfinder: ignore */ 656 gAutoLogin = TRUE;
637 pass.hex_digest(md5pass);
638 password = md5pass;
639
640 remember_password = gSavedSettings.getBOOL("RememberPassword");
641 show_connect_box = FALSE;
642 } 657 }
643 else if (gAutoLogin || gSavedSettings.getBOOL("AutoLogin")) 658 else if (gAutoLogin || gSavedSettings.getBOOL("AutoLogin"))
644 { 659 {
645 firstname = gSavedSettings.getString("FirstName"); 660 firstname = gSavedSettings.getString("FirstName");
646 lastname = gSavedSettings.getString("LastName"); 661 lastname = gSavedSettings.getString("LastName");
647 password = load_password_from_disk(); 662 password = load_password_from_disk();
648 remember_password = TRUE; 663 gSavedSettings.setBOOL("RememberPassword", TRUE);
649 show_connect_box = FALSE; 664 show_connect_box = TRUE;
650 } 665 }
651 else 666 else
652 { 667 {
653 // if not automatically logging in, display login dialog 668 // if not automatically logging in, display login dialog
654 // until a valid userserver is selected 669 // a valid grid is selected
655 firstname = gSavedSettings.getString("FirstName"); 670 firstname = gSavedSettings.getString("FirstName");
656 lastname = gSavedSettings.getString("LastName"); 671 lastname = gSavedSettings.getString("LastName");
657 password = load_password_from_disk(); 672 password = load_password_from_disk();
658 remember_password = gSavedSettings.getBOOL("RememberPassword");
659 show_connect_box = TRUE; 673 show_connect_box = TRUE;
660 } 674 }
661 675
@@ -665,7 +679,8 @@ BOOL idle_startup()
665 } 679 }
666 680
667 if (STATE_LOGIN_SHOW == LLStartUp::getStartupState()) 681 if (STATE_LOGIN_SHOW == LLStartUp::getStartupState())
668 { 682 {
683
669 llinfos << "Initializing Window" << llendl; 684 llinfos << "Initializing Window" << llendl;
670 685
671 gViewerWindow->getWindow()->setCursor(UI_CURSOR_ARROW); 686 gViewerWindow->getWindow()->setCursor(UI_CURSOR_ARROW);
@@ -686,8 +701,6 @@ BOOL idle_startup()
686 // Show the login dialog 701 // Show the login dialog
687 login_show(); 702 login_show();
688 703
689 // connect dialog is already shown, so fill in the names
690 LLPanelLogin::setFields( firstname, lastname, password, remember_password );
691 LLPanelLogin::giveFocus(); 704 LLPanelLogin::giveFocus();
692 705
693 gSavedSettings.setBOOL("FirstRunThisInstall", FALSE); 706 gSavedSettings.setBOOL("FirstRunThisInstall", FALSE);
@@ -699,6 +712,32 @@ BOOL idle_startup()
699 // skip directly to message template verification 712 // skip directly to message template verification
700 LLStartUp::setStartupState( STATE_LOGIN_CLEANUP ); 713 LLStartUp::setStartupState( STATE_LOGIN_CLEANUP );
701 } 714 }
715
716 // Create selection manager
717 // Must be done before menus created, because many enabled callbacks
718 // require its existance.
719 gSelectMgr = new LLSelectMgr();
720 gParcelMgr = new LLViewerParcelMgr();
721 gHUDManager = new LLHUDManager();
722 gMuteListp = new LLMuteList();
723
724 // Initialize UI
725 if (!gNoRender)
726 {
727 // Initialize all our tools. Must be done after saved settings loaded.
728 if ( gToolMgr == NULL )
729 {
730 gToolMgr = new LLToolMgr();
731 gToolMgr->initTools();
732 }
733
734 // Quickly get something onscreen to look at.
735 gViewerWindow->initWorldUI();
736 }
737
738 gViewerWindow->setNormalControlsVisible( FALSE );
739 gLoginMenuBarView->setVisible( TRUE );
740 gLoginMenuBarView->setEnabled( TRUE );
702 741
703 timeout.reset(); 742 timeout.reset();
704 return do_normal_idle; 743 return do_normal_idle;
@@ -716,11 +755,16 @@ BOOL idle_startup()
716 755
717 if (STATE_LOGIN_CLEANUP == LLStartUp::getStartupState()) 756 if (STATE_LOGIN_CLEANUP == LLStartUp::getStartupState())
718 { 757 {
758 //reset the values that could have come in from a slurl
759 if (!gLoginHandler.mWebLoginKey.isNull())
760 {
761 firstname = gLoginHandler.mFirstName;
762 lastname = gLoginHandler.mLastName;
763 web_login_key = gLoginHandler.mWebLoginKey;
764 }
765
719 if (show_connect_box) 766 if (show_connect_box)
720 { 767 {
721 // Load all the name information out of the login view
722 LLPanelLogin::getFields(firstname, lastname, password, remember_password);
723
724 // HACK: Try to make not jump on login 768 // HACK: Try to make not jump on login
725 gKeyboard->resetKeys(); 769 gKeyboard->resetKeys();
726 } 770 }
@@ -730,12 +774,11 @@ BOOL idle_startup()
730 gSavedSettings.setString("FirstName", firstname); 774 gSavedSettings.setString("FirstName", firstname);
731 gSavedSettings.setString("LastName", lastname); 775 gSavedSettings.setString("LastName", lastname);
732 776
777
778
779
733 llinfos << "Attempting login as: " << firstname << " " << lastname << llendl; 780 llinfos << "Attempting login as: " << firstname << " " << lastname << llendl;
734 write_debug("Attempting login as: "); 781 gDebugInfo["LoginName"] = firstname + " " + lastname;
735 write_debug(firstname);
736 write_debug(" ");
737 write_debug(lastname);
738 write_debug("\n");
739 } 782 }
740 783
741 // create necessary directories 784 // create necessary directories
@@ -780,28 +823,10 @@ BOOL idle_startup()
780 823
781 if (show_connect_box) 824 if (show_connect_box)
782 { 825 {
783 LLString server_label;
784 S32 domain_name_index;
785 BOOL user_picked_server = LLPanelLogin::getServer( server_label, domain_name_index );
786 gUserServerChoice = (EUserServerDomain) domain_name_index;
787 gSavedSettings.setS32("ServerChoice", gUserServerChoice);
788 if (gUserServerChoice == USERSERVER_OTHER)
789 {
790 snprintf(gUserServerName, MAX_STRING, "%s", server_label.c_str()); /* Flawfinder: ignore */
791 }
792
793 if ( user_picked_server )
794 { // User picked a grid from the popup, so clear the stored urls and they will be re-generated from gUserServerChoice
795 sAuthUris.clear();
796 resetURIs();
797 }
798
799 LLString location;
800 LLPanelLogin::getLocation( location );
801 LLURLSimString::setString( location );
802 LLPanelLogin::close(); 826 LLPanelLogin::close();
803 } 827 }
804 828
829
805 //For HTML parsing in text boxes. 830 //For HTML parsing in text boxes.
806 LLTextEditor::setLinkColor( gSavedSettings.getColor4("HTMLLinkColor") ); 831 LLTextEditor::setLinkColor( gSavedSettings.getColor4("HTMLLinkColor") );
807 LLTextEditor::setURLCallbacks ( &LLWeb::loadURL, &LLURLDispatcher::dispatch, &LLURLDispatcher::dispatch ); 832 LLTextEditor::setURLCallbacks ( &LLWeb::loadURL, &LLURLDispatcher::dispatch, &LLURLDispatcher::dispatch );
@@ -871,6 +896,8 @@ BOOL idle_startup()
871 if(STATE_LOGIN_AUTH_INIT == LLStartUp::getStartupState()) 896 if(STATE_LOGIN_AUTH_INIT == LLStartUp::getStartupState())
872 { 897 {
873//#define LL_MINIMIAL_REQUESTED_OPTIONS 898//#define LL_MINIMIAL_REQUESTED_OPTIONS
899 gDebugInfo["GridUtilHost"] = gGridInfo[gGridChoice].mName;
900
874 lldebugs << "STATE_LOGIN_AUTH_INIT" << llendl; 901 lldebugs << "STATE_LOGIN_AUTH_INIT" << llendl;
875 if (!gUserAuthp) 902 if (!gUserAuthp)
876 { 903 {
@@ -906,14 +933,13 @@ BOOL idle_startup()
906 gSavedSettings.setBOOL("UseDebugMenus", TRUE); 933 gSavedSettings.setBOOL("UseDebugMenus", TRUE);
907 requested_options.push_back("god-connect"); 934 requested_options.push_back("god-connect");
908 } 935 }
909 if (sAuthUris.empty()) 936 LLAppViewer::instance()->getLoginURIs();
910 { 937 sAuthUris = LLAppViewer::instance()->getLoginURIs();
911 sAuthUris = getLoginURIs(); 938
912 }
913 sAuthUriNum = 0; 939 sAuthUriNum = 0;
914 auth_method = "login_to_simulator"; 940 auth_method = "login_to_simulator";
915 auth_desc = "Logging in. "; 941 auth_desc = "Logging in. ";
916 auth_desc += gSecondLife; 942 auth_desc += LLAppViewer::instance()->getSecondLifeTitle();
917 auth_desc += " may appear frozen. Please wait."; 943 auth_desc += " may appear frozen. Please wait.";
918 LLStartUp::setStartupState( STATE_LOGIN_AUTHENTICATE ); 944 LLStartUp::setStartupState( STATE_LOGIN_AUTHENTICATE );
919 } 945 }
@@ -931,11 +957,12 @@ BOOL idle_startup()
931 // a startup URL was specified 957 // a startup URL was specified
932 std::stringstream unescaped_start; 958 std::stringstream unescaped_start;
933 unescaped_start << "uri:" 959 unescaped_start << "uri:"
934 << LLURLSimString::sInstance.mSimName << "&" 960 << LLURLSimString::sInstance.mSimName << "&"
935 << LLURLSimString::sInstance.mX << "&" 961 << LLURLSimString::sInstance.mX << "&"
936 << LLURLSimString::sInstance.mY << "&" 962 << LLURLSimString::sInstance.mY << "&"
937 << LLURLSimString::sInstance.mZ; 963 << LLURLSimString::sInstance.mZ;
938 start << xml_escape_string(unescaped_start.str().c_str()); 964 start << xml_escape_string(unescaped_start.str().c_str());
965
939 } 966 }
940 else if (gSavedSettings.getBOOL("LoginLastLocation")) 967 else if (gSavedSettings.getBOOL("LoginLastLocation"))
941 { 968 {
@@ -951,13 +978,13 @@ BOOL idle_startup()
951 hashed_mac.update( gMACAddress, MAC_ADDRESS_BYTES ); 978 hashed_mac.update( gMACAddress, MAC_ADDRESS_BYTES );
952 hashed_mac.finalize(); 979 hashed_mac.finalize();
953 hashed_mac.hex_digest(hashed_mac_string); 980 hashed_mac.hex_digest(hashed_mac_string);
954 981
955 gUserAuthp->authenticate( 982 gUserAuthp->authenticate(
956 sAuthUris[sAuthUriNum].c_str(), 983 sAuthUris[sAuthUriNum].c_str(),
957 auth_method.c_str(), 984 auth_method.c_str(),
958 firstname.c_str(), 985 firstname.c_str(),
959 lastname.c_str(), 986 lastname.c_str(),
960 password.c_str(), 987 web_login_key,
961 start.str().c_str(), 988 start.str().c_str(),
962 gSkipOptionalUpdate, 989 gSkipOptionalUpdate,
963 gAcceptTOS, 990 gAcceptTOS,
@@ -966,7 +993,8 @@ BOOL idle_startup()
966 gLastExecFroze, 993 gLastExecFroze,
967 requested_options, 994 requested_options,
968 hashed_mac_string, 995 hashed_mac_string,
969 gSerialNumber); 996 LLAppViewer::instance()->getSerialNumber());
997
970 // reset globals 998 // reset globals
971 gAcceptTOS = FALSE; 999 gAcceptTOS = FALSE;
972 gAcceptCriticalMessage = FALSE; 1000 gAcceptCriticalMessage = FALSE;
@@ -977,6 +1005,10 @@ BOOL idle_startup()
977 if(STATE_LOGIN_NO_DATA_YET == LLStartUp::getStartupState()) 1005 if(STATE_LOGIN_NO_DATA_YET == LLStartUp::getStartupState())
978 { 1006 {
979 //lldebugs << "STATE_LOGIN_NO_DATA_YET" << llendl; 1007 //lldebugs << "STATE_LOGIN_NO_DATA_YET" << llendl;
1008 // If we get here we have gotten past the potential stall
1009 // in curl, so take "may appear frozen" out of progress bar. JC
1010 auth_desc = "Logging in...";
1011 set_startup_status(progress, auth_desc.c_str(), auth_message.c_str());
980 if (!gUserAuthp) 1012 if (!gUserAuthp)
981 { 1013 {
982 llerrs << "No userauth in STATE_LOGIN_NO_DATA_YET!" << llendl; 1014 llerrs << "No userauth in STATE_LOGIN_NO_DATA_YET!" << llendl;
@@ -1167,7 +1199,7 @@ BOOL idle_startup()
1167 default: 1199 default:
1168 if (sAuthUriNum >= (int) sAuthUris.size() - 1) 1200 if (sAuthUriNum >= (int) sAuthUris.size() - 1)
1169 { 1201 {
1170 emsg << "Unable to connect to " << gSecondLife << ".\n"; 1202 emsg << "Unable to connect to " << LLAppViewer::instance()->getSecondLifeTitle() << ".\n";
1171 emsg << gUserAuthp->errorMessage(); 1203 emsg << gUserAuthp->errorMessage();
1172 } else { 1204 } else {
1173 sAuthUriNum++; 1205 sAuthUriNum++;
@@ -1187,7 +1219,7 @@ BOOL idle_startup()
1187 { 1219 {
1188 delete gUserAuthp; 1220 delete gUserAuthp;
1189 gUserAuthp = NULL; 1221 gUserAuthp = NULL;
1190 app_force_quit(NULL); 1222 LLAppViewer::instance()->forceQuit();
1191 return FALSE; 1223 return FALSE;
1192 } 1224 }
1193 1225
@@ -1202,15 +1234,11 @@ BOOL idle_startup()
1202 const char* text; 1234 const char* text;
1203 text = gUserAuthp->getResponse("agent_id"); 1235 text = gUserAuthp->getResponse("agent_id");
1204 if(text) gAgentID.set(text); 1236 if(text) gAgentID.set(text);
1205 write_debug("AgentID: "); 1237 gDebugInfo["AgentID"] = text;
1206 write_debug(text);
1207 write_debug("\n");
1208 1238
1209 text = gUserAuthp->getResponse("session_id"); 1239 text = gUserAuthp->getResponse("session_id");
1210 if(text) gAgentSessionID.set(text); 1240 if(text) gAgentSessionID.set(text);
1211 write_debug("SessionID: "); 1241 gDebugInfo["SessionID"] = text;
1212 write_debug(text);
1213 write_debug("\n");
1214 1242
1215 text = gUserAuthp->getResponse("secure_session_id"); 1243 text = gUserAuthp->getResponse("secure_session_id");
1216 if(text) gAgent.mSecureSessionID.set(text); 1244 if(text) gAgent.mSecureSessionID.set(text);
@@ -1228,17 +1256,8 @@ BOOL idle_startup()
1228 if(text) lastname.assign(text); 1256 if(text) lastname.assign(text);
1229 gSavedSettings.setString("FirstName", firstname); 1257 gSavedSettings.setString("FirstName", firstname);
1230 gSavedSettings.setString("LastName", lastname); 1258 gSavedSettings.setString("LastName", lastname);
1231 if (remember_password) 1259
1232 {
1233 save_password_to_disk(password.c_str());
1234 }
1235 else
1236 {
1237 save_password_to_disk(NULL);
1238 }
1239 gSavedSettings.setBOOL("RememberPassword", remember_password);
1240 gSavedSettings.setBOOL("LoginLastLocation", gSavedSettings.getBOOL("LoginLastLocation")); 1260 gSavedSettings.setBOOL("LoginLastLocation", gSavedSettings.getBOOL("LoginLastLocation"));
1241 gSavedSettings.setBOOL("LoggedIn", TRUE);
1242 1261
1243 text = gUserAuthp->getResponse("agent_access"); 1262 text = gUserAuthp->getResponse("agent_access");
1244 if(text && (text[0] == 'M')) 1263 if(text && (text[0] == 'M'))
@@ -1463,14 +1482,6 @@ BOOL idle_startup()
1463 // type the name/password again if we crash. 1482 // type the name/password again if we crash.
1464 gSavedSettings.saveToFile(gSettingsFileName, TRUE); 1483 gSavedSettings.saveToFile(gSettingsFileName, TRUE);
1465 1484
1466 // Create selection manager
1467 // Must be done before menus created, because many enabled callbacks
1468 // require its existance.
1469 gSelectMgr = new LLSelectMgr();
1470 gParcelMgr = new LLViewerParcelMgr();
1471 gHUDManager = new LLHUDManager();
1472 gMuteListp = new LLMuteList();
1473
1474 // 1485 //
1475 // Initialize classes w/graphics stuff. 1486 // Initialize classes w/graphics stuff.
1476 // 1487 //
@@ -1539,21 +1550,14 @@ BOOL idle_startup()
1539 if ( gViewerWindow != NULL && gToolMgr != NULL ) 1550 if ( gViewerWindow != NULL && gToolMgr != NULL )
1540 { // This isn't the first logon attempt, so show the UI 1551 { // This isn't the first logon attempt, so show the UI
1541 gViewerWindow->setNormalControlsVisible( TRUE ); 1552 gViewerWindow->setNormalControlsVisible( TRUE );
1542 } 1553 }
1554 gLoginMenuBarView->setVisible( FALSE );
1555 gLoginMenuBarView->setEnabled( FALSE );
1556
1557 gFloaterMap->setVisible( gSavedSettings.getBOOL("ShowMiniMap") );
1543 1558
1544 // Initialize UI
1545 if (!gNoRender) 1559 if (!gNoRender)
1546 { 1560 {
1547 // Initialize all our tools. Must be done after saved settings loaded.
1548 if ( gToolMgr == NULL )
1549 {
1550 gToolMgr = new LLToolMgr();
1551 gToolMgr->initTools();
1552 }
1553
1554 // Quickly get something onscreen to look at.
1555 gViewerWindow->initWorldUI();
1556
1557 // Move the progress view in front of the UI 1561 // Move the progress view in front of the UI
1558 gViewerWindow->moveProgressViewToFront(); 1562 gViewerWindow->moveProgressViewToFront();
1559 1563
@@ -1587,7 +1591,7 @@ BOOL idle_startup()
1587 gCacheName->addObserver(callback_cache_name); 1591 gCacheName->addObserver(callback_cache_name);
1588 1592
1589 // Load stored cache if possible 1593 // Load stored cache if possible
1590 load_name_cache(); 1594 LLAppViewer::instance()->loadNameCache();
1591 } 1595 }
1592 1596
1593 // Data storage for map of world. 1597 // Data storage for map of world.
@@ -1985,22 +1989,8 @@ BOOL idle_startup()
1985 gAgent.sendReliableMessage(); 1989 gAgent.sendReliableMessage();
1986 1990
1987 // request all group information 1991 // request all group information
1988 // *FIX: This will not do the right thing if the message
1989 // gets there before the requestuserserverconnection
1990 // circuit is completed.
1991 gAgent.sendAgentDataUpdateRequest(); 1992 gAgent.sendAgentDataUpdateRequest();
1992 1993
1993
1994 // NOTE: removed as part of user-privacy
1995 // enhancements. this information should be available from
1996 // login. 2006-10-16 Phoenix.
1997 // get the users that have been granted modify powers
1998 //msg->newMessageFast(_PREHASH_RequestGrantedProxies);
1999 //msg->nextBlockFast(_PREHASH_AgentData);
2000 //msg->addUUIDFast(_PREHASH_AgentID, gAgent.getID());
2001 //msg->addUUIDFast(_PREHASH_SessionID, gAgent.getSessionID());
2002 //gAgent.sendReliableMessage();
2003
2004 BOOL shown_at_exit = gSavedSettings.getBOOL("ShowInventory"); 1994 BOOL shown_at_exit = gSavedSettings.getBOOL("ShowInventory");
2005 1995
2006 // Create the inventory views 1996 // Create the inventory views
@@ -2136,7 +2126,6 @@ BOOL idle_startup()
2136 //msg->setHandlerFuncFast(_PREHASH_AttachedSoundCutoffRadius, process_attached_sound_cutoff_radius); 2126 //msg->setHandlerFuncFast(_PREHASH_AttachedSoundCutoffRadius, process_attached_sound_cutoff_radius);
2137 2127
2138 llinfos << "Initialization complete" << llendl; 2128 llinfos << "Initialization complete" << llendl;
2139 gInitializationComplete = TRUE;
2140 2129
2141 gRenderStartTime.reset(); 2130 gRenderStartTime.reset();
2142 gForegroundTime.reset(); 2131 gForegroundTime.reset();
@@ -2169,17 +2158,17 @@ BOOL idle_startup()
2169 if (url_ok) 2158 if (url_ok)
2170 { 2159 {
2171 args["[TYPE]"] = "desired"; 2160 args["[TYPE]"] = "desired";
2172 args["[HELP]"] = " "; 2161 args["[HELP]"] = "";
2173 } 2162 }
2174 else if (gSavedSettings.getBOOL("LoginLastLocation")) 2163 else if (gSavedSettings.getBOOL("LoginLastLocation"))
2175 { 2164 {
2176 args["[TYPE]"] = "last"; 2165 args["[TYPE]"] = "last";
2177 args["[HELP]"] = " \n "; 2166 args["[HELP]"] = "";
2178 } 2167 }
2179 else 2168 else
2180 { 2169 {
2181 args["[TYPE]"] = "home"; 2170 args["[TYPE]"] = "home";
2182 args["[HELP]"] = " \nYou may want to set a new home location.\n "; 2171 args["[HELP]"] = "\nYou may want to set a new home location.";
2183 } 2172 }
2184 gViewerWindow->alertXml("AvatarMoved", args); 2173 gViewerWindow->alertXml("AvatarMoved", args);
2185 } 2174 }
@@ -2351,68 +2340,12 @@ void login_show()
2351 // UI textures have been previously loaded in doPreloadImages() 2340 // UI textures have been previously loaded in doPreloadImages()
2352 2341
2353 llinfos << "Setting Servers" << llendl; 2342 llinfos << "Setting Servers" << llendl;
2354
2355 if( USERSERVER_OTHER == gUserServerChoice )
2356 {
2357 LLPanelLogin::addServer( gUserServerName, USERSERVER_OTHER );
2358 }
2359 else
2360 {
2361 LLPanelLogin::addServer( gUserServerDomainName[gUserServerChoice].mLabel, gUserServerChoice );
2362 }
2363
2364 // Arg! We hate loops!
2365 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_DMZ].mLabel, USERSERVER_DMZ );
2366 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_LOCAL].mLabel, USERSERVER_LOCAL );
2367 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_AGNI].mLabel, USERSERVER_AGNI );
2368 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_ADITI].mLabel, USERSERVER_ADITI );
2369 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_SIVA].mLabel, USERSERVER_SIVA );
2370 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_DURGA].mLabel, USERSERVER_DURGA );
2371 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_SHAKTI].mLabel, USERSERVER_SHAKTI );
2372 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_GANGA].mLabel, USERSERVER_GANGA );
2373 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_UMA].mLabel, USERSERVER_UMA );
2374 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_SOMA].mLabel, USERSERVER_SOMA );
2375 LLPanelLogin::addServer( gUserServerDomainName[USERSERVER_VAAK].mLabel, USERSERVER_VAAK );
2376} 2343}
2377 2344
2378// Callback for when login screen is closed. Option 0 = connect, option 1 = quit. 2345// Callback for when login screen is closed. Option 0 = connect, option 1 = quit.
2379void login_callback(S32 option, void *userdata) 2346void login_callback(S32 option, void *userdata)
2380{ 2347{
2381 const S32 CONNECT_OPTION = 0;
2382 const S32 QUIT_OPTION = 1;
2383
2384 if (CONNECT_OPTION == option)
2385 {
2386 LLStartUp::setStartupState( STATE_LOGIN_CLEANUP );
2387 return;
2388 }
2389 else if (QUIT_OPTION == option)
2390 {
2391 // Make sure we don't save the password if the user is trying to clear it.
2392 LLString first, last, password;
2393 BOOL remember = TRUE;
2394 LLPanelLogin::getFields(first, last, password, remember);
2395 if (!remember)
2396 {
2397 // turn off the setting and write out to disk
2398 gSavedSettings.setBOOL("RememberPassword", FALSE);
2399 gSavedSettings.saveToFile(gSettingsFileName, TRUE);
2400
2401 // stomp the saved password on disk
2402 save_password_to_disk(NULL);
2403 }
2404 2348
2405 LLPanelLogin::close();
2406
2407 // Next iteration through main loop should shut down the app cleanly.
2408 gQuit = TRUE;
2409
2410 return;
2411 }
2412 else
2413 {
2414 llwarns << "Unknown login button clicked" << llendl;
2415 }
2416} 2349}
2417 2350
2418LLString load_password_from_disk() 2351LLString load_password_from_disk()
@@ -2660,7 +2593,7 @@ void update_dialog_callback(S32 option, void *userdata)
2660 // ...user doesn't want to do it 2593 // ...user doesn't want to do it
2661 if (mandatory) 2594 if (mandatory)
2662 { 2595 {
2663 app_force_quit(); 2596 LLAppViewer::instance()->forceQuit();
2664 // Bump them back to the login screen. 2597 // Bump them back to the login screen.
2665 //reset_login(); 2598 //reset_login();
2666 } 2599 }
@@ -2680,7 +2613,9 @@ void update_dialog_callback(S32 option, void *userdata)
2680#elif LL_LINUX 2613#elif LL_LINUX
2681 query_map["os"] = "lnx"; 2614 query_map["os"] = "lnx";
2682#endif 2615#endif
2683 query_map["userserver"] = gUserServerName; 2616 // *TODO change userserver to be grid on both viewer and sim, since
2617 // userserver no longer exists.
2618 query_map["userserver"] = gGridName;
2684 query_map["channel"] = gChannelName; 2619 query_map["channel"] = gChannelName;
2685 // *TODO constantize this guy 2620 // *TODO constantize this guy
2686 LLURI update_url = LLURI::buildHTTP("secondlife.com", 80, "update.php", query_map); 2621 LLURI update_url = LLURI::buildHTTP("secondlife.com", 80, "update.php", query_map);
@@ -2691,7 +2626,7 @@ void update_dialog_callback(S32 option, void *userdata)
2691 { 2626 {
2692 // We're hosed, bail 2627 // We're hosed, bail
2693 llwarns << "LLDir::getTempFilename() failed" << llendl; 2628 llwarns << "LLDir::getTempFilename() failed" << llendl;
2694 app_force_quit(NULL); 2629 LLAppViewer::instance()->forceQuit();
2695 return; 2630 return;
2696 } 2631 }
2697 2632
@@ -2709,7 +2644,7 @@ void update_dialog_callback(S32 option, void *userdata)
2709 if (!CopyFileA(updater_source.c_str(), update_exe_path.c_str(), FALSE)) 2644 if (!CopyFileA(updater_source.c_str(), update_exe_path.c_str(), FALSE))
2710 { 2645 {
2711 llinfos << "Unable to copy the updater!" << llendl; 2646 llinfos << "Unable to copy the updater!" << llendl;
2712 app_force_quit(NULL); 2647 LLAppViewer::instance()->forceQuit();
2713 return; 2648 return;
2714 } 2649 }
2715 2650
@@ -2742,13 +2677,14 @@ void update_dialog_callback(S32 option, void *userdata)
2742 program_name = "SecondLife"; 2677 program_name = "SecondLife";
2743 } 2678 }
2744 2679
2745 params << " -silent -name \"" << gSecondLife << "\""; 2680 params << " -silent -name \"" << LLAppViewer::instance()->getSecondLifeTitle() << "\"";
2746 params << " -program \"" << program_name << "\""; 2681 params << " -program \"" << program_name << "\"";
2747 } 2682 }
2748 2683
2749 llinfos << "Calling updater: " << update_exe_path << " " << params.str() << llendl; 2684 llinfos << "Calling updater: " << update_exe_path << " " << params.str() << llendl;
2750 2685
2751 remove_marker_file(); // In case updater fails 2686 // *REMOVE:Mani The following call is handled through ~LLAppViewer.
2687 // remove_marker_file(); // In case updater fails
2752 2688
2753 // Use spawn() to run asynchronously 2689 // Use spawn() to run asynchronously
2754 int retval = _spawnl(_P_NOWAIT, update_exe_path.c_str(), update_exe_path.c_str(), params.str().c_str(), NULL); 2690 int retval = _spawnl(_P_NOWAIT, update_exe_path.c_str(), update_exe_path.c_str(), params.str().c_str(), NULL);
@@ -2767,13 +2703,14 @@ void update_dialog_callback(S32 option, void *userdata)
2767 update_exe_path += "/AutoUpdater.app/Contents/MacOS/AutoUpdater' -url \""; 2703 update_exe_path += "/AutoUpdater.app/Contents/MacOS/AutoUpdater' -url \"";
2768 update_exe_path += update_url.asString(); 2704 update_exe_path += update_url.asString();
2769 update_exe_path += "\" -name \""; 2705 update_exe_path += "\" -name \"";
2770 update_exe_path += gSecondLife; 2706 update_exe_path += LLAppViewer::instance()->getSecondLifeTitle();
2771 update_exe_path += "\" &"; 2707 update_exe_path += "\" &";
2772 2708
2773 llinfos << "Calling updater: " << update_exe_path << llendl; 2709 llinfos << "Calling updater: " << update_exe_path << llendl;
2774
2775 remove_marker_file(); // In case updater fails
2776 2710
2711 // *REMOVE:Mani The following call is handled through ~LLAppViewer.
2712 // remove_marker_file(); // In case updater fails
2713
2777 // Run the auto-updater. 2714 // Run the auto-updater.
2778 system(update_exe_path.c_str()); /* Flawfinder: ignore */ 2715 system(update_exe_path.c_str()); /* Flawfinder: ignore */
2779 2716
@@ -2781,16 +2718,18 @@ void update_dialog_callback(S32 option, void *userdata)
2781 OSMessageBox("Automatic updating is not yet implemented for Linux.\n" 2718 OSMessageBox("Automatic updating is not yet implemented for Linux.\n"
2782 "Please download the latest version from www.secondlife.com.", 2719 "Please download the latest version from www.secondlife.com.",
2783 NULL, OSMB_OK); 2720 NULL, OSMB_OK);
2784 remove_marker_file(); 2721
2722 // *REMOVE:Mani The following call is handled through ~LLAppViewer.
2723 // remove_marker_file();
2785 2724
2786#endif 2725#endif
2787 app_force_quit(NULL); 2726 LLAppViewer::instance()->forceQuit();
2788} 2727}
2789 2728
2790void use_circuit_callback(void**, S32 result) 2729void use_circuit_callback(void**, S32 result)
2791{ 2730{
2792 // bail if we're quitting. 2731 // bail if we're quitting.
2793 if(gQuit) return; 2732 if(LLApp::isExiting()) return;
2794 if( !gUseCircuitCallbackCalled ) 2733 if( !gUseCircuitCallbackCalled )
2795 { 2734 {
2796 gUseCircuitCallbackCalled = true; 2735 gUseCircuitCallbackCalled = true;
@@ -3646,6 +3585,8 @@ void reset_login()
3646 if ( gViewerWindow ) 3585 if ( gViewerWindow )
3647 { // Hide menus and normal buttons 3586 { // Hide menus and normal buttons
3648 gViewerWindow->setNormalControlsVisible( FALSE ); 3587 gViewerWindow->setNormalControlsVisible( FALSE );
3588 gLoginMenuBarView->setVisible( TRUE );
3589 gLoginMenuBarView->setEnabled( TRUE );
3649 } 3590 }
3650 3591
3651 // Hide any other stuff 3592 // Hide any other stuff
@@ -3689,3 +3630,8 @@ bool LLStartUp::dispatchURL()
3689 } 3630 }
3690 return false; 3631 return false;
3691} 3632}
3633
3634void login_alert_done(S32 option, void* user_data)
3635{
3636 LLPanelLogin::giveFocus();
3637}