aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/search.c
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2022-12-04 09:43:38 +0800
committerzeertzjq <zeertzjq@outlook.com>2022-12-04 10:07:05 +0800
commit3f1ee12d311fffe30936217c74ef0352bb7d97d9 (patch)
treee66f23c4b43ef43396001541cbbf7f75bbf86b40 /src/nvim/search.c
parent46e4be0fd0002233bde613295607ce5eeb498567 (diff)
downloadrneovim-3f1ee12d311fffe30936217c74ef0352bb7d97d9.tar.gz
rneovim-3f1ee12d311fffe30936217c74ef0352bb7d97d9.tar.bz2
rneovim-3f1ee12d311fffe30936217c74ef0352bb7d97d9.zip
vim-patch:8.2.3265: smartcase does not work correctly in very magic pattern
Problem: Smartcase does not work correctly in very magic pattern. Solution: Take the magicness into account when skipping over regexp items. (Christian Brabandt, closes vim/vim#8682, closes vim/vim#7845) https://github.com/vim/vim/commit/78ba933d18439ff1a02f6be4c571e73ddceb3cd4 Co-authored-by: Christian Brabandt <cb@256bit.org>
Diffstat (limited to 'src/nvim/search.c')
-rw-r--r--src/nvim/search.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/nvim/search.c b/src/nvim/search.c
index 842927e60c..9814822f76 100644
--- a/src/nvim/search.c
+++ b/src/nvim/search.c
@@ -373,6 +373,10 @@ bool pat_has_uppercase(char_u *pat)
FUNC_ATTR_NONNULL_ALL
{
char_u *p = pat;
+ magic_T magic_val = MAGIC_ON;
+
+ // get the magicness of the pattern
+ (void)skip_regexp_ex((char *)pat, NUL, magic_isset(), NULL, NULL, &magic_val);
while (*p != NUL) {
const int l = utfc_ptr2len((char *)p);
@@ -382,7 +386,7 @@ bool pat_has_uppercase(char_u *pat)
return true;
}
p += l;
- } else if (*p == '\\') {
+ } else if (*p == '\\' && magic_val == MAGIC_ON) {
if (p[1] == '_' && p[2] != NUL) { // skip "\_X"
p += 3;
} else if (p[1] == '%' && p[2] != NUL) { // skip "\%X"
@@ -392,6 +396,10 @@ bool pat_has_uppercase(char_u *pat)
} else {
p += 1;
}
+ } else if ((*p == '%' || *p == '_') && magic_val == MAGIC_ALL) {
+ if (p[1] != NUL) { // skip "_X" and %X
+ p += 2;
+ }
} else if (mb_isupper(*p)) {
return true;
} else {