Merge pull request #4191 from nigredo-tori/fix_tojsstr

Fix toJSStr for control characters
This commit is contained in:
Andreas Rumpf
2016-05-20 20:37:00 +02:00
2 changed files with 13 additions and 1 deletions

View File

@@ -248,8 +248,12 @@ proc toJSStr(s: string): cstring {.asmNoStackFrame, compilerproc.} =
for (var i = 0; i < len; ++i) {
if (nonAsciiPart !== null) {
var offset = (i - nonAsciiOffset) * 2;
var code = `s`[i].toString(16);
if (code.length == 1) {
code = "0"+code;
}
nonAsciiPart[offset] = "%";
nonAsciiPart[offset + 1] = `s`[i].toString(16);
nonAsciiPart[offset + 1] = code;
}
else if (`s`[i] < 128)
asciiPart[i] = fcc(`s`[i]);

8
tests/js/testtojsstr.nim Normal file
View File

@@ -0,0 +1,8 @@
discard """
output = "И\n"
"""
let s: string = "И\n"
let cs = s.cstring
echo $s