Lionのフルスクリーンに対応したパッチを書いてみました。このパッチはインライン入力パッチを当てたbzr HEAD向けに書いてあります。でも、たぶん23.3のリリース版でも行けるとはおいもます。
このパッチを当てる前に次のパッチを当ててください。ツールバーは非表示をお勧めします。表示しているとおかしくなるかもしれません。
=== modified file 'lisp/term/ns-win.el'
--- lisp/term/ns-win.el 2011-08-11 15:25:25 +0000
+++ lisp/term/ns-win.el 2011-08-11 15:29:03 +0000
@@ -912,6 +912,13 @@
(declare-function ns-emacs-info-panel "nsfns.m" ())
+(defun ns-fullscreen-toggle ()
+ (interactive)
+ (ns-fullscreen-toggle-cocoa))
+
+(declare-function ns-fullscreen-toggle "nsfns.m" ())
+
+
(defun ns-do-emacs-info-panel ()
(interactive)
(ns-emacs-info-panel))
=== modified file 'src/nsfns.m'
--- src/nsfns.m 2011-08-11 15:25:25 +0000
+++ src/nsfns.m 2011-08-11 16:03:46 +0000
@@ -2089,6 +2089,25 @@
else
error ("%s", SDATA (result));
}
+
+DEFUN ("ns-fullscreen-toggle-cocoa",Fns_fullscreen_toggle_cocoa,Sns_fullscreen_toggle_cocoa, 0, 0, 0,
+ doc: /* Toggle cooca full-screen */)
+ ()
+{
+ struct frame *sf = SELECTED_FRAME ();
+ check_ns();
+ if(sf)
+ {
+ BLOCK_INPUT;
+ EmacsView *view = (EmacsView*)FRAME_NS_VIEW(sf);
+ EmacsWindow *window = (EmacsWindow*)[view window];
+ [window toggleFullScreen:nil];
+
+ UNBLOCK_INPUT;
+ }
+ return 0;
+}
+
#endif
@@ -2665,6 +2684,7 @@
defsubr (&Sns_list_colors);
#ifdef NS_IMPL_COCOA
defsubr (&Sns_do_applescript);
+ defsubr (&Sns_fullscreen_toggle_cocoa);
#endif
defsubr (&Sxw_color_defined_p);
defsubr (&Sxw_color_values);
=== modified file 'src/nsmenu.m'
--- src/nsmenu.m 2011-06-16 15:31:16 +0000
+++ src/nsmenu.m 2011-08-11 17:00:38 +0000
@@ -1000,6 +1000,7 @@
-------------------------------------------------------------------------- */
{
[[FRAME_NS_VIEW (f) toolbar] setVisible: NO];
+ [[FRAME_NS_VIEW (f) window] setToolbar:nil];
}
void
@@ -1069,6 +1070,10 @@
#undef TOOLPROP
}
+ NSWindow *win = [FRAME_NS_VIEW (f) window];
+ if ([win toolbar] != toolbar)
+ [win setToolbar:toolbar];
+
if (![toolbar isVisible])
[toolbar setVisible: YES];
=== modified file 'src/nsterm.h'
--- src/nsterm.h 2011-08-11 15:25:25 +0000
+++ src/nsterm.h 2011-08-11 17:11:56 +0000
@@ -95,6 +95,9 @@
{
NSPoint grabOffset;
}
+
+- (BOOL) isFullScreen;
+
@end
=== modified file 'src/nsterm.m'
--- src/nsterm.m 2011-08-11 15:25:25 +0000
+++ src/nsterm.m 2011-08-11 17:09:55 +0000
@@ -1176,7 +1176,17 @@
/* constrain to screen if we can */
if (screen)
{
- NSSize sz = [screen visibleFrame].size;
+ NSSize sz = NSMakeSize(0,0);
+ if([[window className] compare:@"EmacsWindow"] == NSOrderedSame){
+ EmacsWindow *ew = (EmacsWindow *)window;
+ if([ew isFullScreen]){
+ sz = [screen frame].size;
+ sz.height += 22;
+ }
+ }
+ if(sz.width == 0 && sz.height == 0){
+ sz = [screen visibleFrame].size;
+ }
NSSize ez = { wr.size.width - sz.width, wr.size.height - sz.height };
if (ez.width > 0)
{
@@ -5156,6 +5166,7 @@
win = [[EmacsWindow alloc]
initWithContentRect: r
styleMask: (NSResizableWindowMask |
+ NSTitledWindowMask |
NSMiniaturizableWindowMask |
NSClosableWindowMask)
backing: NSBackingStoreBuffered
@@ -5187,8 +5198,8 @@
toolbar = [[EmacsToolbar alloc] initForView: self withIdentifier:
[NSString stringWithFormat: @"Emacs Frame %d",
ns_window_num]];
- [win setToolbar: toolbar];
- [toolbar setVisible: NO];
+ /* [win setToolbar: toolbar];
+ [toolbar setVisible: NO]; */
#ifdef NS_IMPL_COCOA
toggleButton = [win standardWindowButton: NSWindowToolbarButton];
[toggleButton setTarget: self];
@@ -5221,6 +5232,13 @@
[self allocateGState];
+ NSApplicationPresentationOptions options = [NSApp currentSystemPresentationOptions];
+ [NSApp setPresentationOptions: options |
+ NSApplicationPresentationFullScreen |
+ NSApplicationPresentationAutoHideToolbar];
+ [win setCollectionBehavior:[win collectionBehavior] | NSWindowCollectionBehaviorFullScreenPrimary];
+
+
ns_window_num++;
return self;
}
@@ -5725,6 +5743,27 @@
[super mouseDragged: theEvent];
}
+-(NSRect)constrainFrameRect:(NSRect)frameRect toScreen:(NSScreen *)aScreen
+{
+ if ([self isFullScreen]) {
+ NSRect result = [[NSScreen mainScreen] frame];
+ result.size.height += 22;
+ if([self toolbar])
+ result.size.height -= 32;
+ [[self delegate] windowWillResize:self toSize:result.size]; /* ad-hock implemention */
+ return result;
+ } else {
+ [[self delegate] windowWillResize:self toSize:frameRect.size]; /* ad-hock implemention */
+ return [super constrainFrameRect:frameRect toScreen:aScreen];
+ }
+}
+
+- (BOOL) isFullScreen
+{
+ BOOL inFullScreen = ([self styleMask] & NSFullScreenWindowMask) == NSFullScreenWindowMask;
+ return inFullScreen;
+}
+
@end /* EmacsWindow */