Skip to content

Commit

Permalink
vibe.web.i18n: Fix bug (Range violation) in wrapText which prevented …
Browse files Browse the repository at this point in the history
…extraction of strings with escape sequence, e.g. "\n".
  • Loading branch information
Andrey Zelenchuk committed Apr 13, 2015
1 parent 38608e4 commit 87cb432
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 1 deletion.
1 change: 1 addition & 0 deletions source/vibe/templ/parsertools.d
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,7 @@ string dstringUnescape(in string str)
if( start > 0 ) ret ~= str[start .. i];
else ret = str[0 .. i];
}
assert(i+1 < str.length, "The string ends with the escape char: " ~ str);
switch(str[i+1]){
default: ret ~= str[i+1]; break;
case 'r': ret ~= '\r'; break;
Expand Down
43 changes: 42 additions & 1 deletion source/vibe/web/i18n.d
Original file line number Diff line number Diff line change
Expand Up @@ -325,6 +325,46 @@ msgstr ""
assert(ds[0].value == "It should not matter where it takes place, the strings should all be concatenated properly.", "Failed to properly wrap the key");
}

// Verify that string wrapping and unescaping is handled correctly on example of PO headers
unittest {
auto str = `
# English translations for ThermoWebUI package.
# This file is put in the public domain.
# Automatically generated, 2015.
#
msgid ""
msgstr ""
"Project-Id-Version: PROJECT VERSION\n"
"Report-Msgid-Bugs-To: [email protected]\n"
"POT-Creation-Date: 2015-04-13 17:55+0600\n"
"PO-Revision-Date: 2015-04-13 14:13+0600\n"
"Last-Translator: Automatically generated\n"
"Language-Team: none\n"
"Language: en\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"
`;
auto expected = `Project-Id-Version: PROJECT VERSION
Report-Msgid-Bugs-To: [email protected]
POT-Creation-Date: 2015-04-13 17:55+0600
PO-Revision-Date: 2015-04-13 14:13+0600
Last-Translator: Automatically generated
Language-Team: none
Language: en
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
Plural-Forms: nplurals=2; plural=(n != 1);
`;

auto ds = extractDeclStrings(str);
assert(1 == ds.length, "Expected one DeclString to have been processed.");
assert(ds[0].key == "", "Failed to properly wrap or unescape the key");
assert(ds[0].value == expected, "Failed to properly wrap or unescape the value");
}

// Verify that the message context is properly parsed
unittest {
auto str1 = `
Expand Down Expand Up @@ -434,7 +474,8 @@ private string wrapText(string str)

for (size_t i=0; i<str.length; ++i) {
if (str[i] == '\\') {
ret ~= str[i..i+1];
assert(i+1 < str.length, "The string ends with the escape char: " ~ str);
ret ~= str[i..i+2];
++i;
} else if (str[i] == '"') {
wrapped = true;
Expand Down

0 comments on commit 87cb432

Please sign in to comment.