/* Copyright (C) 2004 Kimmo Pekkola This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifndef __CONFIGPARSER_H__ #define __CONFIGPARSER_H__ #include #include #include #include #include #include #include "ccalc-0.5.1/mparser.h" class CRainmeter; class CMeterWindow; class CMeasure; class CConfigParser { public: CConfigParser(); ~CConfigParser(); void Initialize(LPCTSTR filename, CRainmeter* pRainmeter, CMeterWindow* meterWindow = NULL); void AddMeasure(CMeasure* pMeasure); void SetVariable(const std::wstring& strVariable, const std::wstring& strValue); void SetStyleTemplate(const std::wstring& strStyle) { m_StyleTemplate = strStyle; } void ResetStyleTemplate() { m_StyleTemplate.clear(); } void ResetVariables(CRainmeter* pRainmeter, CMeterWindow* meterWindow = NULL); const std::wstring& ReadString(LPCTSTR section, LPCTSTR key, LPCTSTR defValue, bool bReplaceMeasures = true); double ReadFloat(LPCTSTR section, LPCTSTR key, double defValue); double ReadFormula(LPCTSTR section, LPCTSTR key, double defValue); int ReadInt(LPCTSTR section, LPCTSTR key, int defValue); Gdiplus::Color ReadColor(LPCTSTR section, LPCTSTR key, Gdiplus::Color defValue); std::vector ReadFloats(LPCTSTR section, LPCTSTR key); std::wstring& GetFilename() { return m_Filename; } const std::vector& GetSections(); // Returns an int if the formula was read successfully, -1 for failure. int ReadFormula(std::wstring& result, double* number); static std::vector Tokenize(const std::wstring& str, const std::wstring delimiters); static double ParseDouble(const std::wstring& string, double defValue, bool rejectExp = false); static Gdiplus::Color ParseColor(LPCTSTR string); static void ClearMultiMonitorVariables() { c_MonitorVariables.clear(); } static void UpdateWorkareaVariables() { SetMultiMonitorVariables(false); } private: void SetDefaultVariables(CRainmeter* pRainmeter, CMeterWindow* meterWindow); void ReadVariables(); void ReplaceVariables(std::wstring& result); void ReadIniFile(const std::wstring& strFileName, int depth = 0); void SetValue(const std::wstring& strSection, const std::wstring& strKey, const std::wstring& strValue); const std::wstring& GetValue(const std::wstring& strSection, const std::wstring& strKey, const std::wstring& strDefault); std::vector GetKeys(const std::wstring& strSection); void SetAutoSelectedMonitorVariables(CMeterWindow* meterWindow); void GetIniFileMappingList(); std::wstring GetAlternateFileName(const std::wstring& iniFile); static void SetMultiMonitorVariables(bool reset); static void SetMonitorVariable(const std::wstring& strVariable, const std::wstring& strValue); std::map m_Variables; std::wstring m_Filename; hqMathParser* m_Parser; std::map m_Measures; std::wstring m_StyleTemplate; std::vector m_Sections; // The sections must be an ordered array stdext::hash_map > m_Keys; stdext::hash_map m_Values; std::vector m_IniFileMappings; static std::map c_MonitorVariables; }; #endif