diff options
author | Steve Block <steveblock@google.com> | 2011-05-25 19:08:45 +0100 |
---|---|---|
committer | Steve Block <steveblock@google.com> | 2011-06-08 13:51:31 +0100 |
commit | 2bde8e466a4451c7319e3a072d118917957d6554 (patch) | |
tree | 28f4a1b869a513e565c7760d0e6a06e7cf1fe95a /Tools/BuildSlaveSupport/build.webkit.org-config/public_html/LeaksViewer/LeaksParserWorker.js | |
parent | 6939c99b71d9372d14a0c74a772108052e8c48c8 (diff) | |
download | external_webkit-2bde8e466a4451c7319e3a072d118917957d6554.zip external_webkit-2bde8e466a4451c7319e3a072d118917957d6554.tar.gz external_webkit-2bde8e466a4451c7319e3a072d118917957d6554.tar.bz2 |
Merge WebKit at r82507: Initial merge by git
Change-Id: I60ce9d780725b58b45e54165733a8ffee23b683e
Diffstat (limited to 'Tools/BuildSlaveSupport/build.webkit.org-config/public_html/LeaksViewer/LeaksParserWorker.js')
-rw-r--r-- | Tools/BuildSlaveSupport/build.webkit.org-config/public_html/LeaksViewer/LeaksParserWorker.js | 101 |
1 files changed, 101 insertions, 0 deletions
diff --git a/Tools/BuildSlaveSupport/build.webkit.org-config/public_html/LeaksViewer/LeaksParserWorker.js b/Tools/BuildSlaveSupport/build.webkit.org-config/public_html/LeaksViewer/LeaksParserWorker.js new file mode 100644 index 0000000..c425b15 --- /dev/null +++ b/Tools/BuildSlaveSupport/build.webkit.org-config/public_html/LeaksViewer/LeaksParserWorker.js @@ -0,0 +1,101 @@ +/* + * Copyright (C) 2011 Apple Inc. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, + * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS + * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF + * THE POSSIBILITY OF SUCH DAMAGE. + */ + +function LeaksParserWorker() { + this.profile = this._createNode("top level"); +} + +LeaksParserWorker.prototype = { + addLeaksFile: function(leaksText) { + this._incorporateLeaks(this._parseLeaks(leaksText)); + }, + + _parseLeaks: function(text) { + var leaks = []; + var currentSize = 0; + text.split("\n").forEach(function(line) { + var match = /^Leak:.*\ssize=(\d+)\s/.exec(line); + if (match) { + currentSize = parseInt(match[1], 10); + return; + } + if (!/^\s+Call stack:/.test(line)) + return; + + // The first frame is not really a frame at all ("Call stack: thread 0xNNNNN:"), so we omit it. + leaks.push({ size: currentSize, stack: line.split(" | ").slice(1).map(function(str) { return str.trim(); }) }); + currentSize = 0; + }); + return leaks; + }, + + _createNode: function(functionName) { + return { + functionName: functionName, + selfTime: 0, + totalTime: 0, + averageTime: 0, + numberOfCalls: 0, + children: [], + childrenByName: {}, + callUID: functionName, + }; + }, + + // This function creates a fake "profile" from a set of leak stacks. "selfTime" is the number of + // stacks in which this function was at the top (in theory, only functions like malloc should have a + // non-zero selfTime). "totalTime" is the number of stacks which contain this function (and thus is + // the number of leaks that occurred in or beneath this function). + // FIXME: This is expensive! Can we parallelize it? + _incorporateLeaks: function(leaks) { + var self = this; + leaks.forEach(function(leak) { + leak.stack.reduce(function(node, frame, index, array) { + var childNode; + if (frame in node.childrenByName) + childNode = node.childrenByName[frame]; + else { + childNode = self._createNode(frame); + childNode.head = self.profile; + node.childrenByName[frame] = childNode; + node.children.push(childNode); + } + if (index === array.length - 1) + childNode.selfTime += leak.size; + childNode.totalTime += leak.size; + ++childNode.numberOfCalls; + return childNode; + }, self.profile); + }); + self.profile.totalTime = self.profile.children.reduce(function(sum, child) { return sum + child.totalTime; }, 0); + }, +}; + +var parser = new LeaksParserWorker(); + +onmessage = function(e) { + parser.addLeaksFile(e.data); + postMessage(parser.profile); +} |