diff options
| author | Martin Rudalics | 2017-04-11 12:37:26 +0200 |
|---|---|---|
| committer | Martin Rudalics | 2017-04-11 12:37:26 +0200 |
| commit | ea6c880aa68bcc8f0e388ecbd8c552392488b38f (patch) | |
| tree | c4da212b292347d6668dc6283f8444fc795f6e2c /src/w32term.c | |
| parent | 0eef8e9af7707b7bd01243033b9a48cb74fb8672 (diff) | |
| download | emacs-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.c | 6 |
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; |