From: Eli Zaretskii Date: Fri, 12 Oct 2012 14:14:35 +0000 (+0200) Subject: Add comments about how non-GUI input works on MS-Windows. X-Git-Tag: emacs-24.2.90~235^2~17 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=605a3df6811c2b3ce9379149cc8fd64fc9846136;p=emacs.git Add comments about how non-GUI input works on MS-Windows. --- diff --git a/src/w32fns.c b/src/w32fns.c index 28a689ddc6c..c5e4be4ffc9 100644 --- a/src/w32fns.c +++ b/src/w32fns.c @@ -2333,7 +2333,9 @@ w32_name_of_message (UINT msg) } #endif /* EMACSDEBUG */ -/* Here's an overview of how Emacs input works on MS-Windows. +/* Here's an overview of how Emacs input works in GUI sessions on + MS-Windows. (For description of non-GUI input, see the commentary + before w32_console_read_socket in w32inevt.c.) System messages are read and processed by w32_msg_pump below. This function runs in a separate thread. It handles a small number of diff --git a/src/w32inevt.c b/src/w32inevt.c index c322d3a0b44..899a6fb89bf 100644 --- a/src/w32inevt.c +++ b/src/w32inevt.c @@ -576,6 +576,38 @@ maybe_generate_resize_event (void) 0, 0, 0); } +/* Here's an overview of how Emacs input works in non-GUI sessions on + MS-Windows. (For description of the GUI input, see the commentary + before w32_msg_pump in w32fns.c.) + + When Emacs is idle, it loops inside wait_reading_process_output, + calling pselect periodically to check whether any input is + available. On Windows, pselect is redirected to sys_select, which + uses MsgWaitForMultipleObjects to wait for input, either from the + keyboard or from any of the Emacs subprocesses. In addition, + MsgWaitForMultipleObjects wakes up when some Windows message is + posted to the input queue of the Emacs's main thread (which is the + thread in which sys_select runs). + + When the Emacs's console window has focus, Windows sends input + events that originate from the keyboard or the mouse; these events + wake up MsgWaitForMultipleObjects, which reports that input is + available. Emacs then calls w32_console_read_socket, below, to + read the input. w32_console_read_socket uses + GetNumberOfConsoleInputEvents and ReadConsoleInput to peek at and + read the console input events. + + One type of non-keyboard input event that gets reported as input + available is due to the Emacs's console window receiving focus. + When that happens, Emacs gets the FOCUS_EVENT event and sys_select + reports some input; however, w32_console_read_socket ignores such + events when called to read them. + + Note that any other Windows message sent to the main thread will + also wake up MsgWaitForMultipleObjects. These messages get + immediately dispatched to their destinations by calling + drain_message_queue. */ + int w32_console_read_socket (struct terminal *terminal, struct input_event *hold_quit)