From 1501b63f8dedbd15ee5bfd9a177e558ffdf0673a Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Sun, 27 Mar 2022 16:56:21 +0100 Subject: patch 8.2.4636: not using Visual range Problem: Not using Visual range. Solution: Put the command pointer back to the range. --- src/ex_docmd.c | 24 +++++++++++++++--------- 1 file changed, 15 insertions(+), 9 deletions(-) (limited to 'src/ex_docmd.c') diff --git a/src/ex_docmd.c b/src/ex_docmd.c index 9b3504f76e..ab2aa60b8e 100644 --- a/src/ex_docmd.c +++ b/src/ex_docmd.c @@ -3092,15 +3092,21 @@ parse_command_modifiers( break; } - if (has_visual_range && eap->cmd > cmd_start) - { - // Move the '<,'> range to after the modifiers and insert a colon. - // Since the modifiers have been parsed put the colon on top of the - // space: "'<,'>mod cmd" -> "mod:'<,'>cmd - // Put eap->cmd after the colon. - mch_memmove(cmd_start - 5, cmd_start, eap->cmd - cmd_start); - eap->cmd -= 5; - mch_memmove(eap->cmd - 1, ":'<,'>", 6); + if (has_visual_range) + { + if (eap->cmd > cmd_start) + { + // Move the '<,'> range to after the modifiers and insert a colon. + // Since the modifiers have been parsed put the colon on top of the + // space: "'<,'>mod cmd" -> "mod:'<,'>cmd + // Put eap->cmd after the colon. + mch_memmove(cmd_start - 5, cmd_start, eap->cmd - cmd_start); + eap->cmd -= 5; + mch_memmove(eap->cmd - 1, ":'<,'>", 6); + } + else + // no modifiers, move the pointer back + eap->cmd -= 5; } return OK; -- cgit v1.2.3