aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/qreg-commands.c
diff options
context:
space:
mode:
authorRobin Haberkorn <robin.haberkorn@googlemail.com>2025-06-27 16:13:15 +0200
committerRobin Haberkorn <robin.haberkorn@googlemail.com>2025-06-27 16:13:15 +0200
commit39249ed57170f09e7dd2fc76c62b51d90a2a4d76 (patch)
treec8cc8e89c2fd31a0215d4f4dbaf9c1aa6b1191de /src/qreg-commands.c
parent06b4da0de1388eb8403d3ad88915c117ab84877f (diff)
downloadsciteco-39249ed57170f09e7dd2fc76c62b51d90a2a4d76.tar.gz
fixed ^S/^Y for <Gq> and <EN>
* We must call teco_interface_bytes2glyphs() only ever with byte offsets that already exist in the buffer. * regression, introduced in aaa1d51a4c85fcc627e88ef7cf5292d9c5f5f840
Diffstat (limited to 'src/qreg-commands.c')
-rw-r--r--src/qreg-commands.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/qreg-commands.c b/src/qreg-commands.c
index 0457e92..7189771 100644
--- a/src/qreg-commands.c
+++ b/src/qreg-commands.c
@@ -535,9 +535,6 @@ teco_state_getqregstring_got_register(teco_machine_main_t *ctx, teco_qreg_t *qre
return NULL;
sptr_t pos = teco_interface_ssm(SCI_GETCURRENTPOS, 0, 0);
- teco_undo_int(teco_ranges[0].from) = teco_interface_bytes2glyphs(pos);
- teco_undo_int(teco_ranges[0].to) = teco_interface_bytes2glyphs(pos + str.len);
- teco_undo_guint(teco_ranges_count) = 1;
if (str.len > 0) {
teco_interface_ssm(SCI_BEGINUNDOACTION, 0, 0);
@@ -549,6 +546,10 @@ teco_state_getqregstring_got_register(teco_machine_main_t *ctx, teco_qreg_t *qre
undo__teco_interface_ssm(SCI_UNDO, 0, 0);
}
+ teco_undo_int(teco_ranges[0].from) = teco_interface_bytes2glyphs(pos);
+ teco_undo_int(teco_ranges[0].to) = teco_interface_bytes2glyphs(pos + str.len);
+ teco_undo_guint(teco_ranges_count) = 1;
+
return &teco_state_start;
}