Merge pull request #526 from mc-server/IniFileFix
Fixed cIniFile's SetValue().
This commit is contained in:
commit
1ec9eb564c
@ -867,6 +867,10 @@ ValueName0=SomeOtherValue
|
|||||||
{ Params = "KeyName, Comment", Return = "", Notes = "Adds a comment to be stored in the file under the specified key" },
|
{ Params = "KeyName, Comment", Return = "", Notes = "Adds a comment to be stored in the file under the specified key" },
|
||||||
},
|
},
|
||||||
AddKeyName = { Params = "KeyName", Returns = "number", Notes = "Adds a new key of the specified name. Returns the KeyID of the new key." },
|
AddKeyName = { Params = "KeyName", Returns = "number", Notes = "Adds a new key of the specified name. Returns the KeyID of the new key." },
|
||||||
|
AddValue = { Params = "KeyName, ValueName, Value", Return = "", Notes = "Adds a new value of the specified name to the specified key. If another value of the same name exists in the key, both are kept (nonstandard INI file)" },
|
||||||
|
AddValueB = { Params = "KeyName, ValueName, Value", Return = "", Notes = "Adds a new bool value of the specified name to the specified key. If another value of the same name exists in the key, both are kept (nonstandard INI file)" },
|
||||||
|
AddValueF = { Params = "KeyName, ValueName, Value", Return = "", Notes = "Adds a new float value of the specified name to the specified key. If another value of the same name exists in the key, both are kept (nonstandard INI file)" },
|
||||||
|
AddValueI = { Params = "KeyName, ValueName, Value", Return = "", Notes = "Adds a new integer value of the specified name to the specified key. If another value of the same name exists in the key, both are kept (nonstandard INI file)" },
|
||||||
CaseInsensitive = { Params = "", Return = "", Notes = "Sets key names' and value names' comparisons to case insensitive (default)." },
|
CaseInsensitive = { Params = "", Return = "", Notes = "Sets key names' and value names' comparisons to case insensitive (default)." },
|
||||||
CaseSensitive = { Params = "", Return = "", Notes = "Sets key names and value names comparisons to case sensitive." },
|
CaseSensitive = { Params = "", Return = "", Notes = "Sets key names and value names comparisons to case sensitive." },
|
||||||
Clear = { Params = "", Return = "", Notes = "Removes all the in-memory data. Note that , like all the other operations, this doesn't affect any file data." },
|
Clear = { Params = "", Return = "", Notes = "Removes all the in-memory data. Note that , like all the other operations, this doesn't affect any file data." },
|
||||||
|
@ -137,7 +137,7 @@ bool cIniFile::ReadFile(const AString & a_FileName, bool a_AllowExampleRedirect)
|
|||||||
{
|
{
|
||||||
valuename = line.substr(0, pLeft);
|
valuename = line.substr(0, pLeft);
|
||||||
value = line.substr(pLeft + 1);
|
value = line.substr(pLeft + 1);
|
||||||
SetValue(keyname, valuename, value);
|
AddValue(keyname, valuename, value);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -344,55 +344,79 @@ AString cIniFile::GetValueName(const AString & keyname, const int valueID) const
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cIniFile::SetValue(const int keyID, const int valueID, const AString & value)
|
void cIniFile::AddValue(const AString & a_KeyName, const AString & a_ValueName, const AString & a_Value)
|
||||||
{
|
{
|
||||||
if ((keyID < (int)keys.size()) && (valueID < (int)keys[keyID].names.size()))
|
int keyID = FindKey(a_KeyName);
|
||||||
{
|
|
||||||
keys[keyID].values[valueID] = value;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cIniFile::SetValue(const AString & keyname, const AString & valuename, const AString & value, bool const create)
|
|
||||||
{
|
|
||||||
int keyID = FindKey(keyname);
|
|
||||||
if (keyID == noID)
|
if (keyID == noID)
|
||||||
{
|
{
|
||||||
if (create)
|
keyID = int(AddKeyName(a_KeyName));
|
||||||
{
|
|
||||||
keyID = int(AddKeyName(keyname));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int valueID = FindValue(int(keyID), valuename);
|
keys[keyID].names.push_back(a_ValueName);
|
||||||
if (valueID == noID)
|
keys[keyID].values.push_back(a_Value);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void cIniFile::AddValueI(const AString & a_KeyName, const AString & a_ValueName, const int a_Value)
|
||||||
{
|
{
|
||||||
if (!create)
|
AddValue(a_KeyName, a_ValueName, Printf("%d", a_Value));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void cIniFile::AddValueF(const AString & a_KeyName, const AString & a_ValueName, const double a_Value)
|
||||||
|
{
|
||||||
|
AddValue(a_KeyName, a_ValueName, Printf("%f", a_Value));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
bool cIniFile::SetValue(const int keyID, const int valueID, const AString & value)
|
||||||
|
{
|
||||||
|
if (((size_t)keyID >= keys.size()) || ((size_t)valueID >= keys[keyID].names.size()))
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
keys[keyID].names.resize(keys[keyID].names.size() + 1, valuename);
|
|
||||||
keys[keyID].values.resize(keys[keyID].values.size() + 1, value);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (!create)
|
|
||||||
{
|
|
||||||
keys[keyID].values[valueID] = value;
|
keys[keyID].values[valueID] = value;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
bool cIniFile::SetValue(const AString & a_KeyName, const AString & a_ValueName, const AString & a_Value, const bool a_CreateIfNotExists)
|
||||||
|
{
|
||||||
|
int keyID = FindKey(a_KeyName);
|
||||||
|
if (keyID == noID)
|
||||||
|
{
|
||||||
|
if (!a_CreateIfNotExists)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
keyID = AddKeyName(a_KeyName);
|
||||||
|
}
|
||||||
|
|
||||||
|
int valueID = FindValue(keyID, a_ValueName);
|
||||||
|
if (valueID == noID)
|
||||||
|
{
|
||||||
|
if (!a_CreateIfNotExists)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
keys[keyID].names.push_back(a_ValueName);
|
||||||
|
keys[keyID].values.push_back(a_Value);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
keys[keyID].names.resize(keys[keyID].names.size() + 1, valuename);
|
keys[keyID].values[valueID] = a_Value;
|
||||||
keys[keyID].values.resize(keys[keyID].values.size() + 1, value);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -402,37 +426,32 @@ bool cIniFile::SetValue(const AString & keyname, const AString & valuename, cons
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cIniFile::SetValueI(const AString & keyname, const AString & valuename, const int value, bool const create)
|
bool cIniFile::SetValueI(const AString & a_KeyName, const AString & a_ValueName, const int a_Value, const bool a_CreateIfNotExists)
|
||||||
{
|
{
|
||||||
AString Data;
|
return SetValue(a_KeyName, a_ValueName, Printf("%d", a_Value), a_CreateIfNotExists);
|
||||||
Printf(Data, "%d", value);
|
|
||||||
return SetValue(keyname, valuename, Data, create);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cIniFile::SetValueF(const AString & keyname, const AString & valuename, double const value, bool const create)
|
bool cIniFile::SetValueF(const AString & a_KeyName, const AString & a_ValueName, double const a_Value, const bool a_CreateIfNotExists)
|
||||||
{
|
{
|
||||||
AString Data;
|
return SetValue(a_KeyName, a_ValueName, Printf("%f", a_Value), a_CreateIfNotExists);
|
||||||
Printf(Data, "%f", value);
|
|
||||||
return SetValue(keyname, valuename, Data, create);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cIniFile::SetValueV(const AString & keyname, const AString & valuename, char * format, ...)
|
bool cIniFile::SetValueV(const AString & a_KeyName, const AString & a_ValueName, const char * a_Format, ...)
|
||||||
{
|
{
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, format);
|
va_start(args, a_Format);
|
||||||
|
|
||||||
AString Data;
|
AString Data;
|
||||||
AppendVPrintf(Data, format, args);
|
AppendVPrintf(Data, a_Format, args);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
return SetValue(keyname, valuename, Data);
|
return SetValue(a_KeyName, a_ValueName, Data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -122,22 +122,32 @@ public:
|
|||||||
return (GetValueSetI(keyname, valuename, defValue ? 1 : 0) != 0);
|
return (GetValueSetI(keyname, valuename, defValue ? 1 : 0) != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sets value of [keyname] valuename =.
|
// Adds a new value to the specified key.
|
||||||
// Specify the optional paramter as false (0) if you do not want it to create
|
// If a value of the same name already exists, creates another one (non-standard INI file)
|
||||||
// the key if it doesn't exist. Returns true if data entered, false otherwise.
|
void AddValue (const AString & a_KeyName, const AString & a_ValueName, const AString & a_Value);
|
||||||
|
void AddValueI(const AString & a_KeyName, const AString & a_ValueName, const int a_Value);
|
||||||
|
void AddValueB(const AString & a_KeyName, const AString & a_ValueName, const bool a_Value)
|
||||||
|
{
|
||||||
|
return AddValueI(a_KeyName, a_ValueName, a_Value ? 1 : 0);
|
||||||
|
}
|
||||||
|
void AddValueF(const AString & a_KeyName, const AString & a_ValueName, const double a_Value);
|
||||||
|
|
||||||
|
// Overwrites the value of [keyname].valuename
|
||||||
|
// Specify the optional parameter as false (0) if you do not want the value created if it doesn't exist.
|
||||||
|
// Returns true if value set, false otherwise.
|
||||||
// Overloaded to accept string, int, and double.
|
// Overloaded to accept string, int, and double.
|
||||||
bool SetValue (const int keyID, const int valueID, const AString & value);
|
bool SetValue (const int keyID, const int valueID, const AString & value);
|
||||||
bool SetValue( const AString & keyname, const AString & valuename, const AString & value, const bool create = true);
|
bool SetValue (const AString & a_KeyName, const AString & a_ValueName, const AString & a_Value, const bool a_CreateIfNotExists = true);
|
||||||
bool SetValueI( const AString & keyname, const AString & valuename, const int value, const bool create = true);
|
bool SetValueI(const AString & a_KeyName, const AString & a_ValueName, const int a_Value, const bool a_CreateIfNotExists = true);
|
||||||
bool SetValueB( const AString & keyname, const AString & valuename, const bool value, const bool create = true)
|
bool SetValueB(const AString & a_KeyName, const AString & a_ValueName, const bool a_Value, const bool a_CreateIfNotExists = true)
|
||||||
{
|
{
|
||||||
return SetValueI( keyname, valuename, int(value), create);
|
return SetValueI(a_KeyName, a_ValueName, int(a_Value), a_CreateIfNotExists);
|
||||||
}
|
}
|
||||||
bool SetValueF( const AString & keyname, const AString & valuename, const double value, const bool create = true);
|
bool SetValueF(const AString & a_KeyName, const AString & a_ValueName, const double a_Value, const bool a_CreateIfNotExists = true);
|
||||||
|
|
||||||
// tolua_end
|
// tolua_end
|
||||||
|
|
||||||
bool SetValueV( const AString & keyname, const AString & valuename, char *format, ...);
|
bool SetValueV( const AString & a_KeyName, const AString & a_ValueName, const char * a_Format, ...);
|
||||||
|
|
||||||
// tolua_begin
|
// tolua_begin
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user