Merge pull request #24 from appropos/msgstr-0
Write proper plural msgstr[0]
This commit is contained in:
		| @@ -5,7 +5,7 @@ module.exports = (grunt) -> | ||||
|     @loadNpmTasks('grunt-contrib-jshint') | ||||
|     @loadNpmTasks('grunt-contrib-uglify') | ||||
|     @loadNpmTasks('grunt-contrib-watch') | ||||
|     @loadNpmTasks('grunt-jscs-checker') | ||||
|     @loadNpmTasks('grunt-jscs') | ||||
|     @loadNpmTasks('grunt-mocha-cli') | ||||
|  | ||||
|     @initConfig | ||||
| @@ -42,8 +42,6 @@ module.exports = (grunt) -> | ||||
|             dist: | ||||
|                 files: | ||||
|                     'dist/pofile.js': ['lib/po.js'] | ||||
|                 options: | ||||
|                     alias: 'lib/po.js:pofile' | ||||
|  | ||||
|         uglify: | ||||
|             dist: | ||||
|   | ||||
							
								
								
									
										10
									
								
								lib/po.js
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								lib/po.js
									
									
									
									
									
								
							| @@ -1,5 +1,4 @@ | ||||
| var fs = require('fs'); | ||||
| var isArray = require('lodash.isarray'); | ||||
|  | ||||
| function trim(string) { | ||||
|     return string.replace(/^\s+|\s+$/g, ''); | ||||
| @@ -317,13 +316,16 @@ PO.Item.prototype.toString = function () { | ||||
|     ['msgctxt', 'msgid', 'msgid_plural', 'msgstr'].forEach(function (keyword) { | ||||
|         var text = self[keyword]; | ||||
|         if (text != null) { | ||||
|             if (isArray(text) && text.length > 1) { | ||||
|             if (Array.isArray(text) && text.length > 1) { | ||||
|                 text.forEach(function (t, i) { | ||||
|                     lines = lines.concat(mkObsolete + _process(keyword, t, i)); | ||||
|                 }); | ||||
|             } else { | ||||
|                 text = isArray(text) ? text.join() : text; | ||||
|                 var processed = _process(keyword, text); | ||||
|                 var index = (self.msgid_plural && Array.isArray(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) | ||||
|                 for (var i = 1; i < processed.length - 1; i++) { | ||||
|                     processed[i] = processed[i].slice(0, -1) + '\\n"'; | ||||
|   | ||||
							
								
								
									
										24
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								package.json
									
									
									
									
									
								
							| @@ -35,18 +35,16 @@ | ||||
|     "test": "test" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "browserify": "~3.11.1", | ||||
|     "grunt": "~0.4.2", | ||||
|     "grunt-browserify": "~1.3.0", | ||||
|     "grunt-bump": "0.0.13", | ||||
|     "grunt-contrib-clean": "~0.5.0", | ||||
|     "grunt-contrib-jshint": "~0.7.2", | ||||
|     "grunt-contrib-uglify": "~0.2.7", | ||||
|     "grunt-contrib-watch": "~0.5.3", | ||||
|     "grunt-jscs-checker": "^0.5.1", | ||||
|     "grunt-mocha-cli": "~1.4.0" | ||||
|     "browserify": "~14.0.0", | ||||
|     "grunt": "~1.0.1", | ||||
|     "grunt-browserify": "~5.0.0", | ||||
|     "grunt-bump": "0.8.0", | ||||
|     "grunt-contrib-clean": "~1.0.0", | ||||
|     "grunt-contrib-jshint": "~1.1.0", | ||||
|     "grunt-contrib-uglify": "~2.1.0", | ||||
|     "grunt-contrib-watch": "~1.0.0", | ||||
|     "grunt-jscs": "~3.0.1", | ||||
|     "grunt-mocha-cli": "~3.0.0" | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "lodash.isarray": "~2.4.1" | ||||
|   } | ||||
|   "dependencies": {} | ||||
| } | ||||
|   | ||||
							
								
								
									
										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); | ||||
| } | ||||
|  | ||||
| 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) { | ||||
|     var lines = str.split('\n'); | ||||
|     var found = false; | ||||
| @@ -103,6 +118,38 @@ describe('Write', function () { | ||||
|         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 () { | ||||
|         it('should escape "', function () { | ||||
|             var item = new PO.Item(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user