diff options
author | Justin M. Keyes <justinkz@gmail.com> | 2017-03-22 12:32:52 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-03-22 12:32:52 +0100 |
commit | ef57ee23bdd7bcc95ea74fd6d50fdaaa036542eb (patch) | |
tree | 2a45e35252c9e3eb551e8088ffefa6d5f7a20317 | |
parent | 92d7cf4511071675513e64ed8e08fdf4dcbf58fb (diff) | |
parent | 26d7757ccbc57125a3dfe3b2cad0f07a2e567df1 (diff) | |
download | rneovim-ef57ee23bdd7bcc95ea74fd6d50fdaaa036542eb.tar.gz rneovim-ef57ee23bdd7bcc95ea74fd6d50fdaaa036542eb.tar.bz2 rneovim-ef57ee23bdd7bcc95ea74fd6d50fdaaa036542eb.zip |
Merge #6312 from lonerover/vim-7.4.2255
vim-patch: 7.4.2255,7.42256
-rw-r--r-- | src/nvim/eval.c | 5 | ||||
-rw-r--r-- | src/nvim/po/check.vim | 76 | ||||
-rw-r--r-- | src/nvim/version.c | 4 |
3 files changed, 61 insertions, 24 deletions
diff --git a/src/nvim/eval.c b/src/nvim/eval.c index e11b460edf..0872ed37ad 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -4860,7 +4860,10 @@ static int get_string_tv(char_u **arg, typval_T *rettv, int evaluate) } *name = NUL; - *arg = p + 1; + if (*p != NUL) { // just in case + p++; + } + *arg = p; return OK; } diff --git a/src/nvim/po/check.vim b/src/nvim/po/check.vim index 1622741da6..b323174550 100644 --- a/src/nvim/po/check.vim +++ b/src/nvim/po/check.vim @@ -33,36 +33,66 @@ func! GetMline() return substitute(idline, '[^%]*\(%[-+ #''.0-9*]*l\=[dsuxXpoc%]\)\=', '\1', 'g') endfunc -" This only works when 'wrapscan' is set. +" This only works when 'wrapscan' is not set. let s:save_wrapscan = &wrapscan -set wrapscan +set nowrapscan " Start at the first "msgid" line. 1 -/^msgid -let startline = line('.') +/^msgid\> + +" When an error is detected this is set to the line number. +" Note: this is used in the Makefile. let error = 0 while 1 if getline(line('.') - 1) !~ "no-c-format" - let fromline = GetMline() + " go over the "msgid" and "msgid_plural" lines + let prevfromline = 'foobar' + while 1 + let fromline = GetMline() + if prevfromline != 'foobar' && prevfromline != fromline + echomsg 'Mismatching % in line ' . (line('.') - 1) + echomsg 'msgid: ' . prevfromline + echomsg 'msgid ' . fromline + if error == 0 + let error = line('.') + endif + endif + if getline('.') !~ 'msgid_plural' + break + endif + let prevfromline = fromline + endwhile + if getline('.') !~ '^msgstr' - echo 'Missing "msgstr" in line ' . line('.') - let error = 1 - endif - let toline = GetMline() - if fromline != toline - echo 'Mismatching % in line ' . (line('.') - 1) - echo 'msgid: ' . fromline - echo 'msgstr: ' . toline - let error = 1 + echomsg 'Missing "msgstr" in line ' . line('.') + if error == 0 + let error = line('.') + endif endif + + " check all the 'msgstr' lines + while getline('.') =~ '^msgstr' + let toline = GetMline() + if fromline != toline + echomsg 'Mismatching % in line ' . (line('.') - 1) + echomsg 'msgid: ' . fromline + echomsg 'msgstr: ' . toline + if error == 0 + let error = line('.') + endif + endif + if line('.') == line('$') + break + endif + endwhile endif - " Find next msgid. - " Wrap around at the end of the file, quit when back at the first one. - /^msgid - if line('.') == startline + " Find next msgid. Quit when there is no more. + let lnum = line('.') + silent! /^msgid\> + if line('.') == lnum break endif endwhile @@ -77,12 +107,16 @@ endwhile " 1 if search('msgid "\("\n"\)\?\([EW][0-9]\+:\).*\nmsgstr "\("\n"\)\?[^"]\@=\2\@!') > 0 - echo 'Mismatching error/warning code in line ' . line('.') - let error = 1 + echomsg 'Mismatching error/warning code in line ' . line('.') + if error == 0 + let error = line('.') + endif endif if error == 0 - echo "OK" + echomsg "OK" +else + exe error endif redir END diff --git a/src/nvim/version.c b/src/nvim/version.c index ccd7fd21d9..398a3e6542 100644 --- a/src/nvim/version.c +++ b/src/nvim/version.c @@ -185,8 +185,8 @@ static int included_patches[] = { // 2259, // 2258 NA // 2257 NA - // 2256, - // 2255, + 2256, + 2255, // 2254 NA // 2253 NA // 2252 NA |