mirror of
https://github.com/chibicitiberiu/rainmeter-studio.git
synced 2024-02-24 04:33:31 +00:00
Move CSystem::GetOSPlatform() to Platform.h
This commit is contained in:
parent
87014a8a87
commit
f9e4230ddd
59
Common/Platform.cpp
Normal file
59
Common/Platform.cpp
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
/*
|
||||||
|
Copyright (C) 2013 Birunthan Mohanathas
|
||||||
|
|
||||||
|
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "Platform.h"
|
||||||
|
#include <Windows.h>
|
||||||
|
|
||||||
|
namespace Platform {
|
||||||
|
|
||||||
|
Version GetVersion()
|
||||||
|
{
|
||||||
|
static Version s_Version = ([]()
|
||||||
|
{
|
||||||
|
OSVERSIONINFOEX osvi = {sizeof(OSVERSIONINFOEX)};
|
||||||
|
if (GetVersionEx((OSVERSIONINFO*)&osvi))
|
||||||
|
{
|
||||||
|
switch (osvi.dwMajorVersion)
|
||||||
|
{
|
||||||
|
case 5:
|
||||||
|
// Not checking for osvi.dwMinorVersion >= 1 because Rainmeter won't run on pre-XP.
|
||||||
|
return Version::WinXP;
|
||||||
|
|
||||||
|
case 6:
|
||||||
|
switch (osvi.dwMinorVersion)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
return Version::WinVista; // Vista, Server 2008
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
return Version::Win7; // 7, Server 2008R2
|
||||||
|
|
||||||
|
default:
|
||||||
|
return Version::Win8; // 8, Server 2012
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return Version::Win8; // newer OS
|
||||||
|
})();
|
||||||
|
|
||||||
|
return s_Version;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Platform
|
46
Common/Platform.h
Normal file
46
Common/Platform.h
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
/*
|
||||||
|
Copyright (C) 2013 Birunthan Mohanathas
|
||||||
|
|
||||||
|
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef RM_COMMON_PLATFORM_H_
|
||||||
|
#define RM_COMMON_PLATFORM_H_
|
||||||
|
|
||||||
|
namespace Platform {
|
||||||
|
|
||||||
|
enum Version
|
||||||
|
{
|
||||||
|
WinXP,
|
||||||
|
WinVista,
|
||||||
|
Win7,
|
||||||
|
Win8
|
||||||
|
};
|
||||||
|
|
||||||
|
Version GetVersion();
|
||||||
|
|
||||||
|
#define RM_PLATFORM_DECLARE_HELPERS(ver) \
|
||||||
|
inline bool IsAtMost ## ver() { return GetVersion() <= ver; } \
|
||||||
|
inline bool Is ## ver() { return GetVersion() == ver; } \
|
||||||
|
inline bool IsAtLeast ## ver() { return GetVersion() >= ver; } \
|
||||||
|
|
||||||
|
RM_PLATFORM_DECLARE_HELPERS(WinXP)
|
||||||
|
RM_PLATFORM_DECLARE_HELPERS(WinVista)
|
||||||
|
RM_PLATFORM_DECLARE_HELPERS(Win7)
|
||||||
|
RM_PLATFORM_DECLARE_HELPERS(Win8)
|
||||||
|
|
||||||
|
} // namespace Platform
|
||||||
|
|
||||||
|
#endif
|
@ -262,7 +262,7 @@ INT_PTR CDialogAbout::OnInitDialog(WPARAM wParam, LPARAM lParam)
|
|||||||
item = GetControl(Id_CloseButton);
|
item = GetControl(Id_CloseButton);
|
||||||
SendMessage(m_Window, WM_NEXTDLGCTL, (WPARAM)item, TRUE);
|
SendMessage(m_Window, WM_NEXTDLGCTL, (WPARAM)item, TRUE);
|
||||||
|
|
||||||
if (CSystem::GetOSPlatform() >= OSPLATFORM_VISTA)
|
if (Platform::IsAtLeastWinVista())
|
||||||
{
|
{
|
||||||
item = m_TabLog.GetControl(CTabLog::Id_ItemsListView);
|
item = m_TabLog.GetControl(CTabLog::Id_ItemsListView);
|
||||||
SetWindowTheme(item, L"explorer", NULL);
|
SetWindowTheme(item, L"explorer", NULL);
|
||||||
@ -638,7 +638,7 @@ void CDialogAbout::CTabSkins::Initialize()
|
|||||||
LVGROUP lvg;
|
LVGROUP lvg;
|
||||||
lvg.cbSize = sizeof(LVGROUP);
|
lvg.cbSize = sizeof(LVGROUP);
|
||||||
lvg.mask = LVGF_HEADER | LVGF_GROUPID | LVGF_STATE;
|
lvg.mask = LVGF_HEADER | LVGF_GROUPID | LVGF_STATE;
|
||||||
lvg.state = (CSystem::GetOSPlatform() >= OSPLATFORM_VISTA) ? LVGS_COLLAPSIBLE : LVGS_NORMAL;
|
lvg.state = (Platform::IsAtLeastWinVista()) ? LVGS_COLLAPSIBLE : LVGS_NORMAL;
|
||||||
lvg.iGroupId = 0;
|
lvg.iGroupId = 0;
|
||||||
lvg.pszHeader = GetString(ID_STR_MEASURES);
|
lvg.pszHeader = GetString(ID_STR_MEASURES);
|
||||||
ListView_InsertGroup(item, 0, &lvg);
|
ListView_InsertGroup(item, 0, &lvg);
|
||||||
|
@ -233,7 +233,7 @@ INT_PTR CDialogManage::OnInitDialog(WPARAM wParam, LPARAM lParam)
|
|||||||
item = m_TabSkins.GetControl(CTabSkins::Id_FileLabel);
|
item = m_TabSkins.GetControl(CTabSkins::Id_FileLabel);
|
||||||
SendMessage(item, WM_SETFONT, (WPARAM)m_FontBold, 0);
|
SendMessage(item, WM_SETFONT, (WPARAM)m_FontBold, 0);
|
||||||
|
|
||||||
if (CSystem::GetOSPlatform() >= OSPLATFORM_VISTA)
|
if (Platform::IsAtLeastWinVista())
|
||||||
{
|
{
|
||||||
// Use arrows instead of plus/minus in the tree for Vista+
|
// Use arrows instead of plus/minus in the tree for Vista+
|
||||||
item = m_TabSkins.GetControl(CTabSkins::Id_SkinsTreeView);
|
item = m_TabSkins.GetControl(CTabSkins::Id_SkinsTreeView);
|
||||||
|
@ -66,6 +66,7 @@
|
|||||||
<ClCompile Include="..\Common\ControlTemplate.cpp" />
|
<ClCompile Include="..\Common\ControlTemplate.cpp" />
|
||||||
<ClCompile Include="..\Common\Dialog.cpp" />
|
<ClCompile Include="..\Common\Dialog.cpp" />
|
||||||
<ClCompile Include="..\Common\MenuTemplate.cpp" />
|
<ClCompile Include="..\Common\MenuTemplate.cpp" />
|
||||||
|
<ClCompile Include="..\Common\Platform.cpp" />
|
||||||
<ClCompile Include="..\Common\StringUtil.cpp" />
|
<ClCompile Include="..\Common\StringUtil.cpp" />
|
||||||
<ClCompile Include="ConfigParser.cpp">
|
<ClCompile Include="ConfigParser.cpp">
|
||||||
<PrecompiledHeader>Use</PrecompiledHeader>
|
<PrecompiledHeader>Use</PrecompiledHeader>
|
||||||
@ -275,6 +276,7 @@
|
|||||||
<ClInclude Include="..\Common\ControlTemplate.h" />
|
<ClInclude Include="..\Common\ControlTemplate.h" />
|
||||||
<ClInclude Include="..\Common\Dialog.h" />
|
<ClInclude Include="..\Common\Dialog.h" />
|
||||||
<ClInclude Include="..\Common\MenuTemplate.h" />
|
<ClInclude Include="..\Common\MenuTemplate.h" />
|
||||||
|
<ClInclude Include="..\Common\Platform.h" />
|
||||||
<ClInclude Include="..\Common\StringUtil.h" />
|
<ClInclude Include="..\Common\StringUtil.h" />
|
||||||
<ClInclude Include="ConfigParser.h" />
|
<ClInclude Include="ConfigParser.h" />
|
||||||
<ClInclude Include="DialogAbout.h" />
|
<ClInclude Include="DialogAbout.h" />
|
||||||
|
@ -333,6 +333,9 @@
|
|||||||
<ClCompile Include="..\Common\MenuTemplate.cpp">
|
<ClCompile Include="..\Common\MenuTemplate.cpp">
|
||||||
<Filter>Common</Filter>
|
<Filter>Common</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\Common\Platform.cpp">
|
||||||
|
<Filter>Common</Filter>
|
||||||
|
</ClCompile>
|
||||||
<ClCompile Include="..\Common\StringUtil.cpp">
|
<ClCompile Include="..\Common\StringUtil.cpp">
|
||||||
<Filter>Common</Filter>
|
<Filter>Common</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
@ -575,6 +578,9 @@
|
|||||||
<ClInclude Include="..\Common\MenuTemplate.h">
|
<ClInclude Include="..\Common\MenuTemplate.h">
|
||||||
<Filter>Common</Filter>
|
<Filter>Common</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\Common\Platform.h">
|
||||||
|
<Filter>Common</Filter>
|
||||||
|
</ClInclude>
|
||||||
<ClInclude Include="..\Common\StringUtil.h">
|
<ClInclude Include="..\Common\StringUtil.h">
|
||||||
<Filter>Common</Filter>
|
<Filter>Common</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
@ -691,7 +691,7 @@ void CMeasureNet::WriteStats(const WCHAR* iniFile, const std::wstring& statsDate
|
|||||||
*/
|
*/
|
||||||
void CMeasureNet::InitializeStatic()
|
void CMeasureNet::InitializeStatic()
|
||||||
{
|
{
|
||||||
if (CSystem::GetOSPlatform() >= OSPLATFORM_VISTA)
|
if (Platform::IsAtLeastWinVista())
|
||||||
{
|
{
|
||||||
HMODULE IpHlpApiLibrary = GetModuleHandle(L"IpHlpApi.dll");
|
HMODULE IpHlpApiLibrary = GetModuleHandle(L"IpHlpApi.dll");
|
||||||
if (IpHlpApiLibrary)
|
if (IpHlpApiLibrary)
|
||||||
|
@ -145,7 +145,7 @@ CMeterWindow::CMeterWindow(const std::wstring& folderPath, const std::wstring& f
|
|||||||
m_FontCollection(),
|
m_FontCollection(),
|
||||||
m_ToolTipHidden(false)
|
m_ToolTipHidden(false)
|
||||||
{
|
{
|
||||||
if (!c_DwmInstance && CSystem::GetOSPlatform() >= OSPLATFORM_VISTA)
|
if (!c_DwmInstance && Platform::IsAtLeastWinVista())
|
||||||
{
|
{
|
||||||
c_DwmInstance = CSystem::RmLoadLibrary(L"dwmapi.dll");
|
c_DwmInstance = CSystem::RmLoadLibrary(L"dwmapi.dll");
|
||||||
if (c_DwmInstance)
|
if (c_DwmInstance)
|
||||||
@ -1030,7 +1030,7 @@ void CMeterWindow::HideBlur()
|
|||||||
*/
|
*/
|
||||||
void CMeterWindow::ResizeBlur(const std::wstring& arg, int mode)
|
void CMeterWindow::ResizeBlur(const std::wstring& arg, int mode)
|
||||||
{
|
{
|
||||||
if (CSystem::GetOSPlatform() >= OSPLATFORM_VISTA)
|
if (Platform::IsAtLeastWinVista())
|
||||||
{
|
{
|
||||||
WCHAR* parseSz = _wcsdup(arg.c_str());
|
WCHAR* parseSz = _wcsdup(arg.c_str());
|
||||||
int type, x, y, w = 0, h = 0;
|
int type, x, y, w = 0, h = 0;
|
||||||
@ -2054,7 +2054,7 @@ bool CMeterWindow::ReadSkin()
|
|||||||
m_TransitionUpdate = m_Parser.ReadInt(L"Rainmeter", L"TransitionUpdate", INTERVAL_TRANSITION);
|
m_TransitionUpdate = m_Parser.ReadInt(L"Rainmeter", L"TransitionUpdate", INTERVAL_TRANSITION);
|
||||||
m_ToolTipHidden = 0 != m_Parser.ReadInt(L"Rainmeter", L"ToolTipHidden", 0);
|
m_ToolTipHidden = 0 != m_Parser.ReadInt(L"Rainmeter", L"ToolTipHidden", 0);
|
||||||
|
|
||||||
if (CSystem::GetOSPlatform() >= OSPLATFORM_VISTA)
|
if (Platform::IsAtLeastWinVista())
|
||||||
{
|
{
|
||||||
if (0 != m_Parser.ReadInt(L"Rainmeter", L"Blur", 0))
|
if (0 != m_Parser.ReadInt(L"Rainmeter", L"Blur", 0))
|
||||||
{
|
{
|
||||||
@ -2095,7 +2095,7 @@ bool CMeterWindow::ReadSkin()
|
|||||||
|
|
||||||
HANDLE find = FindFirstFileEx(
|
HANDLE find = FindFirstFileEx(
|
||||||
resourcePath.c_str(),
|
resourcePath.c_str(),
|
||||||
(CSystem::GetOSPlatform() >= OSPLATFORM_7) ? FindExInfoBasic : FindExInfoStandard,
|
(Platform::IsAtLeastWin7()) ? FindExInfoBasic : FindExInfoStandard,
|
||||||
&fd,
|
&fd,
|
||||||
FindExSearchNameMatch,
|
FindExSearchNameMatch,
|
||||||
NULL,
|
NULL,
|
||||||
|
@ -1828,7 +1828,7 @@ int CRainmeter::ScanForSkinsRecursive(const std::wstring& path, std::wstring bas
|
|||||||
|
|
||||||
hSearch = FindFirstFileEx(
|
hSearch = FindFirstFileEx(
|
||||||
filter.c_str(),
|
filter.c_str(),
|
||||||
(CSystem::GetOSPlatform() >= OSPLATFORM_7) ? FindExInfoBasic : FindExInfoStandard,
|
(Platform::IsAtLeastWin7()) ? FindExInfoBasic : FindExInfoStandard,
|
||||||
&fileData,
|
&fileData,
|
||||||
FindExSearchNameMatch,
|
FindExSearchNameMatch,
|
||||||
NULL,
|
NULL,
|
||||||
@ -1935,7 +1935,7 @@ void CRainmeter::ScanForLayouts()
|
|||||||
|
|
||||||
hSearch = FindFirstFileEx(
|
hSearch = FindFirstFileEx(
|
||||||
folders.c_str(),
|
folders.c_str(),
|
||||||
(CSystem::GetOSPlatform() >= OSPLATFORM_7) ? FindExInfoBasic : FindExInfoStandard,
|
(Platform::IsAtLeastWin7()) ? FindExInfoBasic : FindExInfoStandard,
|
||||||
&fileData,
|
&fileData,
|
||||||
FindExSearchNameMatch,
|
FindExSearchNameMatch,
|
||||||
NULL,
|
NULL,
|
||||||
|
@ -540,40 +540,6 @@ void CSystem::UpdateWorkareaInfo()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
** Sets the OS platform.
|
|
||||||
**
|
|
||||||
*/
|
|
||||||
OSPLATFORM CSystem::InitOSPlatform()
|
|
||||||
{
|
|
||||||
OSVERSIONINFOEX osvi = {sizeof(OSVERSIONINFOEX)};
|
|
||||||
if (GetVersionEx((OSVERSIONINFO*)&osvi))
|
|
||||||
{
|
|
||||||
switch (osvi.dwMajorVersion)
|
|
||||||
{
|
|
||||||
case 5:
|
|
||||||
// Not checking for osvi.dwMinorVersion >= 1 because Rainmeter won't run on pre-XP
|
|
||||||
return OSPLATFORM_XP;
|
|
||||||
|
|
||||||
case 6:
|
|
||||||
switch (osvi.dwMinorVersion)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
return OSPLATFORM_VISTA; // Vista, Server 2008
|
|
||||||
|
|
||||||
case 1:
|
|
||||||
return OSPLATFORM_7; // 7, Server 2008R2
|
|
||||||
|
|
||||||
default:
|
|
||||||
return OSPLATFORM_8; // 8, Server 2012
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return OSPLATFORM_8; // newer OS
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Finds the Default Shell's window.
|
** Finds the Default Shell's window.
|
||||||
**
|
**
|
||||||
@ -1125,7 +1091,7 @@ void CSystem::ResetWorkingDirectory()
|
|||||||
void CSystem::InitializeCriticalSection(LPCRITICAL_SECTION lpCriticalSection)
|
void CSystem::InitializeCriticalSection(LPCRITICAL_SECTION lpCriticalSection)
|
||||||
{
|
{
|
||||||
typedef BOOL (WINAPI * FPINITCRITEX)(LPCRITICAL_SECTION lpCriticalSection, DWORD dwSpinCount, DWORD Flags);
|
typedef BOOL (WINAPI * FPINITCRITEX)(LPCRITICAL_SECTION lpCriticalSection, DWORD dwSpinCount, DWORD Flags);
|
||||||
static FPINITCRITEX InitializeCriticalSectionEx = (GetOSPlatform() >= OSPLATFORM_VISTA) ?
|
static FPINITCRITEX InitializeCriticalSectionEx = Platform::IsAtLeastWinVista() ?
|
||||||
(FPINITCRITEX)GetProcAddress(GetModuleHandle(L"Kernel32"), "InitializeCriticalSectionEx") : nullptr;
|
(FPINITCRITEX)GetProcAddress(GetModuleHandle(L"Kernel32"), "InitializeCriticalSectionEx") : nullptr;
|
||||||
|
|
||||||
if (InitializeCriticalSectionEx)
|
if (InitializeCriticalSectionEx)
|
||||||
@ -1212,7 +1178,7 @@ void CSystem::SetWallpaper(const std::wstring& wallpaper, const std::wstring& st
|
|||||||
{
|
{
|
||||||
wallStyle = L"2";
|
wallStyle = L"2";
|
||||||
}
|
}
|
||||||
else if (GetOSPlatform() >= OSPLATFORM_7)
|
else if (Platform::IsAtLeastWin7())
|
||||||
{
|
{
|
||||||
if (_wcsicmp(option, L"FIT") == 0)
|
if (_wcsicmp(option, L"FIT") == 0)
|
||||||
{
|
{
|
||||||
|
@ -21,14 +21,7 @@
|
|||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include "../Common/Platform.h"
|
||||||
enum OSPLATFORM
|
|
||||||
{
|
|
||||||
OSPLATFORM_XP,
|
|
||||||
OSPLATFORM_VISTA,
|
|
||||||
OSPLATFORM_7,
|
|
||||||
OSPLATFORM_8
|
|
||||||
};
|
|
||||||
|
|
||||||
struct MonitorInfo
|
struct MonitorInfo
|
||||||
{
|
{
|
||||||
@ -67,7 +60,6 @@ public:
|
|||||||
static HWND GetHelperWindow() { return c_HelperWindow; }
|
static HWND GetHelperWindow() { return c_HelperWindow; }
|
||||||
static void PrepareHelperWindow(HWND WorkerW = GetWorkerW());
|
static void PrepareHelperWindow(HWND WorkerW = GetWorkerW());
|
||||||
|
|
||||||
static OSPLATFORM GetOSPlatform() { static OSPLATFORM c_Platform = InitOSPlatform(); return c_Platform; }
|
|
||||||
static ULONGLONG GetTickCount64();
|
static ULONGLONG GetTickCount64();
|
||||||
static POINT GetCursorPosition();
|
static POINT GetCursorPosition();
|
||||||
|
|
||||||
@ -99,8 +91,6 @@ private:
|
|||||||
static void ClearMultiMonitorInfo() { c_Monitors.monitors.clear(); }
|
static void ClearMultiMonitorInfo() { c_Monitors.monitors.clear(); }
|
||||||
static void UpdateWorkareaInfo();
|
static void UpdateWorkareaInfo();
|
||||||
|
|
||||||
static OSPLATFORM InitOSPlatform();
|
|
||||||
|
|
||||||
static HWND GetDefaultShellWindow();
|
static HWND GetDefaultShellWindow();
|
||||||
static HWND GetWorkerW();
|
static HWND GetWorkerW();
|
||||||
static void ChangeZPosInOrder();
|
static void ChangeZPosInOrder();
|
||||||
|
@ -309,7 +309,7 @@ void CTrayWindow::ShowNotification(TRAY_NOTIFICATION id, const WCHAR* title, con
|
|||||||
wcsncpy_s(nid.szInfoTitle, title, _TRUNCATE);
|
wcsncpy_s(nid.szInfoTitle, title, _TRUNCATE);
|
||||||
wcsncpy_s(nid.szInfo, text, _TRUNCATE);
|
wcsncpy_s(nid.szInfo, text, _TRUNCATE);
|
||||||
|
|
||||||
if (CSystem::GetOSPlatform() > OSPLATFORM_VISTA)
|
if (Platform::IsAtLeastWinVista())
|
||||||
{
|
{
|
||||||
nid.dwInfoFlags |= NIIF_LARGE_ICON;
|
nid.dwInfoFlags |= NIIF_LARGE_ICON;
|
||||||
nid.hBalloonIcon = GetIcon(IDI_RAINMETER, true);
|
nid.hBalloonIcon = GetIcon(IDI_RAINMETER, true);
|
||||||
|
Loading…
Reference in New Issue
Block a user