Index: netlog_viewer/sockets_view.js |
diff --git a/netlog_viewer/sockets_view.js b/netlog_viewer/sockets_view.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..9b12cb3376662ebc572426575554c197a15a6d52 |
--- /dev/null |
+++ b/netlog_viewer/sockets_view.js |
@@ -0,0 +1,95 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+/** |
+ * This view displays information on the state of all socket pools. |
+ * |
+ * - Shows a summary of the state of each socket pool at the top. |
+ * - For each pool with allocated sockets or connect jobs, shows all its |
+ * groups with any allocated sockets. |
+ */ |
+var SocketsView = (function() { |
+ 'use strict'; |
+ |
+ // We inherit from DivView. |
+ var superClass = DivView; |
+ |
+ /** |
+ * @constructor |
+ */ |
+ function SocketsView() { |
+ assertFirstConstructorCall(SocketsView); |
+ |
+ // Call superclass's constructor. |
+ superClass.call(this, SocketsView.MAIN_BOX_ID); |
+ |
+ g_browser.addSocketPoolInfoObserver(this, true); |
+ this.socketPoolDiv_ = $(SocketsView.SOCKET_POOL_DIV_ID); |
+ this.socketPoolGroupsDiv_ = $(SocketsView.SOCKET_POOL_GROUPS_DIV_ID); |
+ |
+ var closeIdleButton = $(SocketsView.CLOSE_IDLE_SOCKETS_BUTTON_ID); |
+ closeIdleButton.onclick = this.closeIdleSockets.bind(this); |
+ |
+ var flushSocketsButton = $(SocketsView.SOCKET_POOL_FLUSH_BUTTON_ID); |
+ flushSocketsButton.onclick = this.flushSocketPools.bind(this); |
+ } |
+ |
+ SocketsView.TAB_ID = 'tab-handle-sockets'; |
+ SocketsView.TAB_NAME = 'Sockets'; |
+ SocketsView.TAB_HASH = '#sockets'; |
+ |
+ // IDs for special HTML elements in sockets_view.html |
+ SocketsView.MAIN_BOX_ID = 'sockets-view-tab-content'; |
+ SocketsView.SOCKET_POOL_DIV_ID = 'sockets-view-pool-div'; |
+ SocketsView.SOCKET_POOL_GROUPS_DIV_ID = 'sockets-view-pool-groups-div'; |
+ SocketsView.CLOSE_IDLE_SOCKETS_BUTTON_ID = 'sockets-view-close-idle-button'; |
+ SocketsView.SOCKET_POOL_FLUSH_BUTTON_ID = 'sockets-view-flush-button'; |
+ |
+ cr.addSingletonGetter(SocketsView); |
+ |
+ SocketsView.prototype = { |
+ // Inherit the superclass's methods. |
+ __proto__: superClass.prototype, |
+ |
+ onLoadLogFinish: function(data) { |
+ return this.onSocketPoolInfoChanged(data.socketPoolInfo); |
+ }, |
+ |
+ onSocketPoolInfoChanged: function(socketPoolInfo) { |
+ this.socketPoolDiv_.innerHTML = ''; |
+ this.socketPoolGroupsDiv_.innerHTML = ''; |
+ |
+ if (!socketPoolInfo) |
+ return false; |
+ |
+ var socketPools = SocketPoolWrapper.createArrayFrom(socketPoolInfo); |
+ var tablePrinter = SocketPoolWrapper.createTablePrinter(socketPools); |
+ tablePrinter.toHTML(this.socketPoolDiv_, 'styled-table'); |
+ |
+ // Add table for each socket pool with information on each of its groups. |
+ for (var i = 0; i < socketPools.length; ++i) { |
+ if (socketPools[i].origPool.groups != undefined) { |
+ var p = addNode(this.socketPoolGroupsDiv_, 'p'); |
+ var br = addNode(p, 'br'); |
+ var groupTablePrinter = socketPools[i].createGroupTablePrinter(); |
+ groupTablePrinter.toHTML(p, 'styled-table'); |
+ } |
+ } |
+ return true; |
+ }, |
+ |
+ closeIdleSockets: function() { |
+ g_browser.sendCloseIdleSockets(); |
+ g_browser.checkForUpdatedInfo(false); |
+ }, |
+ |
+ flushSocketPools: function() { |
+ g_browser.sendFlushSocketPools(); |
+ g_browser.checkForUpdatedInfo(false); |
+ } |
+ }; |
+ |
+ return SocketsView; |
+})(); |
+ |