summaryrefslogtreecommitdiff
path: root/Src/Zle/zle_misc.c
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2006-01-06 14:23:00 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2006-01-06 14:23:00 +0000
commit94953f70b94e639b8b5563295a780a76c37330ab (patch)
treecdfbf78990e7c05782a2cba7ca33ae1a1804173b /Src/Zle/zle_misc.c
parentd8a851a9a8b29ebf22b2746299697220e200eaa4 (diff)
downloadzsh-94953f70b94e639b8b5563295a780a76c37330ab.tar.gz
zsh-94953f70b94e639b8b5563295a780a76c37330ab.zip
22124: handle bad multibyte input better
Diffstat (limited to 'Src/Zle/zle_misc.c')
-rw-r--r--Src/Zle/zle_misc.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/Src/Zle/zle_misc.c b/Src/Zle/zle_misc.c
index 1cb113a2d..aa8d1058d 100644
--- a/Src/Zle/zle_misc.c
+++ b/Src/Zle/zle_misc.c
@@ -64,7 +64,8 @@ selfinsert(UNUSED(char **args))
#ifdef MULTIBYTE_SUPPORT
if (!lastchar_wide_valid)
- getrestchar(lastchar);
+ if (getrestchar(lastchar) == WEOF)
+ return 1;
#endif
tmp = LASTFULLCHAR;
doinsert(&tmp, 1);
@@ -1018,6 +1019,9 @@ executenamedcommand(char *prmt)
#ifdef MULTIBYTE_SUPPORT
if (!lastchar_wide_valid)
getrestchar(lastchar);
+ if (lastchar_wide == WEOF)
+ feep = 1;
+ else
#endif
if (ZC_icntrl(LASTFULLCHAR))
feep = 1;