winemac: Don't assume the current display mode is the original if we don't have the displays captured.
Another process may have changed the display mode before we queried the current mode, so we may be seeing a non-original mode.
This commit is contained in:
parent
fe1c0ab952
commit
9c65d672a2
|
@ -726,18 +726,16 @@ - (BOOL) setMode:(CGDisplayModeRef)mode forDisplay:(CGDirectDisplayID)displayID
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CGDisplayModeRelease(currentMode);
|
||||||
|
currentMode = NULL;
|
||||||
|
|
||||||
mode = [self modeMatchingMode:mode forDisplay:displayID];
|
mode = [self modeMatchingMode:mode forDisplay:displayID];
|
||||||
if (!mode)
|
if (!mode)
|
||||||
{
|
|
||||||
CGDisplayModeRelease(currentMode);
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
|
||||||
|
|
||||||
originalMode = (CGDisplayModeRef)[originalDisplayModes objectForKey:displayIDKey];
|
originalMode = (CGDisplayModeRef)[originalDisplayModes objectForKey:displayIDKey];
|
||||||
if (!originalMode)
|
|
||||||
originalMode = currentMode;
|
|
||||||
|
|
||||||
if ([self mode:mode matchesMode:originalMode])
|
if (originalMode && [self mode:mode matchesMode:originalMode])
|
||||||
{
|
{
|
||||||
if ([originalDisplayModes count] == 1) // If this is the last changed display, do a blanket reset
|
if ([originalDisplayModes count] == 1) // If this is the last changed display, do a blanket reset
|
||||||
{
|
{
|
||||||
|
@ -771,8 +769,17 @@ - (BOOL) setMode:(CGDisplayModeRef)mode forDisplay:(CGDirectDisplayID)displayID
|
||||||
{
|
{
|
||||||
if (active)
|
if (active)
|
||||||
{
|
{
|
||||||
ret = (CGDisplaySetDisplayMode(displayID, mode, NULL) == CGDisplayNoErr);
|
// If we get here, we have the displays captured. If we don't
|
||||||
if (ret)
|
// know the original mode of the display, the current mode must
|
||||||
|
// be the original. We should re-query the current mode since
|
||||||
|
// another process could have changed it between when we last
|
||||||
|
// checked and when we captured the displays.
|
||||||
|
if (!originalMode)
|
||||||
|
originalMode = currentMode = CGDisplayCopyDisplayMode(displayID);
|
||||||
|
|
||||||
|
if (originalMode)
|
||||||
|
ret = (CGDisplaySetDisplayMode(displayID, mode, NULL) == CGDisplayNoErr);
|
||||||
|
if (ret && !(currentMode && [self mode:mode matchesMode:currentMode]))
|
||||||
[originalDisplayModes setObject:(id)originalMode forKey:displayIDKey];
|
[originalDisplayModes setObject:(id)originalMode forKey:displayIDKey];
|
||||||
else if (![originalDisplayModes count])
|
else if (![originalDisplayModes count])
|
||||||
{
|
{
|
||||||
|
@ -781,6 +788,9 @@ - (BOOL) setMode:(CGDisplayModeRef)mode forDisplay:(CGDirectDisplayID)displayID
|
||||||
if (!displaysCapturedForFullscreen)
|
if (!displaysCapturedForFullscreen)
|
||||||
CGReleaseAllDisplays();
|
CGReleaseAllDisplays();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (currentMode)
|
||||||
|
CGDisplayModeRelease(currentMode);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -790,8 +800,6 @@ - (BOOL) setMode:(CGDisplayModeRef)mode forDisplay:(CGDirectDisplayID)displayID
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CGDisplayModeRelease(currentMode);
|
|
||||||
|
|
||||||
if (ret)
|
if (ret)
|
||||||
[self adjustWindowLevels];
|
[self adjustWindowLevels];
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue