aboutsummaryrefslogtreecommitdiffstats
path: root/src/w32term.c
diff options
context:
space:
mode:
authorMartin Rudalics2017-04-11 12:37:26 +0200
committerMartin Rudalics2017-04-11 12:37:26 +0200
commitea6c880aa68bcc8f0e388ecbd8c552392488b38f (patch)
treec4da212b292347d6668dc6283f8444fc795f6e2c /src/w32term.c
parent0eef8e9af7707b7bd01243033b9a48cb74fb8672 (diff)
downloademacs-ea6c880aa68bcc8f0e388ecbd8c552392488b38f.tar.gz
emacs-ea6c880aa68bcc8f0e388ecbd8c552392488b38f.zip
Frame movement, focus and hook related changes
New hook `move-frame-functions'. Run `focus-in-hook' after switching to frame that gets focus. Don't run XMoveWindow for GTK. * lisp/frame.el (handle-move-frame, frame-size-changed-p): New functions. * src/frame.c (do_switch_frame): Simplify code. (Fhandle_switch_frame): Switch frame before running `handle-focus-in'. (Vfocus_in_hook, Vfocus_out_hook): Clarify doc-strings. (Vmove_frame_functions): New hook variable. * src/keyboard.c (kbd_buffer_get_event): Handle MOVE_FRAME_EVENT. Handle SELECT_WINDOW_EVENT separately. (head_table): Add Qmove_frame entry. (syms_of_keyboard): Add Qmove_frame. (keys_of_keyboard): Define key for `move-frame'. * src/termhooks.h (event_kind): Add MOVE_FRAME_EVENT. * src/w32term.c (w32_read_socket): Create MOVE_FRAME_EVENT. * src/window.c (run_window_size_change_functions): Record size of FRAME's minibuffer window too. * src/xterm.c (handle_one_xevent): Create MOVE_FRAME_EVENT. (x_set_offset): For GTK call gtk_widget_move instead of XMoveWindow.
Diffstat (limited to 'src/w32term.c')
-rw-r--r--src/w32term.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/w32term.c b/src/w32term.c
index 81666f5bc47..31f0b4a2fa0 100644
--- a/src/w32term.c
+++ b/src/w32term.c
@@ -5038,7 +5038,11 @@ w32_read_socket (struct terminal *terminal,
5038 f = x_window_to_frame (dpyinfo, msg.msg.hwnd); 5038 f = x_window_to_frame (dpyinfo, msg.msg.hwnd);
5039 5039
5040 if (f && !FRAME_ICONIFIED_P (f)) 5040 if (f && !FRAME_ICONIFIED_P (f))
5041 x_real_positions (f, &f->left_pos, &f->top_pos); 5041 {
5042 x_real_positions (f, &f->left_pos, &f->top_pos);
5043 inev.kind = MOVE_FRAME_EVENT;
5044 XSETFRAME (inev.frame_or_window, f);
5045 }
5042 5046
5043 check_visibility = 1; 5047 check_visibility = 1;
5044 break; 5048 break;