Overhauled Variables part. Fixed the issue that all variables are reset when the screen resolution (or work area) is changed.

This commit is contained in:
spx 2010-08-24 01:07:29 +00:00
parent 31b51da234
commit dbdebfd1f1
3 changed files with 192 additions and 142 deletions

View File

@ -60,23 +60,16 @@ void CConfigParser::Initialize(LPCTSTR filename, CRainmeter* pRainmeter, CMeterW
{ {
m_Filename = filename; m_Filename = filename;
m_BuiltInVariables.clear();
m_Variables.clear(); m_Variables.clear();
m_Measures.clear(); m_Measures.clear();
m_Keys.clear(); m_Keys.clear();
m_Values.clear(); m_Values.clear();
m_Sections.clear(); m_Sections.clear();
// Set the default variables. Do this before the ini file is read so that the paths can be used with @include // Set the built-in variables. Do this before the ini file is read so that the paths can be used with @include
SetDefaultVariables(pRainmeter, meterWindow); SetBuiltInVariables(pRainmeter, meterWindow);
ResetMonitorVariables(meterWindow);
// Set the SCREENAREA/WORKAREA variables
if (c_MonitorVariables.empty())
{
SetMultiMonitorVariables(true);
}
// Set the SCREENAREA/WORKAREA variables for present monitor
SetAutoSelectedMonitorVariables(meterWindow);
std::vector<std::wstring> iniFileMappings; std::vector<std::wstring> iniFileMappings;
CSystem::GetIniFileMappingList(iniFileMappings); CSystem::GetIniFileMappingList(iniFileMappings);
@ -86,15 +79,15 @@ void CConfigParser::Initialize(LPCTSTR filename, CRainmeter* pRainmeter, CMeterW
} }
/* /*
** SetDefaultVariables ** SetBuiltInVariables
** **
** **
*/ */
void CConfigParser::SetDefaultVariables(CRainmeter* pRainmeter, CMeterWindow* meterWindow) void CConfigParser::SetBuiltInVariables(CRainmeter* pRainmeter, CMeterWindow* meterWindow)
{ {
if (pRainmeter) if (pRainmeter)
{ {
SetVariable(L"PROGRAMPATH", pRainmeter->GetPath()); SetBuiltInVariable(L"PROGRAMPATH", pRainmeter->GetPath());
// Extract volume path from program path // Extract volume path from program path
// E.g.: // E.g.:
@ -105,7 +98,7 @@ void CConfigParser::SetDefaultVariables(CRainmeter* pRainmeter, CMeterWindow* me
std::wstring::size_type loc, loc2; std::wstring::size_type loc, loc2;
if ((loc = path.find_first_of(L':')) != std::wstring::npos) if ((loc = path.find_first_of(L':')) != std::wstring::npos)
{ {
SetVariable(L"PROGRAMDRIVE", path.substr(0, loc + 1)); SetBuiltInVariable(L"PROGRAMDRIVE", path.substr(0, loc + 1));
} }
else if (path.length() >= 2 && (path[0] == L'\\' || path[0] == L'/') && (path[1] == L'\\' || path[1] == L'/')) else if (path.length() >= 2 && (path[0] == L'\\' || path[0] == L'/') && (path[1] == L'\\' || path[1] == L'/'))
{ {
@ -116,38 +109,39 @@ void CConfigParser::SetDefaultVariables(CRainmeter* pRainmeter, CMeterWindow* me
loc = loc2; loc = loc2;
} }
} }
SetVariable(L"PROGRAMDRIVE", path.substr(0, loc)); SetBuiltInVariable(L"PROGRAMDRIVE", path.substr(0, loc));
} }
SetVariable(L"SETTINGSPATH", pRainmeter->GetSettingsPath()); SetBuiltInVariable(L"SETTINGSPATH", pRainmeter->GetSettingsPath());
SetVariable(L"SKINSPATH", pRainmeter->GetSkinPath()); SetBuiltInVariable(L"SKINSPATH", pRainmeter->GetSkinPath());
SetVariable(L"PLUGINSPATH", pRainmeter->GetPluginPath()); SetBuiltInVariable(L"PLUGINSPATH", pRainmeter->GetPluginPath());
SetVariable(L"CURRENTPATH", CRainmeter::ExtractPath(m_Filename)); SetBuiltInVariable(L"CURRENTPATH", CRainmeter::ExtractPath(m_Filename));
SetVariable(L"ADDONSPATH", pRainmeter->GetPath() + L"Addons\\"); SetBuiltInVariable(L"ADDONSPATH", pRainmeter->GetPath() + L"Addons\\");
SetVariable(L"CRLF", L"\n"); SetBuiltInVariable(L"CRLF", L"\n");
if (meterWindow) if (meterWindow)
{ {
const std::wstring& config = meterWindow->GetSkinName(); const std::wstring& config = meterWindow->GetSkinName();
if ((loc = config.find_first_of(L'\\')) != std::wstring::npos) if ((loc = config.find_first_of(L'\\')) != std::wstring::npos)
{ {
SetVariable(L"ROOTCONFIGPATH", pRainmeter->GetSkinPath() + config.substr(0, loc + 1)); SetBuiltInVariable(L"ROOTCONFIGPATH", pRainmeter->GetSkinPath() + config.substr(0, loc + 1));
} }
else else
{ {
SetVariable(L"ROOTCONFIGPATH", pRainmeter->GetSkinPath() + config + L"\\"); SetBuiltInVariable(L"ROOTCONFIGPATH", pRainmeter->GetSkinPath() + config + L"\\");
} }
} }
} }
if (meterWindow) if (meterWindow)
{ {
SetVariable(L"CURRENTCONFIG", meterWindow->GetSkinName()); SetBuiltInVariable(L"CURRENTCONFIG", meterWindow->GetSkinName());
} }
} }
/* /*
** ReadVariables ** ReadVariables
** **
** Sets all user-defined variables.
** **
*/ */
void CConfigParser::ReadVariables() void CConfigParser::ReadVariables()
@ -164,30 +158,69 @@ void CConfigParser::ReadVariables()
** Sets a new value for the variable. The DynamicVariables must be set to 1 in the ** Sets a new value for the variable. The DynamicVariables must be set to 1 in the
** meter/measure for the changes to be applied. ** meter/measure for the changes to be applied.
** **
** \param variables
** \param strVariable ** \param strVariable
** \param strValue ** \param strValue
*/ */
void CConfigParser::SetVariable(const std::wstring& strVariable, const std::wstring& strValue) void CConfigParser::SetVariable(std::map<std::wstring, std::wstring>& variables, const std::wstring& strVariable, const std::wstring& strValue)
{ {
// DebugLog(L"Variable: %s=%s (size=%i)", strVariable.c_str(), strValue.c_str(), m_Variables.size()); // DebugLog(L"Variable: %s=%s (size=%i)", strVariable.c_str(), strValue.c_str(), m_Variables.size());
std::wstring strTmp(strVariable); std::wstring strTmp(strVariable);
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::tolower); std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::towlower);
m_Variables[strTmp] = strValue; variables[strTmp] = strValue;
}
/**
** Gets a value for the variable.
**
** \param strVariable
** \param strValue
** \return true if variable is found
*/
bool CConfigParser::GetVariable(const std::wstring& strVariable, std::wstring& strValue)
{
std::wstring strTmp(strVariable);
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::towlower);
// #1: Built-in variables
std::map<std::wstring, std::wstring>::const_iterator iter = m_BuiltInVariables.find(strTmp);
if (iter != m_BuiltInVariables.end())
{
// Built-in variable found, replace it with the value
strValue = (*iter).second;
return true;
}
// #2: Monitor variables
iter = c_MonitorVariables.find(strTmp);
if (iter != c_MonitorVariables.end())
{
// SCREENAREA/WORKAREA variable found, replace it with the value
strValue = (*iter).second;
return true;
}
// #3: User defined variables
iter = m_Variables.find(strTmp);
if (iter != m_Variables.end())
{
// Variable found, replace it with the value
strValue = (*iter).second;
return true;
}
// Not found
return false;
} }
/* /*
** ResetVariables ** ResetMonitorVariables
** **
** **
*/ */
void CConfigParser::ResetVariables(CRainmeter* pRainmeter, CMeterWindow* meterWindow) void CConfigParser::ResetMonitorVariables(CMeterWindow* meterWindow)
{ {
m_Variables.clear();
// Set the default variables. Do this before the ini file is read so that the paths can be used with @include
SetDefaultVariables(pRainmeter, meterWindow);
// Set the SCREENAREA/WORKAREA variables // Set the SCREENAREA/WORKAREA variables
if (c_MonitorVariables.empty()) if (c_MonitorVariables.empty())
{ {
@ -196,8 +229,6 @@ void CConfigParser::ResetVariables(CRainmeter* pRainmeter, CMeterWindow* meterWi
// Set the SCREENAREA/WORKAREA variables for present monitor // Set the SCREENAREA/WORKAREA variables for present monitor
SetAutoSelectedMonitorVariables(meterWindow); SetAutoSelectedMonitorVariables(meterWindow);
ReadVariables();
} }
/* /*
@ -306,21 +337,6 @@ void CConfigParser::SetMultiMonitorVariables(bool reset)
} }
} }
/**
** Sets a new value for the SCREENAREA/WORKAREA variable.
**
** \param strVariable
** \param strValue
*/
void CConfigParser::SetMonitorVariable(const std::wstring& strVariable, const std::wstring& strValue)
{
// DebugLog(L"MonitorVariable: %s=%s (size=%i)", strVariable.c_str(), strValue.c_str(), c_MonitorVariables.size());
std::wstring strTmp(strVariable);
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::tolower);
c_MonitorVariables[strTmp] = strValue;
}
/* /*
** SetAutoSelectedMonitorVariables ** SetAutoSelectedMonitorVariables
** **
@ -331,21 +347,27 @@ void CConfigParser::SetAutoSelectedMonitorVariables(CMeterWindow* meterWindow)
{ {
if (meterWindow) if (meterWindow)
{ {
TCHAR buffer[256];
if (CSystem::GetMonitorCount() > 0) if (CSystem::GetMonitorCount() > 0)
{ {
TCHAR buffer[256];
int w1, w2, s1, s2; int w1, w2, s1, s2;
int screenIndex;
const MULTIMONITOR_INFO& multimonInfo = CSystem::GetMultiMonitorInfo(); const MULTIMONITOR_INFO& multimonInfo = CSystem::GetMultiMonitorInfo();
const std::vector<MONITOR_INFO>& monitors = multimonInfo.monitors; const std::vector<MONITOR_INFO>& monitors = multimonInfo.monitors;
// Set X / WIDTH
screenIndex = multimonInfo.primary;
if (meterWindow->GetXScreenDefined()) if (meterWindow->GetXScreenDefined())
{ {
int screenIndex = meterWindow->GetXScreen(); int i = meterWindow->GetXScreen();
if (i >= 0 && (i == 0 || i <= (int)monitors.size() && monitors[i-1].active))
if (screenIndex >= 0 && (screenIndex == 0 || screenIndex <= (int)monitors.size() &&
screenIndex != multimonInfo.primary && monitors[screenIndex-1].active))
{ {
screenIndex = i;
}
}
if (screenIndex == 0) if (screenIndex == 0)
{ {
s1 = w1 = multimonInfo.vsL; s1 = w1 = multimonInfo.vsL;
@ -360,23 +382,25 @@ void CConfigParser::SetAutoSelectedMonitorVariables(CMeterWindow* meterWindow)
} }
swprintf(buffer, L"%i", w1); swprintf(buffer, L"%i", w1);
SetVariable(L"WORKAREAX", buffer); SetBuiltInVariable(L"WORKAREAX", buffer);
swprintf(buffer, L"%i", w2); swprintf(buffer, L"%i", w2);
SetVariable(L"WORKAREAWIDTH", buffer); SetBuiltInVariable(L"WORKAREAWIDTH", buffer);
swprintf(buffer, L"%i", s1); swprintf(buffer, L"%i", s1);
SetVariable(L"SCREENAREAX", buffer); SetBuiltInVariable(L"SCREENAREAX", buffer);
swprintf(buffer, L"%i", s2); swprintf(buffer, L"%i", s2);
SetVariable(L"SCREENAREAWIDTH", buffer); SetBuiltInVariable(L"SCREENAREAWIDTH", buffer);
}
}
// Set Y / HEIGHT
screenIndex = multimonInfo.primary;
if (meterWindow->GetYScreenDefined()) if (meterWindow->GetYScreenDefined())
{ {
int screenIndex = meterWindow->GetYScreen(); int i = meterWindow->GetYScreen();
if (i >= 0 && (i == 0 || i <= (int)monitors.size() && monitors[i-1].active))
if (screenIndex >= 0 && (screenIndex == 0 || screenIndex <= (int)monitors.size() &&
screenIndex != multimonInfo.primary && monitors[screenIndex-1].active))
{ {
screenIndex = i;
}
}
if (screenIndex == 0) if (screenIndex == 0)
{ {
s1 = w1 = multimonInfo.vsL; s1 = w1 = multimonInfo.vsL;
@ -391,15 +415,44 @@ void CConfigParser::SetAutoSelectedMonitorVariables(CMeterWindow* meterWindow)
} }
swprintf(buffer, L"%i", w1); swprintf(buffer, L"%i", w1);
SetVariable(L"WORKAREAY", buffer); SetBuiltInVariable(L"WORKAREAY", buffer);
swprintf(buffer, L"%i", w2); swprintf(buffer, L"%i", w2);
SetVariable(L"WORKAREAHEIGHT", buffer); SetBuiltInVariable(L"WORKAREAHEIGHT", buffer);
swprintf(buffer, L"%i", s1); swprintf(buffer, L"%i", s1);
SetVariable(L"SCREENAREAY", buffer); SetBuiltInVariable(L"SCREENAREAY", buffer);
swprintf(buffer, L"%i", s2); swprintf(buffer, L"%i", s2);
SetVariable(L"SCREENAREAHEIGHT", buffer); SetBuiltInVariable(L"SCREENAREAHEIGHT", buffer);
}
} }
else
{
RECT r;
// Set default WORKAREA
SystemParametersInfo(SPI_GETWORKAREA, 0, &r, 0);
swprintf(buffer, L"%i", r.left);
SetBuiltInVariable(L"WORKAREAX", buffer);
swprintf(buffer, L"%i", r.top);
SetBuiltInVariable(L"WORKAREAY", buffer);
swprintf(buffer, L"%i", r.right - r.left);
SetBuiltInVariable(L"WORKAREAWIDTH", buffer);
swprintf(buffer, L"%i", r.bottom - r.top);
SetBuiltInVariable(L"WORKAREAHEIGHT", buffer);
// Set default SCREENAREA
r.left = 0;
r.top = 0;
r.right = GetSystemMetrics(SM_CXSCREEN);
r.bottom = GetSystemMetrics(SM_CYSCREEN);
swprintf(buffer, L"%i", r.left);
SetBuiltInVariable(L"SCREENAREAX", buffer);
swprintf(buffer, L"%i", r.top);
SetBuiltInVariable(L"SCREENAREAY", buffer);
swprintf(buffer, L"%i", r.right - r.left);
SetBuiltInVariable(L"SCREENAREAWIDTH", buffer);
swprintf(buffer, L"%i", r.bottom - r.top);
SetBuiltInVariable(L"SCREENAREAHEIGHT", buffer);
} }
} }
} }
@ -434,25 +487,14 @@ bool CConfigParser::ReplaceVariables(std::wstring& result)
end = result.find(L'#', pos + 1); end = result.find(L'#', pos + 1);
if (end != std::wstring::npos) if (end != std::wstring::npos)
{ {
std::wstring strTmp(result.begin() + pos + 1, result.begin() + end); std::wstring strVariable(result.begin() + pos + 1, result.begin() + end);
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::tolower); std::wstring strValue;
std::map<std::wstring, std::wstring>::const_iterator iter = m_Variables.find(strTmp); if (GetVariable(strVariable, strValue))
if (iter != m_Variables.end())
{ {
// Variable found, replace it with the value // Variable found, replace it with the value
result.replace(result.begin() + pos, result.begin() + end + 1, (*iter).second); result.replace(result.begin() + pos, result.begin() + end + 1, strValue);
start = pos + (*iter).second.length(); start = pos + strValue.length();
replaced = true;
}
else
{
std::map<std::wstring, std::wstring>::const_iterator iter2 = c_MonitorVariables.find(strTmp);
if (iter2 != c_MonitorVariables.end())
{
// SCREENAREA/WORKAREA variable found, replace it with the value
result.replace(result.begin() + pos, result.begin() + end + 1, (*iter2).second);
start = pos + (*iter2).second.length();
replaced = true; replaced = true;
} }
else else
@ -460,7 +502,6 @@ bool CConfigParser::ReplaceVariables(std::wstring& result)
start = end; start = end;
} }
} }
}
else else
{ {
loop = false; loop = false;
@ -936,7 +977,7 @@ void CConfigParser::ReadIniFile(const std::vector<std::wstring>& iniFileMappings
while(wcslen(pos) > 0) while(wcslen(pos) > 0)
{ {
std::wstring strTmp(pos); std::wstring strTmp(pos);
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::tolower); std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::towlower);
if (m_Keys.find(strTmp) == m_Keys.end()) if (m_Keys.find(strTmp) == m_Keys.end())
{ {
m_Keys[strTmp] = std::vector<std::wstring>(); m_Keys[strTmp] = std::vector<std::wstring>();
@ -1020,8 +1061,8 @@ void CConfigParser::SetValue(const std::wstring& strSection, const std::wstring&
std::wstring strTmpSection(strSection); std::wstring strTmpSection(strSection);
std::wstring strTmpKey(strKey); std::wstring strTmpKey(strKey);
std::transform(strTmpSection.begin(), strTmpSection.end(), strTmpSection.begin(), ::tolower); std::transform(strTmpSection.begin(), strTmpSection.end(), strTmpSection.begin(), ::towlower);
std::transform(strTmpKey.begin(), strTmpKey.end(), strTmpKey.begin(), ::tolower); std::transform(strTmpKey.begin(), strTmpKey.end(), strTmpKey.begin(), ::towlower);
stdext::hash_map<std::wstring, std::vector<std::wstring> >::iterator iter = m_Keys.find(strTmpSection); stdext::hash_map<std::wstring, std::vector<std::wstring> >::iterator iter = m_Keys.find(strTmpSection);
if (iter != m_Keys.end()) if (iter != m_Keys.end())
@ -1044,7 +1085,7 @@ void CConfigParser::SetValue(const std::wstring& strSection, const std::wstring&
const std::wstring& CConfigParser::GetValue(const std::wstring& strSection, const std::wstring& strKey, const std::wstring& strDefault) const std::wstring& CConfigParser::GetValue(const std::wstring& strSection, const std::wstring& strKey, const std::wstring& strDefault)
{ {
std::wstring strTmp(strSection + L"::" + strKey); std::wstring strTmp(strSection + L"::" + strKey);
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::tolower); std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::towlower);
stdext::hash_map<std::wstring, std::wstring>::const_iterator iter = m_Values.find(strTmp); stdext::hash_map<std::wstring, std::wstring>::const_iterator iter = m_Values.find(strTmp);
if (iter != m_Values.end()) if (iter != m_Values.end())
@ -1076,7 +1117,7 @@ const std::vector<std::wstring>& CConfigParser::GetSections()
std::vector<std::wstring> CConfigParser::GetKeys(const std::wstring& strSection) std::vector<std::wstring> CConfigParser::GetKeys(const std::wstring& strSection)
{ {
std::wstring strTmp(strSection); std::wstring strTmp(strSection);
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::tolower); std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::towlower);
stdext::hash_map<std::wstring, std::vector<std::wstring> >::const_iterator iter = m_Keys.find(strTmp); stdext::hash_map<std::wstring, std::vector<std::wstring> >::const_iterator iter = m_Keys.find(strTmp);
if (iter != m_Keys.end()) if (iter != m_Keys.end())

View File

@ -39,11 +39,13 @@ public:
void Initialize(LPCTSTR filename, CRainmeter* pRainmeter, CMeterWindow* meterWindow = NULL); void Initialize(LPCTSTR filename, CRainmeter* pRainmeter, CMeterWindow* meterWindow = NULL);
void AddMeasure(CMeasure* pMeasure); 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); void SetVariable(const std::wstring& strVariable, const std::wstring& strValue) { SetVariable(m_Variables, strVariable, strValue); }
void SetStyleTemplate(const std::wstring& strStyle) { m_StyleTemplate = strStyle; }
void ClearStyleTemplate() { m_StyleTemplate.clear(); }
void ResetMonitorVariables(CMeterWindow* meterWindow = NULL);
const std::wstring& ReadString(LPCTSTR section, LPCTSTR key, LPCTSTR defValue, bool bReplaceMeasures = true, bool* bReplaced = NULL); const std::wstring& ReadString(LPCTSTR section, LPCTSTR key, LPCTSTR defValue, bool bReplaceMeasures = true, bool* bReplaced = NULL);
double ReadFloat(LPCTSTR section, LPCTSTR key, double defValue); double ReadFloat(LPCTSTR section, LPCTSTR key, double defValue);
@ -52,7 +54,7 @@ public:
Gdiplus::Color ReadColor(LPCTSTR section, LPCTSTR key, const Gdiplus::Color& defValue); Gdiplus::Color ReadColor(LPCTSTR section, LPCTSTR key, const Gdiplus::Color& defValue);
std::vector<Gdiplus::REAL> ReadFloats(LPCTSTR section, LPCTSTR key); std::vector<Gdiplus::REAL> ReadFloats(LPCTSTR section, LPCTSTR key);
std::wstring& GetFilename() { return m_Filename; } const std::wstring& GetFilename() { return m_Filename; }
const std::vector<std::wstring>& GetSections(); const std::vector<std::wstring>& GetSections();
// Returns an int if the formula was read successfully, -1 for failure. // Returns an int if the formula was read successfully, -1 for failure.
@ -66,7 +68,10 @@ public:
static void UpdateWorkareaVariables() { SetMultiMonitorVariables(false); } static void UpdateWorkareaVariables() { SetMultiMonitorVariables(false); }
private: private:
void SetDefaultVariables(CRainmeter* pRainmeter, CMeterWindow* meterWindow); void SetBuiltInVariables(CRainmeter* pRainmeter, CMeterWindow* meterWindow);
void SetBuiltInVariable(const std::wstring& strVariable, const std::wstring& strValue) { SetVariable(m_BuiltInVariables, strVariable, strValue); }
bool GetVariable(const std::wstring& strVariable, std::wstring& strValue);
void ReadVariables(); void ReadVariables();
bool ReplaceVariables(std::wstring& result); bool ReplaceVariables(std::wstring& result);
bool ReplaceMeasures(std::wstring& result); bool ReplaceMeasures(std::wstring& result);
@ -79,10 +84,11 @@ private:
void SetAutoSelectedMonitorVariables(CMeterWindow* meterWindow); void SetAutoSelectedMonitorVariables(CMeterWindow* meterWindow);
static void SetMultiMonitorVariables(bool reset); static void SetVariable(std::map<std::wstring, std::wstring>& variables, const std::wstring& strVariable, const std::wstring& strValue);
static void SetMonitorVariable(const std::wstring& strVariable, const std::wstring& strValue);
static void SetMultiMonitorVariables(bool reset);
static void SetMonitorVariable(const std::wstring& strVariable, const std::wstring& strValue) { SetVariable(c_MonitorVariables, strVariable, strValue); }
std::map<std::wstring, std::wstring> m_Variables;
std::wstring m_Filename; std::wstring m_Filename;
hqMathParser* m_Parser; hqMathParser* m_Parser;
@ -94,7 +100,10 @@ private:
stdext::hash_map<std::wstring, std::vector<std::wstring> > m_Keys; stdext::hash_map<std::wstring, std::vector<std::wstring> > m_Keys;
stdext::hash_map<std::wstring, std::wstring> m_Values; stdext::hash_map<std::wstring, std::wstring> m_Values;
static std::map<std::wstring, std::wstring> c_MonitorVariables; std::map<std::wstring, std::wstring> m_BuiltInVariables; // Built-in variables
std::map<std::wstring, std::wstring> m_Variables; // User-defined variables
static std::map<std::wstring, std::wstring> c_MonitorVariables; // Monitor variables
}; };
#endif #endif

View File

@ -1471,7 +1471,7 @@ void CMeterWindow::ScreenToWindow()
if (reset) if (reset)
{ {
m_Parser.ResetVariables(m_Rainmeter, this); // Set present monitor variables m_Parser.ResetMonitorVariables(this); // Set present monitor variables
} }
break; break;
} }
@ -2021,7 +2021,7 @@ bool CMeterWindow::ReadSkin()
{ {
m_Meters.push_back(meter); m_Meters.push_back(meter);
m_Parser.ResetStyleTemplate(); m_Parser.ClearStyleTemplate();
if (!m_HasButtons && dynamic_cast<CMeterButton*>(meter)) if (!m_HasButtons && dynamic_cast<CMeterButton*>(meter))
{ {
@ -2475,7 +2475,7 @@ void CMeterWindow::Update(bool nodraw)
if ((*j)->HasDynamicVariables()) if ((*j)->HasDynamicVariables())
{ {
(*j)->ReadConfig((*j)->GetName()); (*j)->ReadConfig((*j)->GetName());
m_Parser.ResetStyleTemplate(); m_Parser.ClearStyleTemplate();
} }
(*j)->Update(); (*j)->Update();
} }
@ -3295,7 +3295,7 @@ LRESULT CMeterWindow::OnCommand(WPARAM wParam, LPARAM lParam)
m_WindowXScreen = m_WindowYScreen = screenIndex; m_WindowXScreen = m_WindowYScreen = screenIndex;
m_WindowXScreenDefined = m_WindowYScreenDefined = screenDefined; m_WindowXScreenDefined = m_WindowYScreenDefined = screenDefined;
m_Parser.ResetVariables(m_Rainmeter, this); // Set present monitor variables m_Parser.ResetMonitorVariables(this); // Set present monitor variables
ScreenToWindow(); ScreenToWindow();
WriteConfig(); WriteConfig();
@ -4353,7 +4353,7 @@ LRESULT CMeterWindow::OnDelayedMove(WPARAM wParam, LPARAM lParam)
{ {
if (m_NativeTransparency) if (m_NativeTransparency)
{ {
m_Parser.ResetVariables(m_Rainmeter, this); m_Parser.ResetMonitorVariables(this);
// Move the window to correct position // Move the window to correct position
ResizeWindow(true); ResizeWindow(true);