diff options
Diffstat (limited to 'iniFile')
-rw-r--r-- | iniFile/iniFile.cpp | 806 | ||||
-rw-r--r-- | iniFile/iniFile.h | 217 |
2 files changed, 0 insertions, 1023 deletions
diff --git a/iniFile/iniFile.cpp b/iniFile/iniFile.cpp deleted file mode 100644 index 5ecbc5e06..000000000 --- a/iniFile/iniFile.cpp +++ /dev/null @@ -1,806 +0,0 @@ -// IniFile.cpp: Implementation of the CIniFile class. -// Written by: Adam Clauss -// Email: cabadam@houston.rr.com -// You may use this class/code as you wish in your programs. Feel free to distribute it, and -// email suggested changes to me. -// -// Rewritten by: Shane Hill -// Date: 21/08/2001 -// Email: Shane.Hill@dsto.defence.gov.au -// Reason: Remove dependancy on MFC. Code should compile on any -// platform. -////////////////////////////////////////////////////////////////////// - -/* -!! MODIFIED BY FAKETRUTH and xoft !! -*/ - -#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules - -// C++ Includes -#include <fstream> - -// C Includes -#include <ctype.h> - -// Local Includes -#include "iniFile.h" - -#if defined(WIN32) - #define iniEOL endl -#else - #define iniEOL '\r' << endl -#endif - -#ifndef _WIN32 - #define sscanf_s(buffer, stringbuffer, ...) (sscanf(buffer, stringbuffer, __VA_ARGS__)) -#endif - -using namespace std; - - - - - -cIniFile::cIniFile(const string & a_Path) : - m_IsCaseInsensitive(true) -{ - Path(a_Path); -} - - - - - -bool cIniFile::ReadFile(bool a_AllowExampleRedirect) -{ - // Normally you would use ifstream, but the SGI CC compiler has - // a few bugs with ifstream. So ... fstream used. - fstream f; - string line; - string keyname, valuename, value; - string::size_type pLeft, pRight; - bool IsFromExampleRedirect = false; - - f.open((FILE_IO_PREFIX + m_Path).c_str(), ios::in); - if (f.fail()) - { - f.clear(); - if (a_AllowExampleRedirect) - { - // Retry with the .example.ini file instead of .ini: - string ExPath(m_Path.substr(0, m_Path.length() - 4)); - ExPath.append(".example.ini"); - f.open((FILE_IO_PREFIX + ExPath).c_str(), ios::in); - if (f.fail()) - { - return false; - } - IsFromExampleRedirect = true; - } - else - { - return false; - } - } - - while (getline(f, line)) - { - // To be compatible with Win32, check for existence of '\r'. - // Win32 files have the '\r' and Unix files don't at the end of a line. - // Note that the '\r' will be written to INI files from - // Unix so that the created INI file can be read under Win32 - // without change. - unsigned int lineLength = line.length(); - if (lineLength == 0) - { - continue; - } - if (line[lineLength - 1] == '\r') - { - line = line.substr(0, lineLength - 1); - } - - if (line.length() == 0) - { - continue; - } - - // Check that the user hasn't opened a binary file by checking the first - // character of each line! - if (!isprint(line[0])) - { - printf("%s: Binary-check failed on char %d\n", __FUNCTION__, line[0]); - f.close(); - return false; - } - if ((pLeft = line.find_first_of(";#[=")) == string::npos) - { - continue; - } - - switch (line[pLeft]) - { - case '[': - { - if ( - ((pRight = line.find_last_of("]")) != string::npos) && - (pRight > pLeft) - ) - { - keyname = line.substr(pLeft + 1, pRight - pLeft - 1); - AddKeyName(keyname); - } - break; - } - - case '=': - { - valuename = line.substr(0, pLeft); - value = line.substr(pLeft + 1); - SetValue(keyname, valuename, value); - break; - } - - case ';': - case '#': - { - if (names.size() == 0) - { - HeaderComment(line.substr(pLeft + 1)); - } - else - { - KeyComment(keyname, line.substr(pLeft + 1)); - } - break; - } - } // switch (line[pLeft]) - } // while (getline()) - - f.close(); - if (names.size() == 0) - { - return false; - } - - if (IsFromExampleRedirect) - { - WriteFile(); - } - return true; -} - - - - - -bool cIniFile::WriteFile(void) const -{ - unsigned commentID, keyID, valueID; - // Normally you would use ofstream, but the SGI CC compiler has - // a few bugs with ofstream. So ... fstream used. - fstream f; - - f.open((FILE_IO_PREFIX + m_Path).c_str(), ios::out); - if (f.fail()) - { - return false; - } - - // Write header comments. - for (commentID = 0; commentID < comments.size(); ++commentID) - { - f << ';' << comments[commentID] << iniEOL; - } - if (comments.size()) - { - f << iniEOL; - } - - // Write keys and values. - for (keyID = 0; keyID < keys.size(); ++keyID) - { - f << '[' << names[keyID] << ']' << iniEOL; - - // Comments. - for (commentID = 0; commentID < keys[keyID].comments.size(); ++commentID) - { - f << ';' << keys[keyID].comments[commentID] << iniEOL; - } - - // Values. - for (valueID = 0; valueID < keys[keyID].names.size(); ++valueID) - { - f << keys[keyID].names[valueID] << '=' << keys[keyID].values[valueID] << iniEOL; - } - f << iniEOL; - } - f.close(); - - return true; -} - - - - - -long cIniFile::FindKey(const string & a_KeyName) const -{ - string CaseKeyName = CheckCase(a_KeyName); - for (unsigned keyID = 0; keyID < names.size(); ++keyID) - { - if (CheckCase(names[keyID]) == CaseKeyName) - { - return long(keyID); - } - } - return noID; -} - - - - - -long cIniFile::FindValue(unsigned const keyID, const string & a_ValueName) const -{ - if (!keys.size() || (keyID >= keys.size())) - { - return noID; - } - - string CaseValueName = CheckCase(a_ValueName); - for (unsigned valueID = 0; valueID < keys[keyID].names.size(); ++valueID) - { - if (CheckCase(keys[keyID].names[valueID]) == CaseValueName) - { - return long(valueID); - } - } - return noID; -} - - - - - -unsigned cIniFile::AddKeyName(const string & keyname) -{ - names.resize(names.size() + 1, keyname); - keys.resize(keys.size() + 1); - return names.size() - 1; -} - - - - - -string cIniFile::KeyName(unsigned const keyID) const -{ - if (keyID < names.size()) - { - return names[keyID]; - } - else - { - return ""; - } -} - - - - - -unsigned cIniFile::NumValues(unsigned const keyID) -{ - if (keyID < keys.size()) - { - return keys[keyID].names.size(); - } - return 0; -} - - - - - -unsigned cIniFile::NumValues(const string & keyname) -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - return 0; - } - return keys[keyID].names.size(); -} - - - - - -string cIniFile::ValueName(unsigned const keyID, unsigned const valueID) const -{ - if (keyID < keys.size() && valueID < keys[keyID].names.size()) - { - return keys[keyID].names[valueID]; - } - return ""; -} - - - - - -string cIniFile::ValueName(const string & keyname, unsigned const valueID) const -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - return ""; - } - return ValueName(keyID, valueID); -} - - - - - -bool cIniFile::SetValue(unsigned const keyID, unsigned const valueID, const string & value) -{ - if ((keyID < keys.size()) && (valueID < keys[keyID].names.size())) - { - keys[keyID].values[valueID] = value; - } - return false; -} - - - - - -bool cIniFile::SetValue(const string & keyname, const string & valuename, const string & value, bool const create) -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - if (create) - { - keyID = long(AddKeyName(keyname)); - } - else - { - return false; - } - } - - long valueID = FindValue(unsigned(keyID), valuename); - if (valueID == noID) - { - if (!create) - { - 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; - } - else - { - keys[keyID].names.resize(keys[keyID].names.size() + 1, valuename); - keys[keyID].values.resize(keys[keyID].values.size() + 1, value); - } - } - - return true; -} - - - - - -bool cIniFile::SetValueI(const string & keyname, const string & valuename, int const value, bool const create) -{ - AString Data; - Printf(Data, "%d", value); - return SetValue(keyname, valuename, Data, create); -} - - - - - -bool cIniFile::SetValueF(const string & keyname, const string & valuename, double const value, bool const create) -{ - AString Data; - Printf(Data, "%f", value); - return SetValue(keyname, valuename, Data, create); -} - - - - - -bool cIniFile::SetValueV(const string & keyname, const string & valuename, char * format, ...) -{ - va_list args; - va_start(args, format); - - AString Data; - AppendVPrintf(Data, format, args); - va_end(args); - return SetValue(keyname, valuename, Data); -} - - - - - -string cIniFile::GetValue(unsigned const keyID, unsigned const valueID, const string & defValue) const -{ - if ((keyID < keys.size()) && (valueID < keys[keyID].names.size())) - { - return keys[keyID].values[valueID]; - } - return defValue; -} - - - - - -string cIniFile::GetValue(const string & keyname, const string & valuename, const string & defValue) const -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - return defValue; - } - - long valueID = FindValue(unsigned(keyID), valuename); - if (valueID == noID) - { - return defValue; - } - - return keys[keyID].values[valueID]; -} - - - - - -int cIniFile::GetValueI(const string & keyname, const string & valuename, int const defValue) const -{ - AString Data; - Printf(Data, "%d", defValue); - return atoi(GetValue(keyname, valuename, Data).c_str()); -} - - - - - -double cIniFile::GetValueF(const string & keyname, const string & valuename, double const defValue) const -{ - AString Data; - Printf(Data, "%f", defValue); - return atof(GetValue(keyname, valuename, Data).c_str()); -} - - - - - -AString cIniFile::GetValueSet(const AString & keyname, const AString & valuename, const AString & defValue) -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - SetValue(keyname, valuename, defValue); - return defValue; - } - - long valueID = FindValue(unsigned(keyID), valuename); - if (valueID == noID) - { - SetValue(keyname, valuename, defValue); - return defValue; - } - - return keys[keyID].values[valueID]; -} - - - - - -double cIniFile::GetValueSetF(const AString & keyname, const AString & valuename, const double defValue) -{ - AString Data; - Printf(Data, "%f", defValue); - return atof(GetValueSet(keyname, valuename, Data).c_str()); -} - - - - - -int cIniFile::GetValueSetI(const AString & keyname, const AString & valuename, const int defValue) -{ - AString Data; - Printf(Data, "%d", defValue); - return atoi(GetValueSet(keyname, valuename, Data).c_str()); -} - - - - - -bool cIniFile::DeleteValueByID(const unsigned keyID, const unsigned valueID) -{ - if (keyID < keys.size() && valueID < keys[keyID].names.size()) - { - // This looks strange, but is neccessary. - vector<string>::iterator npos = keys[keyID].names.begin() + valueID; - vector<string>::iterator vpos = keys[keyID].values.begin() + valueID; - keys[keyID].names.erase(npos, npos + 1); - keys[keyID].values.erase(vpos, vpos + 1); - return true; - } - return false; -} - - - - - -bool cIniFile::DeleteValue(const string & keyname, const string & valuename) -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - return false; - } - - long valueID = FindValue(unsigned(keyID), valuename); - if (valueID == noID) - { - return false; - } - - return DeleteValueByID(keyID, valueID); -} - - - - - -bool cIniFile::DeleteKey(const string & keyname) -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - return false; - } - - vector<string>::iterator npos = names.begin() + keyID; - vector<key>::iterator kpos = keys.begin() + keyID; - names.erase(npos, npos + 1); - keys.erase(kpos, kpos + 1); - - return true; -} - - - - - -void cIniFile::Clear(void) -{ - names.clear(); - keys.clear(); - comments.clear(); -} - - - - - -void cIniFile::HeaderComment(const string & comment) -{ - comments.push_back(comment); - // comments.resize(comments.size() + 1, comment); -} - - - - - -string cIniFile::HeaderComment(unsigned const commentID) const -{ - if (commentID < comments.size()) - { - return comments[commentID]; - } - return ""; -} - - - - - -bool cIniFile::DeleteHeaderComment(unsigned commentID) -{ - if (commentID < comments.size()) - { - vector<string>::iterator cpos = comments.begin() + commentID; - comments.erase(cpos, cpos + 1); - return true; - } - return false; -} - - - - - -unsigned cIniFile::NumKeyComments(unsigned const keyID) const -{ - if (keyID < keys.size()) - { - return keys[keyID].comments.size(); - } - return 0; -} - - - - - -unsigned cIniFile::NumKeyComments(const string & keyname) const -{ - long keyID = FindKey(keyname); - if (keyID == noID) - return 0; - return keys[keyID].comments.size(); -} - - - - - -bool cIniFile::KeyComment(unsigned const keyID, const string & comment) -{ - if (keyID < keys.size()) - { - keys[keyID].comments.resize(keys[keyID].comments.size() + 1, comment); - return true; - } - return false; -} - - - - - -bool cIniFile::KeyComment(const string & keyname, const string & comment) -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - return false; - } - return KeyComment(unsigned(keyID), comment); -} - - - - - -string cIniFile::KeyComment(unsigned const keyID, unsigned const commentID) const -{ - if ((keyID < keys.size()) && (commentID < keys[keyID].comments.size())) - { - return keys[keyID].comments[commentID]; - } - return ""; -} - - - - - -string cIniFile::KeyComment(const string & keyname, unsigned const commentID) const -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - return ""; - } - return KeyComment(unsigned(keyID), commentID); -} - - - - - -bool cIniFile::DeleteKeyComment(unsigned const keyID, unsigned const commentID) -{ - if ((keyID < keys.size()) && (commentID < keys[keyID].comments.size())) - { - vector<string>::iterator cpos = keys[keyID].comments.begin() + commentID; - keys[keyID].comments.erase(cpos, cpos + 1); - return true; - } - return false; -} - - - - - -bool cIniFile::DeleteKeyComment(const string & keyname, unsigned const commentID) -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - return false; - } - return DeleteKeyComment(unsigned(keyID), commentID); -} - - - - - -bool cIniFile::DeleteKeyComments(unsigned const keyID) -{ - if (keyID < keys.size()) - { - keys[keyID].comments.clear(); - return true; - } - return false; -} - - - - - -bool cIniFile::DeleteKeyComments(const string & keyname) -{ - long keyID = FindKey(keyname); - if (keyID == noID) - { - return false; - } - return DeleteKeyComments(unsigned(keyID)); -} - - - - - -string cIniFile::CheckCase(const string & s) const -{ - if (!m_IsCaseInsensitive) - { - return s; - } - string res(s); - size_t len = res.length(); - for (size_t i = 0; i < len; i++) - { - res[i] = tolower(res[i]); - } - return res; -} - - - - diff --git a/iniFile/iniFile.h b/iniFile/iniFile.h deleted file mode 100644 index aef45c094..000000000 --- a/iniFile/iniFile.h +++ /dev/null @@ -1,217 +0,0 @@ -// IniFile.cpp: Implementation of the CIniFile class. -// Written by: Adam Clauss -// Email: cabadam@tamu.edu -// You may use this class/code as you wish in your programs. Feel free to distribute it, and -// email suggested changes to me. -// -// Rewritten by: Shane Hill -// Date: 21/08/2001 -// Email: Shane.Hill@dsto.defence.gov.au -// Reason: Remove dependancy on MFC. Code should compile on any -// platform. Tested on Windows/Linux/Irix -////////////////////////////////////////////////////////////////////// - -/* -!! MODIFIED BY FAKETRUTH and madmaxoft!! -*/ - -#ifndef CIniFile_H -#define CIniFile_H - - - - - -#define MAX_KEYNAME 128 -#define MAX_VALUENAME 128 -#define MAX_VALUEDATA 2048 - - - - - -// tolua_begin - -class cIniFile -{ -private: - bool m_IsCaseInsensitive; - std::string m_Path; - - struct key - { - std::vector<std::string> names; - std::vector<std::string> values; - std::vector<std::string> comments; - } ; - - std::vector<key> keys; - std::vector<std::string> names; - std::vector<std::string> comments; - - /// If the object is case-insensitive, returns s as lowercase; otherwise returns s as-is - std::string CheckCase(const std::string & s) const; - -public: - enum errors - { - noID = -1, - }; - - /// Creates a new instance; sets m_Path to a_Path, but doesn't read the file - cIniFile(const std::string & a_Path = ""); - - // Sets whether or not keynames and valuenames should be case sensitive. - // The default is case insensitive. - void CaseSensitive (void) { m_IsCaseInsensitive = false; } - void CaseInsensitive(void) { m_IsCaseInsensitive = true; } - - // Sets path of ini file to read and write from. - void Path(const std::string & newPath) {m_Path = newPath;} - const std::string & Path(void) const {return m_Path;} - void SetPath(const std::string & newPath) {Path(newPath);} - - /** Reads the ini file specified in m_Path - If the file doesn't exist and a_AllowExampleRedirect is true, tries to read <basename>.example.ini, and - writes its contents as <basename>.ini, if successful. - Returns true if successful, false otherwise. - */ - bool ReadFile(bool a_AllowExampleRedirect = true); - - /// Writes data stored in class to ini file specified in m_Path - bool WriteFile(void) const; - - /// Deletes all stored ini data (but doesn't touch the file) - void Clear(void); - void Reset(void) { Clear(); } - void Erase(void) { Clear(); } // OBSOLETE, this name is misguiding and will be removed from the interface - - /// Returns index of specified key, or noID if not found - long FindKey(const std::string & keyname) const; - - /// Returns index of specified value, in the specified key, or noID if not found - long FindValue(const unsigned keyID, const std::string & valuename) const; - - /// Returns number of keys currently in the ini - unsigned NumKeys (void) const {return names.size();} - unsigned GetNumKeys(void) const {return NumKeys();} - - /// Add a key name - unsigned AddKeyName(const std::string & keyname); - - // Returns key names by index. - std::string KeyName(const unsigned keyID) const; - std::string GetKeyName(const unsigned keyID) const {return KeyName(keyID);} - - // Returns number of values stored for specified key. - unsigned NumValues (const std::string & keyname); - unsigned GetNumValues(const std::string & keyname) {return NumValues(keyname);} - unsigned NumValues (const unsigned keyID); - unsigned GetNumValues(const unsigned keyID) {return NumValues(keyID);} - - // Returns value name by index for a given keyname or keyID. - std::string ValueName( const std::string & keyname, const unsigned valueID) const; - std::string GetValueName( const std::string & keyname, const unsigned valueID) const - { - return ValueName(keyname, valueID); - } - std::string ValueName (const unsigned keyID, const unsigned valueID) const; - std::string GetValueName(const unsigned keyID, const unsigned valueID) const - { - return ValueName(keyID, valueID); - } - - // Gets value of [keyname] valuename =. - // Overloaded to return string, int, and double. - // Returns defValue if key/value not found. - AString GetValue (const AString & keyname, const AString & valuename, const AString & defValue = "") const; - AString GetValue (const unsigned keyID, const unsigned valueID, const AString & defValue = "") const; - double GetValueF(const AString & keyname, const AString & valuename, const double defValue = 0) const; - int GetValueI(const AString & keyname, const AString & valuename, const int defValue = 0) const; - bool GetValueB(const AString & keyname, const AString & valuename, const bool defValue = false) const - { - return (GetValueI(keyname, valuename, int(defValue)) > 0); - } - - // Gets the value; if not found, write the default to the INI file - AString GetValueSet (const AString & keyname, const AString & valuename, const AString & defValue = ""); - double GetValueSetF(const AString & keyname, const AString & valuename, const double defValue = 0.0); - int GetValueSetI(const AString & keyname, const AString & valuename, const int defValue = 0); - bool GetValueSetB(const AString & keyname, const AString & valuename, const bool defValue = false) - { - return (GetValueSetI(keyname, valuename, defValue ? 1 : 0) > 0); - } - - // Sets value of [keyname] valuename =. - // Specify the optional paramter as false (0) if you do not want it to create - // the key if it doesn't exist. Returns true if data entered, false otherwise. - // Overloaded to accept string, int, and double. - bool SetValue( const unsigned keyID, const unsigned valueID, const std::string & value); - bool SetValue( const std::string & keyname, const std::string & valuename, const std::string & value, const bool create = true); - bool SetValueI( const std::string & keyname, const std::string & valuename, const int value, const bool create = true); - bool SetValueB( const std::string & keyname, const std::string & valuename, const bool value, const bool create = true) - { - return SetValueI( keyname, valuename, int(value), create); - } - bool SetValueF( const std::string & keyname, const std::string & valuename, const double value, const bool create = true); - - // tolua_end - - bool SetValueV( const std::string & keyname, const std::string & valuename, char *format, ...); - - // tolua_begin - - // Deletes specified value. - // Returns true if value existed and deleted, false otherwise. - bool DeleteValueByID( const unsigned keyID, const unsigned valueID ); - bool DeleteValue( const std::string & keyname, const std::string & valuename); - - // Deletes specified key and all values contained within. - // Returns true if key existed and deleted, false otherwise. - bool DeleteKey(const std::string & keyname); - - // Header comment functions. - // Header comments are those comments before the first key. - // - // Number of header comments. - unsigned NumHeaderComments(void) {return comments.size();} - // Add a header comment. - void HeaderComment(const std::string & comment); - // Return a header comment. - std::string HeaderComment(const unsigned commentID) const; - // Delete a header comment. - bool DeleteHeaderComment(unsigned commentID); - // Delete all header comments. - void DeleteHeaderComments(void) {comments.clear();} - - - // Key comment functions. - // Key comments are those comments within a key. Any comments - // defined within value names will be added to this list. Therefore, - // these comments will be moved to the top of the key definition when - // the CIniFile::WriteFile() is called. - // - // Number of key comments. - unsigned NumKeyComments( const unsigned keyID) const; - unsigned NumKeyComments( const std::string & keyname) const; - - // Add a key comment. - bool KeyComment(const unsigned keyID, const std::string & comment); - bool KeyComment(const std::string & keyname, const std::string & comment); - - // Return a key comment. - std::string KeyComment(const unsigned keyID, const unsigned commentID) const; - std::string KeyComment(const std::string & keyname, const unsigned commentID) const; - - // Delete a key comment. - bool DeleteKeyComment(const unsigned keyID, const unsigned commentID); - bool DeleteKeyComment(const std::string & keyname, const unsigned commentID); - - // Delete all comments for a key. - bool DeleteKeyComments(const unsigned keyID); - bool DeleteKeyComments(const std::string & keyname); -}; - -// tolua_end - -#endif |