diff options
| author | Jason Rumney | 2008-01-30 09:34:49 +0000 |
|---|---|---|
| committer | Jason Rumney | 2008-01-30 09:34:49 +0000 |
| commit | 480cb5d27b1fc5805e99df99d474d24e904c536b (patch) | |
| tree | 454ca873d10152e4281ac8a5dfeb964927af2662 | |
| parent | 9fab8546840e884c123fdd57a4016a79ec8f7a3d (diff) | |
| download | emacs-480cb5d27b1fc5805e99df99d474d24e904c536b.tar.gz emacs-480cb5d27b1fc5805e99df99d474d24e904c536b.zip | |
(w32_read_socket) <WM_CHAR>: Decode non-Unicode
input in the default locale. Handle non-Unicode multibyte input.
| -rw-r--r-- | src/w32term.c | 57 |
1 files changed, 51 insertions, 6 deletions
diff --git a/src/w32term.c b/src/w32term.c index e04e57cd52a..4766382f6a1 100644 --- a/src/w32term.c +++ b/src/w32term.c | |||
| @@ -4787,19 +4787,64 @@ w32_read_socket (sd, expected, hold_quit) | |||
| 4787 | if (temp_index == sizeof temp_buffer / sizeof (short)) | 4787 | if (temp_index == sizeof temp_buffer / sizeof (short)) |
| 4788 | temp_index = 0; | 4788 | temp_index = 0; |
| 4789 | temp_buffer[temp_index++] = msg.msg.wParam; | 4789 | temp_buffer[temp_index++] = msg.msg.wParam; |
| 4790 | |||
| 4791 | inev.modifiers = msg.dwModifiers; | ||
| 4792 | XSETFRAME (inev.frame_or_window, f); | ||
| 4793 | inev.timestamp = msg.msg.time; | ||
| 4794 | |||
| 4790 | if (msg.msg.message == WM_UNICHAR) | 4795 | if (msg.msg.message == WM_UNICHAR) |
| 4791 | { | 4796 | { |
| 4792 | inev.kind = MULTIBYTE_CHAR_KEYSTROKE_EVENT; | ||
| 4793 | inev.code = msg.msg.wParam; | 4797 | inev.code = msg.msg.wParam; |
| 4794 | } | 4798 | } |
| 4799 | else if (msg.msg.wParam < 256) | ||
| 4800 | { | ||
| 4801 | wchar_t code; | ||
| 4802 | char dbcs[2]; | ||
| 4803 | dbcs[0] = 0; | ||
| 4804 | dbcs[1] = (char) msg.msg.wParam; | ||
| 4805 | |||
| 4806 | if (dbcs_lead) | ||
| 4807 | { | ||
| 4808 | dbcs[0] = dbcs_lead; | ||
| 4809 | dbcs_lead = 0; | ||
| 4810 | if (!MultiByteToWideChar (CP_ACP, 0, dbcs, 2, &code, 1)) | ||
| 4811 | { | ||
| 4812 | /* Garbage */ | ||
| 4813 | DebPrint (("Invalid DBCS sequence: %d %d\n", | ||
| 4814 | dbcs[0], dbcs[1])); | ||
| 4815 | inev.kind = NO_EVENT; | ||
| 4816 | break; | ||
| 4817 | } | ||
| 4818 | } | ||
| 4819 | else if (IsDBCSLeadByteEx (CP_ACP, (BYTE) msg.msg.wParam)) | ||
| 4820 | { | ||
| 4821 | dbcs_lead = (char) msg.msg.wParam; | ||
| 4822 | inev.kind = NO_EVENT; | ||
| 4823 | break; | ||
| 4824 | } | ||
| 4825 | else | ||
| 4826 | { | ||
| 4827 | if (!MultiByteToWideChar (CP_ACP, 0, &dbcs[1], 1, | ||
| 4828 | &code, 1)) | ||
| 4829 | { | ||
| 4830 | /* What to do with garbage? */ | ||
| 4831 | DebPrint (("Invalid character: %d\n", dbcs[1])); | ||
| 4832 | inev.kind = NO_EVENT; | ||
| 4833 | break; | ||
| 4834 | } | ||
| 4835 | } | ||
| 4836 | inev.code = code; | ||
| 4837 | } | ||
| 4795 | else | 4838 | else |
| 4796 | { | 4839 | { |
| 4797 | inev.kind = ASCII_KEYSTROKE_EVENT; | 4840 | /* Windows shouldn't generate WM_CHAR events above 0xFF |
| 4798 | inev.code = msg.msg.wParam; | 4841 | in non-Unicode message handlers. */ |
| 4842 | DebPrint (("Non-byte WM_CHAR: %d\n", msg.msg.wParam)); | ||
| 4843 | inev.kind = NO_EVENT; | ||
| 4844 | break; | ||
| 4799 | } | 4845 | } |
| 4800 | inev.modifiers = msg.dwModifiers; | 4846 | inev.kind = inev.code < 128 ? ASCII_KEYSTROKE_EVENT |
| 4801 | XSETFRAME (inev.frame_or_window, f); | 4847 | : MULTIBYTE_CHAR_KEYSTROKE_EVENT; |
| 4802 | inev.timestamp = msg.msg.time; | ||
| 4803 | } | 4848 | } |
| 4804 | break; | 4849 | break; |
| 4805 | 4850 | ||