diff options
Diffstat (limited to 'linden/indra/newview/llappviewer.cpp')
-rw-r--r-- | linden/indra/newview/llappviewer.cpp | 56 |
1 files changed, 45 insertions, 11 deletions
diff --git a/linden/indra/newview/llappviewer.cpp b/linden/indra/newview/llappviewer.cpp index 9851e47..f1b2e32 100644 --- a/linden/indra/newview/llappviewer.cpp +++ b/linden/indra/newview/llappviewer.cpp | |||
@@ -682,12 +682,11 @@ bool LLAppViewer::init() | |||
682 | LLUIImageList::getInstance(), | 682 | LLUIImageList::getInstance(), |
683 | ui_audio_callback, | 683 | ui_audio_callback, |
684 | &LLUI::sGLScaleFactor); | 684 | &LLUI::sGLScaleFactor); |
685 | |||
686 | LLWeb::initClass(); // do this after LLUI | 685 | LLWeb::initClass(); // do this after LLUI |
687 | LLTextEditor::setURLCallbacks(&LLWeb::loadURL, | 686 | LLTextEditor::setURLCallbacks(&LLWeb::loadURL, |
688 | &LLURLDispatcher::dispatchFromTextEditor, | 687 | &LLURLDispatcher::dispatchFromTextEditor, |
689 | &LLURLDispatcher::dispatchFromTextEditor); | 688 | &LLURLDispatcher::dispatchFromTextEditor); |
690 | 689 | ||
691 | LLUICtrlFactory::getInstance()->setupPaths(); // update paths with correct language set | 690 | LLUICtrlFactory::getInstance()->setupPaths(); // update paths with correct language set |
692 | 691 | ||
693 | ///////////////////////////////////////////////// | 692 | ///////////////////////////////////////////////// |
@@ -767,6 +766,8 @@ bool LLAppViewer::init() | |||
767 | CreateLCDDebugWindows(); | 766 | CreateLCDDebugWindows(); |
768 | #endif | 767 | #endif |
769 | 768 | ||
769 | LLFolderViewItem::initClass(); // SJB: Needs to happen after initWindow(), not sure why but related to fonts | ||
770 | |||
770 | gGLManager.getGLInfo(gDebugInfo); | 771 | gGLManager.getGLInfo(gDebugInfo); |
771 | gGLManager.printGLInfoString(); | 772 | gGLManager.printGLInfoString(); |
772 | 773 | ||
@@ -941,6 +942,7 @@ bool LLAppViewer::mainLoop() | |||
941 | LLFastTimer t3(LLFastTimer::FTM_IDLE); | 942 | LLFastTimer t3(LLFastTimer::FTM_IDLE); |
942 | idle(); | 943 | idle(); |
943 | 944 | ||
945 | if (gAres != NULL && gAres->isInitialized()) | ||
944 | { | 946 | { |
945 | pingMainloopTimeout("Main:ServicePump"); | 947 | pingMainloopTimeout("Main:ServicePump"); |
946 | LLFastTimer t4(LLFastTimer::FTM_PUMP); | 948 | LLFastTimer t4(LLFastTimer::FTM_PUMP); |
@@ -1077,14 +1079,17 @@ bool LLAppViewer::mainLoop() | |||
1077 | 1079 | ||
1078 | } | 1080 | } |
1079 | catch(std::bad_alloc) | 1081 | catch(std::bad_alloc) |
1080 | { | 1082 | { |
1081 | llwarns << "Bad memory allocation in LLAppViewer::mainLoop()!" << llendl ; | ||
1082 | |||
1083 | //stop memory leaking simulation | 1083 | //stop memory leaking simulation |
1084 | if(LLFloaterMemLeak::getInstance()) | 1084 | if(LLFloaterMemLeak::getInstance()) |
1085 | { | 1085 | { |
1086 | LLFloaterMemLeak::getInstance()->stop() ; | 1086 | LLFloaterMemLeak::getInstance()->stop() ; |
1087 | } | 1087 | llwarns << "Bad memory allocation in LLAppViewer::mainLoop()!" << llendl ; |
1088 | } | ||
1089 | else | ||
1090 | { | ||
1091 | llerrs << "Bad memory allocation in LLAppViewer::mainLoop()!" << llendl ; | ||
1092 | } | ||
1088 | } | 1093 | } |
1089 | } | 1094 | } |
1090 | 1095 | ||
@@ -1279,6 +1284,7 @@ bool LLAppViewer::cleanup() | |||
1279 | //LLVolumeMgr::cleanupClass(); | 1284 | //LLVolumeMgr::cleanupClass(); |
1280 | LLPrimitive::cleanupVolumeManager(); | 1285 | LLPrimitive::cleanupVolumeManager(); |
1281 | LLWorldMapView::cleanupClass(); | 1286 | LLWorldMapView::cleanupClass(); |
1287 | LLFolderViewItem::cleanupClass(); | ||
1282 | LLUI::cleanupClass(); | 1288 | LLUI::cleanupClass(); |
1283 | 1289 | ||
1284 | // | 1290 | // |
@@ -1480,7 +1486,7 @@ bool LLAppViewer::initLogging() | |||
1480 | return true; | 1486 | return true; |
1481 | } | 1487 | } |
1482 | 1488 | ||
1483 | void LLAppViewer::loadSettingsFromDirectory(ELLPath path_index, bool set_defaults) | 1489 | bool LLAppViewer::loadSettingsFromDirectory(ELLPath path_index, bool set_defaults) |
1484 | { | 1490 | { |
1485 | for(LLSD::map_iterator itr = mSettingsFileList.beginMap(); itr != mSettingsFileList.endMap(); ++itr) | 1491 | for(LLSD::map_iterator itr = mSettingsFileList.beginMap(); itr != mSettingsFileList.endMap(); ++itr) |
1486 | { | 1492 | { |
@@ -1515,13 +1521,24 @@ void LLAppViewer::loadSettingsFromDirectory(ELLPath path_index, bool set_default | |||
1515 | } | 1521 | } |
1516 | if(!gSettings[settings_name]->loadFromFile(full_settings_path, set_defaults)) | 1522 | if(!gSettings[settings_name]->loadFromFile(full_settings_path, set_defaults)) |
1517 | { | 1523 | { |
1518 | llwarns << "Cannot load " << full_settings_path << " - No settings found." << llendl; | 1524 | // If attempting to load the default global settings (app_settings/settings.xml) |
1525 | // fails, the app should error and quit. | ||
1526 | if(path_index == LL_PATH_APP_SETTINGS && settings_name == sGlobalSettingsName) | ||
1527 | { | ||
1528 | llwarns << "Error: Cannot load default settings from: " << full_settings_path << llendl; | ||
1529 | return false; | ||
1530 | } | ||
1531 | else | ||
1532 | { | ||
1533 | llwarns << "Cannot load " << full_settings_path << " - No settings found." << llendl; | ||
1534 | } | ||
1519 | } | 1535 | } |
1520 | else | 1536 | else |
1521 | { | 1537 | { |
1522 | llinfos << "Loaded settings file " << full_settings_path << llendl; | 1538 | llinfos << "Loaded settings file " << full_settings_path << llendl; |
1523 | } | 1539 | } |
1524 | } | 1540 | } |
1541 | return true; | ||
1525 | } | 1542 | } |
1526 | 1543 | ||
1527 | std::string LLAppViewer::getSettingsFileName(const std::string& file) | 1544 | std::string LLAppViewer::getSettingsFileName(const std::string& file) |
@@ -1563,7 +1580,19 @@ bool LLAppViewer::initConfiguration() | |||
1563 | 1580 | ||
1564 | // - load defaults | 1581 | // - load defaults |
1565 | bool set_defaults = true; | 1582 | bool set_defaults = true; |
1566 | loadSettingsFromDirectory(LL_PATH_APP_SETTINGS, set_defaults); | 1583 | if(!loadSettingsFromDirectory(LL_PATH_APP_SETTINGS, set_defaults)) |
1584 | { | ||
1585 | std::ostringstream msg; | ||
1586 | msg << "Second Life could not load its default settings file. \n" | ||
1587 | << "The installation may be corrupted. \n"; | ||
1588 | |||
1589 | OSMessageBox( | ||
1590 | msg.str(), | ||
1591 | LLStringUtil::null, | ||
1592 | OSMB_OK); | ||
1593 | |||
1594 | return false; | ||
1595 | } | ||
1567 | 1596 | ||
1568 | // - set procedural settings | 1597 | // - set procedural settings |
1569 | gSavedSettings.setString("ClientSettingsFile", | 1598 | gSavedSettings.setString("ClientSettingsFile", |
@@ -1710,7 +1739,7 @@ bool LLAppViewer::initConfiguration() | |||
1710 | 1739 | ||
1711 | OSMessageBox( | 1740 | OSMessageBox( |
1712 | msg.str().c_str(), | 1741 | msg.str().c_str(), |
1713 | NULL, | 1742 | LLStringUtil::null, |
1714 | OSMB_OK); | 1743 | OSMB_OK); |
1715 | 1744 | ||
1716 | return false; | 1745 | return false; |
@@ -2331,6 +2360,11 @@ void LLAppViewer::handleViewerCrash() | |||
2331 | { | 2360 | { |
2332 | gDebugInfo["CurrentSimHost"] = gAgent.getRegionHost().getHostName(); | 2361 | gDebugInfo["CurrentSimHost"] = gAgent.getRegionHost().getHostName(); |
2333 | gDebugInfo["CurrentRegion"] = gAgent.getRegion()->getName(); | 2362 | gDebugInfo["CurrentRegion"] = gAgent.getRegion()->getName(); |
2363 | |||
2364 | const LLVector3& loc = gAgent.getPositionAgent(); | ||
2365 | gDebugInfo["CurrentLocationX"] = loc.mV[0]; | ||
2366 | gDebugInfo["CurrentLocationY"] = loc.mV[1]; | ||
2367 | gDebugInfo["CurrentLocationZ"] = loc.mV[2]; | ||
2334 | } | 2368 | } |
2335 | 2369 | ||
2336 | if(LLAppViewer::instance()->mMainloopTimeout) | 2370 | if(LLAppViewer::instance()->mMainloopTimeout) |
@@ -2646,7 +2680,7 @@ bool LLAppViewer::initCache() | |||
2646 | std::string cache_dir = gDirUtilp->getOSUserAppDir(); | 2680 | std::string cache_dir = gDirUtilp->getOSUserAppDir(); |
2647 | std::string new_cache_dir = gDirUtilp->getOSCacheDir(); | 2681 | std::string new_cache_dir = gDirUtilp->getOSCacheDir(); |
2648 | cache_dir = cache_dir + "/cache"; | 2682 | cache_dir = cache_dir + "/cache"; |
2649 | new_cache_dir = new_cache_dir + "/" + gSecondLife; | 2683 | new_cache_dir = new_cache_dir + "/SecondLife"; |
2650 | if (gDirUtilp->fileExists(cache_dir)) | 2684 | if (gDirUtilp->fileExists(cache_dir)) |
2651 | { | 2685 | { |
2652 | gDirUtilp->setCacheDir(cache_dir); | 2686 | gDirUtilp->setCacheDir(cache_dir); |