summaryrefslogtreecommitdiffstats
path: root/chrome/browser/resources/workers/workers.js
blob: 991330565de8fd9eb1f0d5a43d0a961885632c8f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
// Copyright (c) 2011 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.

function requestData() {
  var xhr = new XMLHttpRequest();
  xhr.open('GET', 'workers_data.json', false);
  xhr.send(null);
  if (xhr.status === 200)
     return JSON.parse(xhr.responseText);
  return [];
}

function addColumn(row, value) {
  var column = document.createElement("td");
  column.textContent = value;
  row.appendChild(column);
}

function openDevTools(workerProcessHostId, workerRouteId) {
  chrome.send("openDevTools",
              [String(workerProcessHostId), String(workerRouteId)]);
}

function reloadWorker(workerProcessHostId, workerRouteId) {
  chrome.send("terminateWorker",
              [String(workerProcessHostId), String(workerRouteId)]);
}

function populateWorkerList() {
  var data = requestData();
  var list = document.getElementById("workers-table");
  for (var i = 0; i < data.length; i++)
    addWorkerInfoToList(data[i], list);
}

function addWorkerInfoToList(workerData, list) {
  var row = document.createElement("tr");
  var workerProperties = ["workerRouteId", "url", "name", "pid"];
  for (var j = 0; j < workerProperties.length; j++)
    addColumn(row, workerData[workerProperties[j]]);

  var column = document.createElement("td");
  var link = document.createElement("a");
  link.setAttribute("href", "#");
  link.textContent = "inspect";
  link.addEventListener(
      "click",
      openDevTools.bind(this,
                        workerData.workerProcessHostId,
                        workerData.workerRouteId),
      true);
  column.appendChild(link);
  row.appendChild(column);

  var link = document.createElement("a");
  link.setAttribute("href", "#");
  link.textContent = "terminate";
  link.addEventListener(
      "click",
      reloadWorker.bind(this,
                        workerData.workerProcessHostId,
                        workerData.workerRouteId),
      true);
  column.appendChild(link);
  row.appendChild(column);

  row.workerProcessHostId = workerData.workerProcessHostId;
  row.workerRouteId = workerData.workerRouteId;

  list.appendChild(row);
}

function workerCreated(workerData) {
  var list = document.getElementById("workers-table");
  addWorkerInfoToList(workerData, list);
}

function workerDestroyed(workerData) {
  var list = document.getElementById("workers-table");
  for (var row = list.firstChild; row; row = row.nextSibling) {
    if (row.workerProcessHostId === workerData.workerProcessHostId &&
        row.workerRouteId === workerData.workerRouteId) {
      list.removeChild(row);
      return;
    }
  }
}

document.addEventListener('DOMContentLoaded', populateWorkerList);