mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
Remove hard dependencies on multi-monitor functions.
These are more functions that don't exist on all our supported legacy versions of Windows, so we need to follow the same policy as everywhere else, by trying to acquire them at run time and having a fallback if they aren't available.
This commit is contained in:
parent
83ff08f9db
commit
01c007121a
@ -197,6 +197,9 @@ bool tried_pal = false;
|
|||||||
COLORREF colorref_modifier = 0;
|
COLORREF colorref_modifier = 0;
|
||||||
|
|
||||||
enum MONITOR_DPI_TYPE { MDT_EFFECTIVE_DPI, MDT_ANGULAR_DPI, MDT_RAW_DPI, MDT_DEFAULT };
|
enum MONITOR_DPI_TYPE { MDT_EFFECTIVE_DPI, MDT_ANGULAR_DPI, MDT_RAW_DPI, MDT_DEFAULT };
|
||||||
|
DECL_WINDOWS_FUNCTION(static, BOOL, GetMonitorInfoA, (HMONITOR, LPMONITORINFO));
|
||||||
|
DECL_WINDOWS_FUNCTION(static, HMONITOR, MonitorFromPoint, (POINT, DWORD));
|
||||||
|
DECL_WINDOWS_FUNCTION(static, HMONITOR, MonitorFromWindow, (HWND, DWORD));
|
||||||
DECL_WINDOWS_FUNCTION(static, HRESULT, GetDpiForMonitor, (HMONITOR hmonitor, enum MONITOR_DPI_TYPE dpiType, UINT *dpiX, UINT *dpiY));
|
DECL_WINDOWS_FUNCTION(static, HRESULT, GetDpiForMonitor, (HMONITOR hmonitor, enum MONITOR_DPI_TYPE dpiType, UINT *dpiX, UINT *dpiY));
|
||||||
DECL_WINDOWS_FUNCTION(static, HRESULT, GetSystemMetricsForDpi, (int nIndex, UINT dpi));
|
DECL_WINDOWS_FUNCTION(static, HRESULT, GetSystemMetricsForDpi, (int nIndex, UINT dpi));
|
||||||
DECL_WINDOWS_FUNCTION(static, HRESULT, AdjustWindowRectExForDpi, (LPRECT lpRect, DWORD dwStyle, BOOL bMenu, DWORD dwExStyle, UINT dpi));
|
DECL_WINDOWS_FUNCTION(static, HRESULT, AdjustWindowRectExForDpi, (LPRECT lpRect, DWORD dwStyle, BOOL bMenu, DWORD dwExStyle, UINT dpi));
|
||||||
@ -1293,9 +1296,9 @@ static int get_font_width(HDC hdc, const TEXTMETRIC *tm)
|
|||||||
static void init_dpi_info(void)
|
static void init_dpi_info(void)
|
||||||
{
|
{
|
||||||
if (dpi_info.cur_dpi.x == 0 || dpi_info.cur_dpi.y == 0) {
|
if (dpi_info.cur_dpi.x == 0 || dpi_info.cur_dpi.y == 0) {
|
||||||
if (p_GetDpiForMonitor) {
|
if (p_GetDpiForMonitor && p_MonitorFromWindow) {
|
||||||
UINT dpiX, dpiY;
|
UINT dpiX, dpiY;
|
||||||
HMONITOR currentMonitor = MonitorFromWindow(
|
HMONITOR currentMonitor = p_MonitorFromWindow(
|
||||||
wgs.term_hwnd, MONITOR_DEFAULTTOPRIMARY);
|
wgs.term_hwnd, MONITOR_DEFAULTTOPRIMARY);
|
||||||
if (p_GetDpiForMonitor(currentMonitor, MDT_EFFECTIVE_DPI,
|
if (p_GetDpiForMonitor(currentMonitor, MDT_EFFECTIVE_DPI,
|
||||||
&dpiX, &dpiY) == S_OK) {
|
&dpiX, &dpiY) == S_OK) {
|
||||||
@ -2618,27 +2621,26 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
|
|||||||
|
|
||||||
GetCursorPos(&pt);
|
GetCursorPos(&pt);
|
||||||
#ifndef NO_MULTIMON
|
#ifndef NO_MULTIMON
|
||||||
{
|
if (p_GetMonitorInfoA && p_MonitorFromPoint) {
|
||||||
HMONITOR mon;
|
HMONITOR mon;
|
||||||
MONITORINFO mi;
|
MONITORINFO mi;
|
||||||
|
|
||||||
mon = MonitorFromPoint(pt, MONITOR_DEFAULTTONULL);
|
mon = p_MonitorFromPoint(pt, MONITOR_DEFAULTTONULL);
|
||||||
|
|
||||||
if (mon != NULL) {
|
if (mon != NULL) {
|
||||||
mi.cbSize = sizeof(MONITORINFO);
|
mi.cbSize = sizeof(MONITORINFO);
|
||||||
GetMonitorInfo(mon, &mi);
|
p_GetMonitorInfoA(mon, &mi);
|
||||||
|
|
||||||
if (mi.rcMonitor.left == pt.x &&
|
if (mi.rcMonitor.left == pt.x &&
|
||||||
mi.rcMonitor.top == pt.y) {
|
mi.rcMonitor.top == pt.y) {
|
||||||
mouse_on_hotspot = true;
|
mouse_on_hotspot = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} else
|
||||||
#else
|
#endif
|
||||||
if (pt.x == 0 && pt.y == 0) {
|
if (pt.x == 0 && pt.y == 0) {
|
||||||
mouse_on_hotspot = true;
|
mouse_on_hotspot = true;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
if (is_full_screen() && press &&
|
if (is_full_screen() && press &&
|
||||||
button == MBT_LEFT && mouse_on_hotspot) {
|
button == MBT_LEFT && mouse_on_hotspot) {
|
||||||
SendMessage(hwnd, WM_SYSCOMMAND, SC_MOUSEMENU,
|
SendMessage(hwnd, WM_SYSCOMMAND, SC_MOUSEMENU,
|
||||||
@ -4075,6 +4077,9 @@ static void init_winfuncs(void)
|
|||||||
GET_WINDOWS_FUNCTION(user32_module, FlashWindowEx);
|
GET_WINDOWS_FUNCTION(user32_module, FlashWindowEx);
|
||||||
GET_WINDOWS_FUNCTION(user32_module, ToUnicodeEx);
|
GET_WINDOWS_FUNCTION(user32_module, ToUnicodeEx);
|
||||||
GET_WINDOWS_FUNCTION_PP(winmm_module, PlaySound);
|
GET_WINDOWS_FUNCTION_PP(winmm_module, PlaySound);
|
||||||
|
GET_WINDOWS_FUNCTION_NO_TYPECHECK(user32_module, GetMonitorInfoA);
|
||||||
|
GET_WINDOWS_FUNCTION_NO_TYPECHECK(user32_module, MonitorFromPoint);
|
||||||
|
GET_WINDOWS_FUNCTION_NO_TYPECHECK(user32_module, MonitorFromWindow);
|
||||||
GET_WINDOWS_FUNCTION_NO_TYPECHECK(shcore_module, GetDpiForMonitor);
|
GET_WINDOWS_FUNCTION_NO_TYPECHECK(shcore_module, GetDpiForMonitor);
|
||||||
GET_WINDOWS_FUNCTION_NO_TYPECHECK(user32_module, GetSystemMetricsForDpi);
|
GET_WINDOWS_FUNCTION_NO_TYPECHECK(user32_module, GetSystemMetricsForDpi);
|
||||||
GET_WINDOWS_FUNCTION_NO_TYPECHECK(user32_module, AdjustWindowRectExForDpi);
|
GET_WINDOWS_FUNCTION_NO_TYPECHECK(user32_module, AdjustWindowRectExForDpi);
|
||||||
@ -5685,23 +5690,24 @@ static bool is_full_screen()
|
|||||||
static bool get_fullscreen_rect(RECT * ss)
|
static bool get_fullscreen_rect(RECT * ss)
|
||||||
{
|
{
|
||||||
#if defined(MONITOR_DEFAULTTONEAREST) && !defined(NO_MULTIMON)
|
#if defined(MONITOR_DEFAULTTONEAREST) && !defined(NO_MULTIMON)
|
||||||
|
if (p_GetMonitorInfoA && p_MonitorFromWindow) {
|
||||||
HMONITOR mon;
|
HMONITOR mon;
|
||||||
MONITORINFO mi;
|
MONITORINFO mi;
|
||||||
mon = MonitorFromWindow(wgs.term_hwnd, MONITOR_DEFAULTTONEAREST);
|
mon = p_MonitorFromWindow(wgs.term_hwnd, MONITOR_DEFAULTTONEAREST);
|
||||||
mi.cbSize = sizeof(mi);
|
mi.cbSize = sizeof(mi);
|
||||||
GetMonitorInfo(mon, &mi);
|
p_GetMonitorInfoA(mon, &mi);
|
||||||
|
|
||||||
/* structure copy */
|
/* structure copy */
|
||||||
*ss = mi.rcMonitor;
|
*ss = mi.rcMonitor;
|
||||||
return true;
|
return true;
|
||||||
#else
|
}
|
||||||
|
#endif
|
||||||
/* could also use code like this:
|
/* could also use code like this:
|
||||||
ss->left = ss->top = 0;
|
ss->left = ss->top = 0;
|
||||||
ss->right = GetSystemMetrics(SM_CXSCREEN);
|
ss->right = GetSystemMetrics(SM_CXSCREEN);
|
||||||
ss->bottom = GetSystemMetrics(SM_CYSCREEN);
|
ss->bottom = GetSystemMetrics(SM_CYSCREEN);
|
||||||
*/
|
*/
|
||||||
return GetClientRect(GetDesktopWindow(), ss);
|
return GetClientRect(GetDesktopWindow(), ss);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user