From bd850a25f51dfb662a761473c151c016c815bcb5 Mon Sep 17 00:00:00 2001 From: Wojciech Mandrysz Date: Tue, 15 Nov 2016 14:08:49 +0100 Subject: [PATCH] JS: Well, this is the right place for surrogates. --- js/binary/encoder.js | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/js/binary/encoder.js b/js/binary/encoder.js index a9d09d72c0190..d952d714d7965 100644 --- a/js/binary/encoder.js +++ b/js/binary/encoder.js @@ -426,17 +426,19 @@ jspb.BinaryEncoder.prototype.writeString = function(value) { if (second >= 0xDC00 && second <= 0xDFFF) { // low surrogate // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae c = (c - 0xD800) * 0x400 + second - 0xDC00 + 0x10000; + + this.buffer_.push((c >> 18) | 240); + this.buffer_.push(((c >> 12) & 63 ) | 128); + this.buffer_.push(((c >> 6) & 63) | 128); + this.buffer_.push((c & 63) | 128); + i++; } } - this.buffer_.push((c >> 12) | 224); - this.buffer_.push(((c >> 6) & 63) | 128); - this.buffer_.push((c & 63) | 128); - } else { - this.buffer_.push((c >> 18) | 240); - this.buffer_.push(((c >> 12) & 63 ) | 128); - this.buffer_.push(((c >> 6) & 63) | 128); - this.buffer_.push((c & 63) | 128); - i++; + else { + this.buffer_.push((c >> 12) | 224); + this.buffer_.push(((c >> 6) & 63) | 128); + this.buffer_.push((c & 63) | 128); + } } }