From f5e8527a8c62dd59e3883b25d9c3009fb7caf4ab Mon Sep 17 00:00:00 2001
From: Peter Stephenson
Date: Fri, 11 Sep 2015 18:40:22 +0100
Subject: 36483: handle incomplete multibyte characters in bracketed-paste-magi
---
Functions/Zle/bracketed-paste-magic | 16 ++++++++++++----
1 file changed, 12 insertions(+), 4 deletions(-)
(limited to 'Functions/Zle/bracketed-paste-magic')
diff --git a/Functions/Zle/bracketed-paste-magic b/Functions/Zle/bracketed-paste-magic
index 49f4b6620..464c6b339 100644
--- a/Functions/Zle/bracketed-paste-magic
+++ b/Functions/Zle/bracketed-paste-magic
@@ -164,17 +164,25 @@ bracketed-paste-magic() {
integer bpm_limit=$UNDO_LIMIT_NO bpm_undo=$UNDO_CHANGE_NO
UNDO_LIMIT_NO=$UNDO_CHANGE_NO
+ local mbchar
+ integer ismb
while [[ -n $PASTED ]] && zle .read-command; do
- PASTED=${PASTED#$KEYS}
- if [[ $KEYS = ${(~j:|:)${(b)bpm_inactive}} ]]; then
- zle .self-insert-unmeta
+ mbchar=$KEYS
+ ismb=0
+ while [[ $mbchar = [[:INCOMPLETE:]]* ]] && zle .read-command; do
+ mbchar+=$KEYS
+ ismb=1
+ done
+ PASTED=${PASTED#$mbchar}
+ if [[ ismb -ne 0 || $mbchar = ${(~j:|:)${(b)bpm_inactive}} ]]; then
+ LBUFFER+=$mbchar
else
case $REPLY in
(${~bpm_active}) function () {
emulate -L $bpm_emulate; set -$bpm_opts
zle $REPLY
};;
- (*) zle .self-insert-unmeta;;
+ (*) LBUFFER+=$mbchar;
esac
fi
done
--
cgit 1.4.1