Commit c62a39ca authored by Pierre d'Herbemont's avatar Pierre d'Herbemont

Mac OS X gui: Fix a double unlock issue, by making sure all timers are...

Mac OS X gui: Fix a double unlock issue, by making sure all timers are disabled when checking if we have to unlock. (Pointed by Felix Paul Kuhne)
parent 161c8a3b
...@@ -174,13 +174,6 @@ ...@@ -174,13 +174,6 @@
[self lockFullscreenAnimation]; [self lockFullscreenAnimation];
/* This is a recursive lock. If we are already in the middle of an animation we
* unlock it. We don't add an extra locking here, because enter/leavefullscreen
* are executed always in the same thread */
if (b_animation_lock_alreadylocked)
[self unlockFullscreenAnimation];
b_animation_lock_alreadylocked = YES;
if (!screen) if (!screen)
screen = [self screen]; screen = [self screen];
...@@ -248,16 +241,16 @@ ...@@ -248,16 +241,16 @@
{ {
/* We were already fullscreen nothing to do when NSAnimation /* We were already fullscreen nothing to do when NSAnimation
* is not supported */ * is not supported */
[self unlockFullscreenAnimation];
b_animation_lock_alreadylocked = NO; b_animation_lock_alreadylocked = NO;
[self unlockFullscreenAnimation];
return; return;
} }
/* We are in fullscreen (and no animation is running) */ /* We are in fullscreen (and no animation is running) */
if (b_fullscreen) if (b_fullscreen)
{ {
[self unlockFullscreenAnimation];
b_animation_lock_alreadylocked = NO; b_animation_lock_alreadylocked = NO;
[self unlockFullscreenAnimation];
return; return;
} }
...@@ -272,6 +265,13 @@ ...@@ -272,6 +265,13 @@
[o_fullscreen_anim2 release]; [o_fullscreen_anim2 release];
} }
/* This is a recursive lock. If we are already in the middle of an animation we
* unlock it. We don't add an extra locking here, because enter/leavefullscreen
* are executed always in the same thread */
if (b_animation_lock_alreadylocked)
[self unlockFullscreenAnimation];
b_animation_lock_alreadylocked = YES;
if ([screen isMainScreen]) if ([screen isMainScreen])
SetSystemUIMode( kUIModeAllHidden, kUIOptionAutoShowMenuBar); SetSystemUIMode( kUIModeAllHidden, kUIOptionAutoShowMenuBar);
...@@ -331,13 +331,6 @@ ...@@ -331,13 +331,6 @@
[self lockFullscreenAnimation]; [self lockFullscreenAnimation];
/* This is a recursive lock. If we are already in the middle of an animation we
* unlock it. We don't add an extra locking here, because enter/leavefullscreen
* are executed always in the same thread */
if (b_animation_lock_alreadylocked)
[self unlockFullscreenAnimation];
b_animation_lock_alreadylocked = YES;
b_fullscreen = NO; b_fullscreen = NO;
[o_btn_fullscreen setState: NO]; [o_btn_fullscreen setState: NO];
...@@ -347,8 +340,8 @@ ...@@ -347,8 +340,8 @@
/* Don't do anything if o_fullscreen_window is already closed */ /* Don't do anything if o_fullscreen_window is already closed */
if (!o_fullscreen_window) if (!o_fullscreen_window)
{ {
[self unlockFullscreenAnimation];
b_animation_lock_alreadylocked = NO; b_animation_lock_alreadylocked = NO;
[self unlockFullscreenAnimation];
return; return;
} }
...@@ -387,6 +380,13 @@ ...@@ -387,6 +380,13 @@
[o_fullscreen_anim2 release]; [o_fullscreen_anim2 release];
} }
/* This is a recursive lock. If we are already in the middle of an animation we
* unlock it. We don't add an extra locking here, because enter/leavefullscreen
* are executed always in the same thread */
if (b_animation_lock_alreadylocked)
[self unlockFullscreenAnimation];
b_animation_lock_alreadylocked = YES;
frame = [[o_temp_view superview] convertRect: [o_temp_view frame] toView: nil]; /* Convert to Window base coord */ frame = [[o_temp_view superview] convertRect: [o_temp_view frame] toView: nil]; /* Convert to Window base coord */
frame.origin.x += [self frame].origin.x; frame.origin.x += [self frame].origin.x;
frame.origin.y += [self frame].origin.y; frame.origin.y += [self frame].origin.y;
...@@ -438,8 +438,8 @@ ...@@ -438,8 +438,8 @@
[o_fullscreen_window release]; [o_fullscreen_window release];
o_fullscreen_window = nil; o_fullscreen_window = nil;
[self unlockFullscreenAnimation];
b_animation_lock_alreadylocked = NO; b_animation_lock_alreadylocked = NO;
[self unlockFullscreenAnimation];
} }
- (void)animationDidEnd:(NSAnimation*)animation - (void)animationDidEnd:(NSAnimation*)animation
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment