From 849d8cfa2440812e8deff61a93c72727e7d9e0d5 Mon Sep 17 00:00:00 2001 From: Rob Wu Date: Sun, 18 Jun 2017 12:57:17 +0200 Subject: [PATCH] Improve memory-efficiency of DOMElement_toString in domstubs Test case: Using the PDF file from https://github.com/mozilla/pdf.js/issues/8534 node --max_old_space_size=200 examples/node/pdf2svg.js /tmp/FatalProcessOutOfMemory.pdf Before this patch: Node.js crashes due to OOM after processing 10 pages. After this patch: Node.js crashes due to OOM after processing 19 pages. --- examples/node/domstubs.js | 29 ++++++++++++++++------------- 1 file changed, 16 insertions(+), 13 deletions(-) diff --git a/examples/node/domstubs.js b/examples/node/domstubs.js index ce4dc7890..d746b0051 100644 --- a/examples/node/domstubs.js +++ b/examples/node/domstubs.js @@ -91,24 +91,27 @@ DOMElement.prototype = { }, toString: function DOMElement_toString() { - var attrList = []; - for (i in this.attributes) { - attrList.push(i + '="' + xmlEncode(this.attributes[i]) + '"'); + var buf = []; + buf.push('<' + this.nodeName); + if (this.nodeName === 'svg:svg') { + buf.push(' xmlns:xlink="http://www.w3.org/1999/xlink"' + + ' xmlns:svg="http://www.w3.org/2000/svg"'); + } + for (var i in this.attributes) { + buf.push(' ' + i + '="' + xmlEncode(this.attributes[i]) + '"'); } + buf.push('>'); + if (this.nodeName === 'svg:tspan' || this.nodeName === 'svg:style') { - var encText = xmlEncode(this.textContent); - return '<' + this.nodeName + ' ' + attrList.join(' ') + '>' + - encText + ''; - } else if (this.nodeName === 'svg:svg') { - var ns = 'xmlns:xlink="http://www.w3.org/1999/xlink" ' + - 'xmlns:svg="http://www.w3.org/2000/svg"' - return '<' + this.nodeName + ' ' + ns + ' ' + attrList.join(' ') + '>' + - this.childNodes.join('') + ''; + buf.push(xmlEncode(this.textContent)); } else { - return '<' + this.nodeName + ' ' + attrList.join(' ') + '>' + - this.childNodes.join('') + ''; + this.childNodes.forEach(function(childNode) { + buf.push(childNode.toString()); + }); } + buf.push(''); + return buf.join(''); }, cloneNode: function DOMElement_cloneNode() {