Code cleanup.

This commit is contained in:
spx 2011-01-23 06:16:18 +00:00
parent f22324d423
commit 84dba0c65a

View File

@ -1896,14 +1896,17 @@ bool CMeterWindow::ReadSkin()
std::wstring localFont = m_Parser.ReadString(L"Rainmeter", L"LocalFont", L""); std::wstring localFont = m_Parser.ReadString(L"Rainmeter", L"LocalFont", L"");
// If there is a local font we want to load it // If there is a local font we want to load it
if(!localFont.empty()) if(!localFont.empty())
{
m_FontCollection = new PrivateFontCollection();
int i = 2;
do
{ {
// We want to check the fonts folder first // We want to check the fonts folder first
// !!!!!!! - We may want to fix the method in which I get the path to // !!!!!!! - We may want to fix the method in which I get the path to
// Rainmeter/fonts // Rainmeter/fonts
std::wstring szFontFile = m_Rainmeter->GetPath(); std::wstring szFontFile = m_Rainmeter->GetPath() + L"Fonts\\";
szFontFile += localFont;
m_FontCollection = new Gdiplus::PrivateFontCollection();
Status nResults = m_FontCollection->AddFontFile(szFontFile.c_str()); Status nResults = m_FontCollection->AddFontFile(szFontFile.c_str());
// It wasn't found in the fonts folder, check the local folder // It wasn't found in the fonts folder, check the local folder
@ -1913,7 +1916,6 @@ bool CMeterWindow::ReadSkin()
szFontFile += m_SkinName; szFontFile += m_SkinName;
szFontFile += L"\\"; szFontFile += L"\\";
szFontFile += localFont; szFontFile += localFont;
nResults = m_FontCollection->AddFontFile(szFontFile.c_str()); nResults = m_FontCollection->AddFontFile(szFontFile.c_str());
// The font wasn't found, check full path. // The font wasn't found, check full path.
@ -1921,64 +1923,22 @@ bool CMeterWindow::ReadSkin()
{ {
szFontFile = localFont; szFontFile = localFont;
nResults = m_FontCollection->AddFontFile(szFontFile.c_str()); nResults = m_FontCollection->AddFontFile(szFontFile.c_str());
if(nResults != Ok) if(nResults != Ok)
{ {
std::wstring error = L"Couldn't load font file: " + localFont; std::wstring error = L"Unable to load font file: " + localFont;
Log(LOG_ERROR, error.c_str()); Log(LOG_ERROR, error.c_str());
} }
} }
} }
// Here we are checking to see if there are more than one local font // Here we are checking to see if there are more than one local font
// to be loaded. They will be named LocalFont2, LocalFont3, etc. // to be loaded. They will be named LocalFont2, LocalFont3, etc.
WCHAR tmpName[64]; WCHAR tmpName[64];
int i = 2; _snwprintf_s(tmpName, _TRUNCATE, L"LocalFont%i", i++);
bool loop = true;
do
{
_snwprintf_s(tmpName, _TRUNCATE, L"LocalFont%i", i);
localFont = m_Parser.ReadString(L"Rainmeter", tmpName, L""); localFont = m_Parser.ReadString(L"Rainmeter", tmpName, L"");
// There is a key called LocalFont%i
if (!localFont.empty())
{
// We want to check the fonts folder first
// !!!!!!! - We may want to fix the method in which I get the path to
// Rainmeter/fonts
std::wstring szFontFile = m_Rainmeter->GetPath();
szFontFile += L"Fonts\\";
szFontFile += localFont;
nResults = m_FontCollection->AddFontFile(szFontFile.c_str()); } while (!localFont.empty());
// It wasn't found in the fonts folder, check the local folder
if(nResults != Ok)
{
szFontFile = m_SkinPath; // Get the local path
szFontFile += m_SkinName;
szFontFile += localFont;
nResults = m_FontCollection->AddFontFile(szFontFile.c_str());
// The font wasn't found, check full path.
if(nResults != Ok)
{
szFontFile = localFont;
nResults = m_FontCollection->AddFontFile(szFontFile.c_str());
// The font file wasn't found anywhere, log the error
if(nResults != Ok)
{
std::wstring error = L"Couldn't load font file: " + localFont;
Log(LOG_ERROR, error.c_str());
}
}
}
}
// There were no extra Local Fonts found: exit loop.
else
{
loop = false;
}
++i;
} while(loop);
} }
// Create the meters and measures // Create the meters and measures