mirror of
https://github.com/vim/vim.git
synced 2025-09-23 03:43:49 -04:00
patch 7.4.2255
Problem: The script that checks translations can't handle plurals. Solution: Check for plural msgid and msgstr entries. Leave the cursor on the first error.
This commit is contained in:
@@ -30,36 +30,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"
|
||||
" go over the "msgid" and "msgid_plural" lines
|
||||
let prevfromline = 'foobar'
|
||||
while 1
|
||||
let fromline = GetMline()
|
||||
if getline('.') !~ '^msgstr'
|
||||
echo 'Missing "msgstr" in line ' . line('.')
|
||||
let error = 1
|
||||
if prevfromline != 'foobar' && prevfromline != fromline
|
||||
echomsg 'Mismatching % in line ' . (line('.') - 1)
|
||||
echomsg 'msgid: ' . prevfromline
|
||||
echomsg 'msgid ' . fromline
|
||||
if error == 0
|
||||
let error = line('.')
|
||||
endif
|
||||
let toline = GetMline()
|
||||
if fromline != toline
|
||||
echo 'Mismatching % in line ' . (line('.') - 1)
|
||||
echo 'msgid: ' . fromline
|
||||
echo 'msgstr: ' . toline
|
||||
let error = 1
|
||||
endif
|
||||
if getline('.') !~ 'msgid_plural'
|
||||
break
|
||||
endif
|
||||
let prevfromline = fromline
|
||||
endwhile
|
||||
|
||||
if getline('.') !~ '^msgstr'
|
||||
echomsg 'Missing "msgstr" in line ' . line('.')
|
||||
if error == 0
|
||||
let error = line('.')
|
||||
endif
|
||||
endif
|
||||
|
||||
" Find next msgid.
|
||||
" Wrap around at the end of the file, quit when back at the first one.
|
||||
/^msgid
|
||||
if line('.') == startline
|
||||
" 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. Quit when there is no more.
|
||||
let lnum = line('.')
|
||||
silent! /^msgid\>
|
||||
if line('.') == lnum
|
||||
break
|
||||
endif
|
||||
endwhile
|
||||
@@ -74,12 +104,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
|
||||
|
||||
let &wrapscan = s:save_wrapscan
|
||||
|
@@ -763,6 +763,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
2255,
|
||||
/**/
|
||||
2254,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user