summaryrefslogtreecommitdiffstats
path: root/Tools/BuildSlaveSupport/build.webkit.org-config/public_html/LeaksViewer/LeaksParserWorker.js
diff options
context:
space:
mode:
authorSteve Block <steveblock@google.com>2011-05-25 19:08:45 +0100
committerSteve Block <steveblock@google.com>2011-06-08 13:51:31 +0100
commit2bde8e466a4451c7319e3a072d118917957d6554 (patch)
tree28f4a1b869a513e565c7760d0e6a06e7cf1fe95a /Tools/BuildSlaveSupport/build.webkit.org-config/public_html/LeaksViewer/LeaksParserWorker.js
parent6939c99b71d9372d14a0c74a772108052e8c48c8 (diff)
downloadexternal_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.js101
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);
+}