Merge pull request #24 from appropos/msgstr-0
Write proper plural msgstr[0]
This commit is contained in:
commit
52c11f77e9
@ -5,7 +5,7 @@ module.exports = (grunt) ->
|
|||||||
@loadNpmTasks('grunt-contrib-jshint')
|
@loadNpmTasks('grunt-contrib-jshint')
|
||||||
@loadNpmTasks('grunt-contrib-uglify')
|
@loadNpmTasks('grunt-contrib-uglify')
|
||||||
@loadNpmTasks('grunt-contrib-watch')
|
@loadNpmTasks('grunt-contrib-watch')
|
||||||
@loadNpmTasks('grunt-jscs-checker')
|
@loadNpmTasks('grunt-jscs')
|
||||||
@loadNpmTasks('grunt-mocha-cli')
|
@loadNpmTasks('grunt-mocha-cli')
|
||||||
|
|
||||||
@initConfig
|
@initConfig
|
||||||
@ -42,8 +42,6 @@ module.exports = (grunt) ->
|
|||||||
dist:
|
dist:
|
||||||
files:
|
files:
|
||||||
'dist/pofile.js': ['lib/po.js']
|
'dist/pofile.js': ['lib/po.js']
|
||||||
options:
|
|
||||||
alias: 'lib/po.js:pofile'
|
|
||||||
|
|
||||||
uglify:
|
uglify:
|
||||||
dist:
|
dist:
|
||||||
|
10
lib/po.js
10
lib/po.js
@ -1,5 +1,4 @@
|
|||||||
var fs = require('fs');
|
var fs = require('fs');
|
||||||
var isArray = require('lodash.isarray');
|
|
||||||
|
|
||||||
function trim(string) {
|
function trim(string) {
|
||||||
return string.replace(/^\s+|\s+$/g, '');
|
return string.replace(/^\s+|\s+$/g, '');
|
||||||
@ -317,13 +316,16 @@ PO.Item.prototype.toString = function () {
|
|||||||
['msgctxt', 'msgid', 'msgid_plural', 'msgstr'].forEach(function (keyword) {
|
['msgctxt', 'msgid', 'msgid_plural', 'msgstr'].forEach(function (keyword) {
|
||||||
var text = self[keyword];
|
var text = self[keyword];
|
||||||
if (text != null) {
|
if (text != null) {
|
||||||
if (isArray(text) && text.length > 1) {
|
if (Array.isArray(text) && text.length > 1) {
|
||||||
text.forEach(function (t, i) {
|
text.forEach(function (t, i) {
|
||||||
lines = lines.concat(mkObsolete + _process(keyword, t, i));
|
lines = lines.concat(mkObsolete + _process(keyword, t, i));
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
text = isArray(text) ? text.join() : text;
|
var index = (self.msgid_plural && Array.isArray(text)) ?
|
||||||
var processed = _process(keyword, text);
|
0 :
|
||||||
|
undefined;
|
||||||
|
text = Array.isArray(text) ? text.join() : text;
|
||||||
|
var processed = _process(keyword, text, index);
|
||||||
//handle \n in single-line texts (can not be handled in _escape)
|
//handle \n in single-line texts (can not be handled in _escape)
|
||||||
for (var i = 1; i < processed.length - 1; i++) {
|
for (var i = 1; i < processed.length - 1; i++) {
|
||||||
processed[i] = processed[i].slice(0, -1) + '\\n"';
|
processed[i] = processed[i].slice(0, -1) + '\\n"';
|
||||||
|
24
package.json
24
package.json
@ -35,18 +35,16 @@
|
|||||||
"test": "test"
|
"test": "test"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"browserify": "~3.11.1",
|
"browserify": "~14.0.0",
|
||||||
"grunt": "~0.4.2",
|
"grunt": "~1.0.1",
|
||||||
"grunt-browserify": "~1.3.0",
|
"grunt-browserify": "~5.0.0",
|
||||||
"grunt-bump": "0.0.13",
|
"grunt-bump": "0.8.0",
|
||||||
"grunt-contrib-clean": "~0.5.0",
|
"grunt-contrib-clean": "~1.0.0",
|
||||||
"grunt-contrib-jshint": "~0.7.2",
|
"grunt-contrib-jshint": "~1.1.0",
|
||||||
"grunt-contrib-uglify": "~0.2.7",
|
"grunt-contrib-uglify": "~2.1.0",
|
||||||
"grunt-contrib-watch": "~0.5.3",
|
"grunt-contrib-watch": "~1.0.0",
|
||||||
"grunt-jscs-checker": "^0.5.1",
|
"grunt-jscs": "~3.0.1",
|
||||||
"grunt-mocha-cli": "~1.4.0"
|
"grunt-mocha-cli": "~3.0.0"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {}
|
||||||
"lodash.isarray": "~2.4.1"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
32
test/fixtures/plural.po
vendored
Normal file
32
test/fixtures/plural.po
vendored
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
# French translation of Link (6.x-2.9)
|
||||||
|
# Copyright (c) 2011 by the French translation team
|
||||||
|
#
|
||||||
|
msgid ""
|
||||||
|
msgstr ""
|
||||||
|
"Project-Id-Version: Link (6.x-2.9)\n"
|
||||||
|
"POT-Creation-Date: 2011-12-31 23:39+0000\n"
|
||||||
|
"PO-Revision-Date: 2013-12-17 14:59+0100\n"
|
||||||
|
"Language-Team: French\n"
|
||||||
|
"MIME-Version: 1.0\n"
|
||||||
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
|
"Content-Transfer-Encoding: 8bit\n"
|
||||||
|
"Plural-Forms: nplurals=2; plural=(n > 1);\n"
|
||||||
|
"Last-Translator: Ruben Vermeersch <ruben@rocketeer.be>\n"
|
||||||
|
"Language: fr\n"
|
||||||
|
"X-Generator: Poedit 1.6.2\n"
|
||||||
|
|
||||||
|
# correct plurals, with translation
|
||||||
|
msgid "1 source"
|
||||||
|
msgid_plural "{{$count}} sources"
|
||||||
|
msgstr[0] "1 source"
|
||||||
|
msgstr[1] "{{$count}} sources"
|
||||||
|
|
||||||
|
# correct plurals, with no translation
|
||||||
|
msgid "1 destination"
|
||||||
|
msgid_plural "{{$count}} destinations"
|
||||||
|
msgstr[0] ""
|
||||||
|
|
||||||
|
# incorrect plurals, with no translation
|
||||||
|
msgid "1 mistake"
|
||||||
|
msgid_plural "{{$count}} mistakes"
|
||||||
|
msgstr ""
|
@ -16,6 +16,21 @@ function assertHasLine(str, line) {
|
|||||||
assert(found, 'Could not find line: ' + line);
|
assert(found, 'Could not find line: ' + line);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function assertHasContiguousLines(str, assertedLines) {
|
||||||
|
var assertedLinesJoined = assertedLines.join('\n');
|
||||||
|
|
||||||
|
var trimmedStr = str
|
||||||
|
.split('\n')
|
||||||
|
.map(function (line) {
|
||||||
|
return line.trim();
|
||||||
|
})
|
||||||
|
.join('\n');
|
||||||
|
|
||||||
|
var found = trimmedStr.indexOf(assertedLinesJoined) !== -1;
|
||||||
|
|
||||||
|
assert(found, 'Could not find lines: \n' + assertedLinesJoined);
|
||||||
|
}
|
||||||
|
|
||||||
function assertDoesntHaveLine(str, line) {
|
function assertDoesntHaveLine(str, line) {
|
||||||
var lines = str.split('\n');
|
var lines = str.split('\n');
|
||||||
var found = false;
|
var found = false;
|
||||||
@ -103,6 +118,38 @@ describe('Write', function () {
|
|||||||
assertHasLine(str, '#~ msgstr "also not sure"');
|
assertHasLine(str, '#~ msgstr "also not sure"');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('plurals', function () {
|
||||||
|
it('should write multiple msgstrs', function () {
|
||||||
|
var input = fs.readFileSync(__dirname + '/fixtures/plural.po', 'utf8');
|
||||||
|
var po = PO.parse(input);
|
||||||
|
var str = po.toString();
|
||||||
|
assertHasContiguousLines(str, [
|
||||||
|
'msgstr[0] "1 source"',
|
||||||
|
'msgstr[1] "{{$count}} sources"'
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should write msgstr[0] when there is no translation', function () {
|
||||||
|
var input = fs.readFileSync(__dirname + '/fixtures/plural.po', 'utf8');
|
||||||
|
var po = PO.parse(input);
|
||||||
|
var str = po.toString();
|
||||||
|
assertHasContiguousLines(str, [
|
||||||
|
'msgid_plural "{{$count}} destinations"',
|
||||||
|
'msgstr[0] ""'
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should write msgstr[0] when there is no translation and empty plural translation is stored in msgstr ""', function () {
|
||||||
|
var input = fs.readFileSync(__dirname + '/fixtures/plural.po', 'utf8');
|
||||||
|
var po = PO.parse(input);
|
||||||
|
var str = po.toString();
|
||||||
|
assertHasContiguousLines(str, [
|
||||||
|
'msgid_plural "{{$count}} mistakes"',
|
||||||
|
'msgstr[0] ""'
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('C-Strings', function () {
|
describe('C-Strings', function () {
|
||||||
it('should escape "', function () {
|
it('should escape "', function () {
|
||||||
var item = new PO.Item();
|
var item = new PO.Item();
|
||||||
|
Loading…
Reference in New Issue
Block a user