mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-22 18:35:09 +00:00
Add no-accept-focus and frame-list-z-order to NS port
* lisp/frame.el (frame-list-z-order): Add NS. * src/nsfns.m: Add x_set_no_accept_focus to handler struct. (Fx_create_frame): Handle no-accept-focus parameter. (ns_window_is_ancestor): (Fns_frame_list_z_order): New functions. * src/nsterm.m (x_set_no_accept_focus): New function. (initFrameFromEmacs): Use EmacsWindow instead of EmacsFSWindow for non-fullscreen windows. (EmacsWindow:canBecomeKeyWindow): New function.
This commit is contained in:
parent
a3b8618d79
commit
d812d20fbc
@ -1500,6 +1500,7 @@ keys and their meanings."
|
|||||||
|
|
||||||
(declare-function x-frame-list-z-order "xfns.c" (&optional display))
|
(declare-function x-frame-list-z-order "xfns.c" (&optional display))
|
||||||
(declare-function w32-frame-list-z-order "w32fns.c" (&optional display))
|
(declare-function w32-frame-list-z-order "w32fns.c" (&optional display))
|
||||||
|
(declare-function ns-frame-list-z-order "nsfns.m" (&optional display))
|
||||||
|
|
||||||
(defun frame-list-z-order (&optional display)
|
(defun frame-list-z-order (&optional display)
|
||||||
"Return list of Emacs' frames, in Z (stacking) order.
|
"Return list of Emacs' frames, in Z (stacking) order.
|
||||||
@ -1517,10 +1518,13 @@ Return nil if DISPLAY contains no Emacs frame."
|
|||||||
((eq frame-type 'x)
|
((eq frame-type 'x)
|
||||||
(x-frame-list-z-order display))
|
(x-frame-list-z-order display))
|
||||||
((eq frame-type 'w32)
|
((eq frame-type 'w32)
|
||||||
(w32-frame-list-z-order display)))))
|
(w32-frame-list-z-order display))
|
||||||
|
((eq frame-type 'ns)
|
||||||
|
(ns-frame-list-z-order display)))))
|
||||||
|
|
||||||
(declare-function x-frame-restack "xfns.c" (frame1 frame2 &optional above))
|
(declare-function x-frame-restack "xfns.c" (frame1 frame2 &optional above))
|
||||||
(declare-function w32-frame-restack "w32fns.c" (frame1 frame2 &optional above))
|
(declare-function w32-frame-restack "w32fns.c" (frame1 frame2 &optional above))
|
||||||
|
(declare-function ns-frame-restack "nsfns.m" (frame1 frame2 &optional above))
|
||||||
|
|
||||||
(defun frame-restack (frame1 frame2 &optional above)
|
(defun frame-restack (frame1 frame2 &optional above)
|
||||||
"Restack FRAME1 below FRAME2.
|
"Restack FRAME1 below FRAME2.
|
||||||
|
61
src/nsfns.m
61
src/nsfns.m
@ -973,14 +973,14 @@ Turn the input menu (an NSMenu) into a lisp list for tracking on lisp side
|
|||||||
0, /* x_set_tool_bar_position */
|
0, /* x_set_tool_bar_position */
|
||||||
0, /* x_set_inhibit_double_buffering */
|
0, /* x_set_inhibit_double_buffering */
|
||||||
#ifdef NS_IMPL_COCOA
|
#ifdef NS_IMPL_COCOA
|
||||||
x_set_undecorated, /* x_set_undecorated */
|
x_set_undecorated,
|
||||||
#else
|
#else
|
||||||
0, /*x_set_undecorated */
|
0, /*x_set_undecorated */
|
||||||
#endif
|
#endif
|
||||||
x_set_parent_frame, /* x_set_parent_frame */
|
x_set_parent_frame,
|
||||||
0, /* x_set_skip_taskbar */
|
0, /* x_set_skip_taskbar */
|
||||||
0, /* x_set_no_focus_on_map */
|
0, /* x_set_no_focus_on_map */
|
||||||
0, /* x_set_no_accept_focus */
|
x_set_no_accept_focus,
|
||||||
x_set_z_group, /* x_set_z_group */
|
x_set_z_group, /* x_set_z_group */
|
||||||
0, /* x_set_override_redirect */
|
0, /* x_set_override_redirect */
|
||||||
};
|
};
|
||||||
@ -1287,6 +1287,8 @@ Turn the input menu (an NSMenu) into a lisp list for tracking on lisp side
|
|||||||
store_frame_param (f, Qparent_frame, parent_frame);
|
store_frame_param (f, Qparent_frame, parent_frame);
|
||||||
|
|
||||||
x_default_parameter (f, parms, Qz_group, Qnil, NULL, NULL, RES_TYPE_SYMBOL);
|
x_default_parameter (f, parms, Qz_group, Qnil, NULL, NULL, RES_TYPE_SYMBOL);
|
||||||
|
x_default_parameter (f, parms, Qno_accept_focus, Qnil,
|
||||||
|
NULL, NULL, RES_TYPE_BOOLEAN);
|
||||||
|
|
||||||
/* The resources controlling the menu-bar and tool-bar are
|
/* The resources controlling the menu-bar and tool-bar are
|
||||||
processed specially at startup, and reflected in the mode
|
processed specially at startup, and reflected in the mode
|
||||||
@ -1428,6 +1430,58 @@ Turn the input menu (an NSMenu) into a lisp list for tracking on lisp side
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static BOOL
|
||||||
|
ns_window_is_ancestor (NSWindow *win, NSWindow *candidate)
|
||||||
|
/* Test whether CANDIDATE is an ancestor window of WIN. */
|
||||||
|
{
|
||||||
|
if (candidate == NULL)
|
||||||
|
return NO;
|
||||||
|
else if (win == candidate)
|
||||||
|
return YES;
|
||||||
|
else
|
||||||
|
return ns_window_is_ancestor(win, [candidate parentWindow]);
|
||||||
|
}
|
||||||
|
|
||||||
|
DEFUN ("ns-frame-list-z-order", Fns_frame_list_z_order,
|
||||||
|
Sns_frame_list_z_order, 0, 1, 0,
|
||||||
|
doc: /* Return list of Emacs' frames, in Z (stacking) order.
|
||||||
|
The optional argument TERMINAL specifies which display to ask about.
|
||||||
|
TERMINAL should be either a frame or a display name (a string). If
|
||||||
|
omitted or nil, that stands for the selected frame's display. Return
|
||||||
|
nil if TERMINAL contains no Emacs frame.
|
||||||
|
|
||||||
|
As a special case, if TERMINAL is non-nil and specifies a live frame,
|
||||||
|
return the child frames of that frame in Z (stacking) order.
|
||||||
|
|
||||||
|
Frames are listed from topmost (first) to bottommost (last). */)
|
||||||
|
(Lisp_Object terminal)
|
||||||
|
{
|
||||||
|
NSArray *list = [NSApp orderedWindows];
|
||||||
|
Lisp_Object frames = Qnil;
|
||||||
|
|
||||||
|
if (FRAMEP (terminal) && FRAME_LIVE_P (XFRAME (terminal)))
|
||||||
|
{
|
||||||
|
/* Filter LIST to just those that are ancestors of TERMINAL. */
|
||||||
|
NSWindow *win = [FRAME_NS_VIEW (XFRAME (terminal)) window];
|
||||||
|
|
||||||
|
NSPredicate *ancestor_pred =
|
||||||
|
[NSPredicate predicateWithBlock:^BOOL(id candidate, NSDictionary *bind) {
|
||||||
|
return ns_window_is_ancestor (win, [(NSWindow *)candidate parentWindow]);
|
||||||
|
}];
|
||||||
|
|
||||||
|
list = [[NSApp orderedWindows] filteredArrayUsingPredicate: ancestor_pred];
|
||||||
|
}
|
||||||
|
|
||||||
|
for (NSWindow *win in [list reverseObjectEnumerator])
|
||||||
|
{
|
||||||
|
Lisp_Object frame;
|
||||||
|
XSETFRAME (frame, ((EmacsView *)[win delegate])->emacsframe);
|
||||||
|
frames = Fcons(frame, frames);
|
||||||
|
}
|
||||||
|
|
||||||
|
return frames;
|
||||||
|
}
|
||||||
|
|
||||||
DEFUN ("ns-frame-restack", Fns_frame_restack, Sns_frame_restack, 2, 3, 0,
|
DEFUN ("ns-frame-restack", Fns_frame_restack, Sns_frame_restack, 2, 3, 0,
|
||||||
doc: /* Restack FRAME1 below FRAME2.
|
doc: /* Restack FRAME1 below FRAME2.
|
||||||
This means that if both frames are visible and the display areas of
|
This means that if both frames are visible and the display areas of
|
||||||
@ -3188,6 +3242,7 @@ - (NSString *)panel: (id)sender userEnteredFilename: (NSString *)filename
|
|||||||
defsubr (&Sns_display_monitor_attributes_list);
|
defsubr (&Sns_display_monitor_attributes_list);
|
||||||
defsubr (&Sns_frame_geometry);
|
defsubr (&Sns_frame_geometry);
|
||||||
defsubr (&Sns_frame_edges);
|
defsubr (&Sns_frame_edges);
|
||||||
|
defsubr (&Sns_frame_list_z_order);
|
||||||
defsubr (&Sns_frame_restack);
|
defsubr (&Sns_frame_restack);
|
||||||
defsubr (&Sx_display_mm_width);
|
defsubr (&Sx_display_mm_width);
|
||||||
defsubr (&Sx_display_mm_height);
|
defsubr (&Sx_display_mm_height);
|
||||||
|
@ -1212,6 +1212,8 @@ extern void x_set_undecorated (struct frame *f, Lisp_Object new_value,
|
|||||||
Lisp_Object old_value);
|
Lisp_Object old_value);
|
||||||
extern void x_set_parent_frame (struct frame *f, Lisp_Object new_value,
|
extern void x_set_parent_frame (struct frame *f, Lisp_Object new_value,
|
||||||
Lisp_Object old_value);
|
Lisp_Object old_value);
|
||||||
|
extern void x_set_no_accept_focus (struct frame *f, Lisp_Object new_value,
|
||||||
|
Lisp_Object old_value);
|
||||||
extern void x_set_z_group (struct frame *f, Lisp_Object new_value,
|
extern void x_set_z_group (struct frame *f, Lisp_Object new_value,
|
||||||
Lisp_Object old_value);
|
Lisp_Object old_value);
|
||||||
extern int ns_select (int nfds, fd_set *readfds, fd_set *writefds,
|
extern int ns_select (int nfds, fd_set *readfds, fd_set *writefds,
|
||||||
|
22
src/nsterm.m
22
src/nsterm.m
@ -1912,6 +1912,21 @@ so some key presses (TAB) are swallowed by the system. */
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
x_set_no_accept_focus (struct frame *f, Lisp_Object new_value, Lisp_Object old_value)
|
||||||
|
/* Set frame F's `no-accept-focus' parameter which, if non-nil, hints
|
||||||
|
* that F's window-system window does not want to receive input focus
|
||||||
|
* via mouse clicks or by moving the mouse into it.
|
||||||
|
*
|
||||||
|
* If non-nil, this may have the unwanted side-effect that a user cannot
|
||||||
|
* scroll a non-selected frame with the mouse.
|
||||||
|
*
|
||||||
|
* Some window managers may not honor this parameter. */
|
||||||
|
{
|
||||||
|
if (!EQ (new_value, old_value))
|
||||||
|
FRAME_NO_ACCEPT_FOCUS (f) = !NILP (new_value);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
x_set_z_group (struct frame *f, Lisp_Object new_value, Lisp_Object old_value)
|
x_set_z_group (struct frame *f, Lisp_Object new_value, Lisp_Object old_value)
|
||||||
/* Set frame F's `z-group' parameter. If `above', F's window-system
|
/* Set frame F's `z-group' parameter. If `above', F's window-system
|
||||||
@ -6900,7 +6915,7 @@ This avoids an extra clear and redraw (flicker) at frame creation. */
|
|||||||
maximizing_resize = NO;
|
maximizing_resize = NO;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
win = [[EmacsFSWindow alloc]
|
win = [[EmacsWindow alloc]
|
||||||
initWithContentRect: r
|
initWithContentRect: r
|
||||||
styleMask: (FRAME_UNDECORATED (f)
|
styleMask: (FRAME_UNDECORATED (f)
|
||||||
? NSWindowStyleMaskBorderless
|
? NSWindowStyleMaskBorderless
|
||||||
@ -8130,6 +8145,11 @@ - (void)setFrameTopLeftPoint:(NSPoint)point
|
|||||||
|
|
||||||
[super setFrameTopLeftPoint:point];
|
[super setFrameTopLeftPoint:point];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (BOOL)canBecomeKeyWindow
|
||||||
|
{
|
||||||
|
return !FRAME_NO_ACCEPT_FOCUS (((EmacsView *)[self delegate])->emacsframe);
|
||||||
|
}
|
||||||
@end /* EmacsWindow */
|
@end /* EmacsWindow */
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user