Merge #5804 from brcolow/vim-7.4.1793

vim-patch:7.4.17[83,85,93]
This commit is contained in:
Justin M. Keyes 2016-12-31 23:43:49 +01:00 committed by GitHub
commit 61d4ca214f
4 changed files with 118 additions and 37 deletions

View File

@ -2309,48 +2309,64 @@ collection:
} }
break; break;
case CLASS_ALNUM: case CLASS_ALNUM:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu < 128; cu++) {
if (isalnum(cu)) if (isalnum(cu)) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_ALPHA: case CLASS_ALPHA:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu < 128; cu++) {
if (isalpha(cu)) if (isalpha(cu)) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_BLANK: case CLASS_BLANK:
regc(' '); regc(' ');
regc('\t'); regc('\t');
break; break;
case CLASS_CNTRL: case CLASS_CNTRL:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu <= 255; cu++) {
if (iscntrl(cu)) if (iscntrl(cu)) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_DIGIT: case CLASS_DIGIT:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu <= 255; cu++) {
if (ascii_isdigit(cu)) if (ascii_isdigit(cu)) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_GRAPH: case CLASS_GRAPH:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu <= 255; cu++) {
if (isgraph(cu)) if (isgraph(cu)) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_LOWER: case CLASS_LOWER:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu <= 255; cu++) {
if (vim_islower(cu)) if (vim_islower(cu) && cu != 170 && cu != 186) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_PRINT: case CLASS_PRINT:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu <= 255; cu++) {
if (vim_isprintc(cu)) if (vim_isprintc(cu)) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_PUNCT: case CLASS_PUNCT:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu < 128; cu++) {
if (ispunct(cu)) if (ispunct(cu)) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_SPACE: case CLASS_SPACE:
for (cu = 9; cu <= 13; cu++) for (cu = 9; cu <= 13; cu++)
@ -2358,14 +2374,18 @@ collection:
regc(' '); regc(' ');
break; break;
case CLASS_UPPER: case CLASS_UPPER:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu <= 255; cu++) {
if (vim_isupper(cu)) if (vim_isupper(cu)) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_XDIGIT: case CLASS_XDIGIT:
for (cu = 1; cu <= 255; cu++) for (cu = 1; cu <= 255; cu++) {
if (ascii_isxdigit(cu)) if (ascii_isxdigit(cu)) {
regc(cu); regmbc(cu);
}
}
break; break;
case CLASS_TAB: case CLASS_TAB:
regc('\t'); regc('\t');

View File

@ -4320,12 +4320,14 @@ static int check_char_class(int class, int c)
{ {
switch (class) { switch (class) {
case NFA_CLASS_ALNUM: case NFA_CLASS_ALNUM:
if (c >= 1 && c <= 255 && isalnum(c)) if (c >= 1 && c < 128 && isalnum(c)) {
return OK; return OK;
}
break; break;
case NFA_CLASS_ALPHA: case NFA_CLASS_ALPHA:
if (c >= 1 && c <= 255 && isalpha(c)) if (c >= 1 && c < 128 && isalpha(c)) {
return OK; return OK;
}
break; break;
case NFA_CLASS_BLANK: case NFA_CLASS_BLANK:
if (c == ' ' || c == '\t') if (c == ' ' || c == '\t')
@ -4344,16 +4346,18 @@ static int check_char_class(int class, int c)
return OK; return OK;
break; break;
case NFA_CLASS_LOWER: case NFA_CLASS_LOWER:
if (vim_islower(c)) if (vim_islower(c) && c != 170 && c != 186) {
return OK; return OK;
}
break; break;
case NFA_CLASS_PRINT: case NFA_CLASS_PRINT:
if (vim_isprintc(c)) if (vim_isprintc(c))
return OK; return OK;
break; break;
case NFA_CLASS_PUNCT: case NFA_CLASS_PUNCT:
if (c >= 1 && c <= 255 && ispunct(c)) if (c >= 1 && c < 128 && ispunct(c)) {
return OK; return OK;
}
break; break;
case NFA_CLASS_SPACE: case NFA_CLASS_SPACE:
if ((c >= 9 && c <= 13) || (c == ' ')) if ((c >= 9 && c <= 13) || (c == ' '))

View File

@ -35,3 +35,60 @@ func Test_strcharpart_utf8()
call assert_equal('̀', strcharpart('àxb', 1, 1)) call assert_equal('̀', strcharpart('àxb', 1, 1))
call assert_equal('x', strcharpart('àxb', 2, 1)) call assert_equal('x', strcharpart('àxb', 2, 1))
endfunc endfunc
func s:classes_test()
set isprint=@,161-255
call assert_equal('Motörhead', matchstr('Motörhead', '[[:print:]]\+'))
let alphachars = ''
let lowerchars = ''
let upperchars = ''
let alnumchars = ''
let printchars = ''
let punctchars = ''
let xdigitchars = ''
let i = 1
while i <= 255
let c = nr2char(i)
if c =~ '[[:alpha:]]'
let alphachars .= c
endif
if c =~ '[[:lower:]]'
let lowerchars .= c
endif
if c =~ '[[:upper:]]'
let upperchars .= c
endif
if c =~ '[[:alnum:]]'
let alnumchars .= c
endif
if c =~ '[[:print:]]'
let printchars .= c
endif
if c =~ '[[:punct:]]'
let punctchars .= c
endif
if c =~ '[[:xdigit:]]'
let xdigitchars .= c
endif
let i += 1
endwhile
call assert_equal('ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz', alphachars)
call assert_equal('abcdefghijklmnopqrstuvwxyzµßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ', lowerchars)
call assert_equal('ABCDEFGHIJKLMNOPQRSTUVWXYZÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞ', upperchars)
call assert_equal('0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz', alnumchars)
call assert_equal(' !"#$%&''()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿ', printchars)
call assert_equal('!"#$%&''()*+,-./:;<=>?@[\]^_`{|}~', punctchars)
call assert_equal('0123456789ABCDEFabcdef', xdigitchars)
endfunc
func Test_classes_re1()
set re=1
call s:classes_test()
endfunc
func Test_classes_re2()
set re=2
call s:classes_test()
endfunc

View File

@ -646,7 +646,7 @@ static int included_patches[] = {
// 1796 NA // 1796 NA
// 1795 NA // 1795 NA
// 1794 NA // 1794 NA
// 1793, 1793,
// 1792 NA // 1792 NA
// 1791 NA // 1791 NA
// 1790 NA // 1790 NA
@ -655,9 +655,9 @@ static int included_patches[] = {
// 1788 NA // 1788 NA
// 1787 NA // 1787 NA
// 1786 NA // 1786 NA
// 1785, 1785,
// 1784 NA // 1784 NA
// 1783, 1783,
1782, 1782,
// 1781, // 1781,
1780, 1780,