diff options
author | Charles A. Roelli <charles@aurox.ch> | 2017-04-27 20:44:09 +0200 |
---|---|---|
committer | Alan Third <alan@idiocy.org> | 2017-05-02 21:28:42 +0100 |
commit | 6e0cac4896f70b28b2a608fd63bc88b0253313bf (patch) | |
tree | e95f69e219aee4277d8fd98cf01047fcb340503f | |
parent | b50dda3fa2d21973cd87b537a746f5ed70bdc9af (diff) | |
download | emacs-6e0cac4896f70b28b2a608fd63bc88b0253313bf.tar.gz |
Constrain non-child frames to screen area in OS X
* src/nsterm.m (constrainFrameRect:toScreen:): Constrain non-child
frames in OS X, if they would otherwise go offscreen.
Fixes: debbugs:25818
-rw-r--r-- | src/nsterm.m | 35 |
1 files changed, 34 insertions, 1 deletions
diff --git a/src/nsterm.m b/src/nsterm.m index f75a9fe2be8..c22c5a70baa 100644 --- a/src/nsterm.m +++ b/src/nsterm.m @@ -8040,7 +8040,40 @@ not_in_argv (NSString *arg) NSTRACE_RETURN_RECT (frameRect); return frameRect; } -#endif + else +#endif /* MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_9 */ + // Check that the proposed frameRect is visible in at least one + // screen. If it is not, ask the system to reposition it (only + // for non-child windows). + + if (!FRAME_PARENT_FRAME (((EmacsView *)[self delegate])->emacsframe)) + { + NSArray *screens = [NSScreen screens]; + NSUInteger nr_screens = [screens count]; + + int i; + BOOL frame_on_screen = NO; + + for (i = 0; i < nr_screens; ++i) + { + NSScreen *s = [screens objectAtIndex: i]; + NSRect scrRect = [s frame]; + + if (NSIntersectsRect(frameRect, scrRect)) + { + frame_on_screen = YES; + break; + } + } + + if (!frame_on_screen) + { + NSTRACE_MSG ("Frame outside screens; constraining"); + frameRect = [super constrainFrameRect:frameRect toScreen:screen]; + NSTRACE_RETURN_RECT (frameRect); + return frameRect; + } + } #endif return constrain_frame_rect(frameRect, |