aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llxml/llcontrol.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llxml/llcontrol.cpp')
-rw-r--r--linden/indra/llxml/llcontrol.cpp35
1 files changed, 18 insertions, 17 deletions
diff --git a/linden/indra/llxml/llcontrol.cpp b/linden/indra/llxml/llcontrol.cpp
index d185987..5504a10 100644
--- a/linden/indra/llxml/llcontrol.cpp
+++ b/linden/indra/llxml/llcontrol.cpp
@@ -69,8 +69,6 @@ std::set<LLControlBase*> LLControlBase::mChangedControls;
69 69
70const S32 CURRENT_VERSION = 101; 70const S32 CURRENT_VERSION = 101;
71 71
72BOOL control_insert_before( LLControlBase* first, LLControlBase* second );
73
74BOOL LLControl::llsd_compare(const LLSD& a, const LLSD & b) 72BOOL LLControl::llsd_compare(const LLSD& a, const LLSD & b)
75{ 73{
76 switch (mType) 74 switch (mType)
@@ -1033,6 +1031,13 @@ U32 LLControlGroup::loadFromFile(const LLString& filename, BOOL require_declarat
1033 return validitems; 1031 return validitems;
1034} 1032}
1035 1033
1034struct compare_controls
1035{
1036 bool operator() (const LLControlBase* const a, const LLControlBase* const b) const
1037 {
1038 return a->getName() < b->getName();
1039 }
1040};
1036 1041
1037U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only) 1042U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only)
1038{ 1043{
@@ -1042,13 +1047,14 @@ U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only)
1042 1047
1043 // place the objects in a temporary container that enforces a sort 1048 // place the objects in a temporary container that enforces a sort
1044 // order to ease manual editing of the file 1049 // order to ease manual editing of the file
1045 LLLinkedList< LLControlBase > controls; 1050
1046 controls.setInsertBefore( &control_insert_before ); 1051 typedef std::set< LLControlBase*, compare_controls > control_list_t;
1047 LLString name; 1052 control_list_t controls;
1053
1048 for (ctrl_name_table_t::iterator iter = mNameTable.begin(); 1054 for (ctrl_name_table_t::iterator iter = mNameTable.begin();
1049 iter != mNameTable.end(); iter++) 1055 iter != mNameTable.end(); iter++)
1050 { 1056 {
1051 name = iter->first; 1057 LLString name = iter->first;
1052 if (name.empty()) 1058 if (name.empty())
1053 { 1059 {
1054 CONTROL_ERRS << "Control with no name found!!!" << llendl; 1060 CONTROL_ERRS << "Control with no name found!!!" << llendl;
@@ -1065,7 +1071,7 @@ U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only)
1065 { 1071 {
1066 if (!(nondefault_only && (control->mIsDefault))) 1072 if (!(nondefault_only && (control->mIsDefault)))
1067 { 1073 {
1068 controls.addDataSorted( control ); 1074 controls.insert( control );
1069 } 1075 }
1070 else 1076 else
1071 { 1077 {
@@ -1088,12 +1094,12 @@ U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only)
1088 // Write file version 1094 // Write file version
1089 file << "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"yes\"?>\n"; 1095 file << "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"yes\"?>\n";
1090 file << "<settings version = \"" << CURRENT_VERSION << "\">\n"; 1096 file << "<settings version = \"" << CURRENT_VERSION << "\">\n";
1091 for( LLControlBase* control = controls.getFirstData(); 1097 for (control_list_t::iterator iter = controls.begin();
1092 control != NULL; 1098 iter != controls.end(); ++iter)
1093 control = controls.getNextData() )
1094 { 1099 {
1100 LLControlBase* control = *iter;
1095 file << "\t<!--" << control->comment() << "-->" << ENDL; 1101 file << "\t<!--" << control->comment() << "-->" << ENDL;
1096 name = control->name(); 1102 LLString name = control->getName();
1097 switch (control->type()) 1103 switch (control->type())
1098 { 1104 {
1099 case TYPE_U32: 1105 case TYPE_U32:
@@ -1165,7 +1171,7 @@ U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only)
1165 file << "</settings>\n"; 1171 file << "</settings>\n";
1166 file.close(); 1172 file.close();
1167 1173
1168 return controls.getLength(); 1174 return controls.size();
1169} 1175}
1170 1176
1171void LLControlGroup::applyOverrides(const std::map<std::string, std::string>& overrides) 1177void LLControlGroup::applyOverrides(const std::map<std::string, std::string>& overrides)
@@ -1435,8 +1441,3 @@ void main()
1435} 1441}
1436#endif 1442#endif
1437 1443
1438BOOL control_insert_before( LLControlBase* first, LLControlBase* second )
1439{
1440 return ( first->getName().compare(second->getName()) < 0 );
1441}
1442