diff options
Diffstat (limited to 'linden/indra/newview/llpanellogin.cpp')
-rw-r--r-- | linden/indra/newview/llpanellogin.cpp | 61 |
1 files changed, 28 insertions, 33 deletions
diff --git a/linden/indra/newview/llpanellogin.cpp b/linden/indra/newview/llpanellogin.cpp index d8da3c0..065e429 100644 --- a/linden/indra/newview/llpanellogin.cpp +++ b/linden/indra/newview/llpanellogin.cpp | |||
@@ -777,9 +777,8 @@ void LLPanelLogin::getFields(LLString &firstname, LLString &lastname, LLString & | |||
777 | remember = sInstance->childGetValue("remember_check"); | 777 | remember = sInstance->childGetValue("remember_check"); |
778 | } | 778 | } |
779 | 779 | ||
780 | 780 | // static | |
781 | // static. Return TRUE if user made a choice from the popup | 781 | BOOL LLPanelLogin::isGridComboDirty() |
782 | BOOL LLPanelLogin::getServer(LLString &server, S32 &domain_name) | ||
783 | { | 782 | { |
784 | BOOL user_picked = FALSE; | 783 | BOOL user_picked = FALSE; |
785 | if (!sInstance) | 784 | if (!sInstance) |
@@ -789,25 +788,8 @@ BOOL LLPanelLogin::getServer(LLString &server, S32 &domain_name) | |||
789 | else | 788 | else |
790 | { | 789 | { |
791 | LLComboBox* combo = sInstance->getChild<LLComboBox>("server_combo"); | 790 | LLComboBox* combo = sInstance->getChild<LLComboBox>("server_combo"); |
792 | LLSD combo_val = combo->getValue(); | ||
793 | if (LLSD::TypeInteger == combo_val.type()) | ||
794 | { | ||
795 | domain_name = combo->getValue().asInteger(); | ||
796 | |||
797 | if ((S32)GRID_INFO_OTHER == domain_name) | ||
798 | { | ||
799 | server = LLViewerLogin::getInstance()->getGridLabel(); | ||
800 | } | ||
801 | } | ||
802 | else | ||
803 | { | ||
804 | // no valid selection, return other | ||
805 | domain_name = (S32)GRID_INFO_OTHER; | ||
806 | server = combo_val.asString(); | ||
807 | } | ||
808 | user_picked = combo->isDirty(); | 791 | user_picked = combo->isDirty(); |
809 | } | 792 | } |
810 | |||
811 | return user_picked; | 793 | return user_picked; |
812 | } | 794 | } |
813 | 795 | ||
@@ -941,19 +923,13 @@ void LLPanelLogin::loadLoginPage() | |||
941 | curl_free(curl_version); | 923 | curl_free(curl_version); |
942 | 924 | ||
943 | // Grid | 925 | // Grid |
944 | LLString grid; | 926 | char* curl_grid = curl_escape(LLViewerLogin::getInstance()->getGridLabel().c_str(), 0); |
945 | S32 grid_index; | 927 | oStr << "&grid=" << curl_grid; |
946 | getServer( grid, grid_index ); | 928 | curl_free(curl_grid); |
947 | 929 | ||
948 | gViewerWindow->setMenuBackgroundColor(false, !LLViewerLogin::getInstance()->isInProductionGrid()); | 930 | gViewerWindow->setMenuBackgroundColor(false, !LLViewerLogin::getInstance()->isInProductionGrid()); |
949 | gLoginMenuBarView->setBackgroundColor(gMenuBarView->getBackgroundColor()); | 931 | gLoginMenuBarView->setBackgroundColor(gMenuBarView->getBackgroundColor()); |
950 | 932 | ||
951 | if (!grid.empty()) | ||
952 | { | ||
953 | char* curl_grid = curl_escape(grid.c_str(), 0); | ||
954 | oStr << "&grid=" << curl_grid; | ||
955 | curl_free(curl_grid); | ||
956 | } | ||
957 | 933 | ||
958 | #if USE_VIEWER_AUTH | 934 | #if USE_VIEWER_AUTH |
959 | LLURLSimString::sInstance.parse(); | 935 | LLURLSimString::sInstance.parse(); |
@@ -1167,9 +1143,29 @@ void LLPanelLogin::onSelectServer(LLUICtrl*, void*) | |||
1167 | { | 1143 | { |
1168 | // The user twiddled with the grid choice ui. | 1144 | // The user twiddled with the grid choice ui. |
1169 | // apply the selection to the grid setting. | 1145 | // apply the selection to the grid setting. |
1170 | LLString grid; | 1146 | LLString grid_label; |
1171 | S32 grid_index; | 1147 | S32 grid_index; |
1172 | getServer( grid, grid_index ); | 1148 | |
1149 | LLComboBox* combo = sInstance->getChild<LLComboBox>("server_combo"); | ||
1150 | LLSD combo_val = combo->getValue(); | ||
1151 | |||
1152 | if (LLSD::TypeInteger == combo_val.type()) | ||
1153 | { | ||
1154 | grid_index = combo->getValue().asInteger(); | ||
1155 | |||
1156 | if ((S32)GRID_INFO_OTHER == grid_index) | ||
1157 | { | ||
1158 | // This happens if the user specifies a custom grid | ||
1159 | // via command line. | ||
1160 | grid_label = combo->getSimple(); | ||
1161 | } | ||
1162 | } | ||
1163 | else | ||
1164 | { | ||
1165 | // no valid selection, return other | ||
1166 | grid_index = (S32)GRID_INFO_OTHER; | ||
1167 | grid_label = combo_val.asString(); | ||
1168 | } | ||
1173 | 1169 | ||
1174 | // This new seelction will override preset uris | 1170 | // This new seelction will override preset uris |
1175 | // from the command line. | 1171 | // from the command line. |
@@ -1178,11 +1174,10 @@ void LLPanelLogin::onSelectServer(LLUICtrl*, void*) | |||
1178 | if(grid_index != GRID_INFO_OTHER) | 1174 | if(grid_index != GRID_INFO_OTHER) |
1179 | { | 1175 | { |
1180 | vl->setGridChoice((EGridInfo)grid_index); | 1176 | vl->setGridChoice((EGridInfo)grid_index); |
1181 | grid = vl->getGridLabel(); | ||
1182 | } | 1177 | } |
1183 | else | 1178 | else |
1184 | { | 1179 | { |
1185 | vl->setGridChoice(grid); | 1180 | vl->setGridChoice(grid_label); |
1186 | } | 1181 | } |
1187 | 1182 | ||
1188 | // grid changed so show new splash screen (possibly) | 1183 | // grid changed so show new splash screen (possibly) |