https://github.com/mozilla/gecko-dev
Raw File
Tip revision: 79149ff2397791525200c0fc51ff128b15f6b350 authored by ffxbld on 06 July 2015, 01:07:43 UTC
Added FENNEC_39_0_1_RELEASE FENNEC_39_0_1_BUILD1 tag(s) for changeset 1d1e6d6573a3. DONTBUILD CLOSED TREE a=release
Tip revision: 79149ff
nsIHangReport.idl
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim:set ts=2 sw=2 sts=2 et cindent: */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "nsISupports.idl"

interface nsIDOMElement;
interface nsIFrameLoader;

/**
 * When a content process hangs, Gecko notifies "process-hang-report" observers
 * and passes an nsIHangReport for the subject parameter. There is at most one
 * nsIHangReport associated with a given content process. As long as the content
 * process stays stuck, the "process-hang-report" observer will continue to be
 * notified at regular intervals (approximately once per second). The content
 * process will continue to run uninhibitedly during this time.
 */

[scriptable, uuid(3b88d100-8d5b-11e4-b4a9-0800200c9a66)]
interface nsIHangReport : nsISupports
{
  const unsigned long SLOW_SCRIPT = 1;
  const unsigned long PLUGIN_HANG = 2;

  // The type of hang being reported: SLOW_SCRIPT or PLUGIN_HANG.
  readonly attribute unsigned long hangType;

  // For SLOW_SCRIPT reports, these fields contain information about the
  // slow script.
  // Only valid for SLOW_SCRIPT reports.
  readonly attribute nsIDOMElement scriptBrowser;
  readonly attribute ACString scriptFileName;
  readonly attribute unsigned long scriptLineNo;

  // For PLUGIN_HANGs, this field contains information about the plugin.
  // Only valid for PLUGIN_HANG reports.
  readonly attribute ACString pluginName;

  // Terminate the slow script if it is still running.
  // Only valid for SLOW_SCRIPT reports.
  void terminateScript();

  // Terminate the plugin if it is still hung.
  // Only valid for PLUGIN_HANG reports.
  void terminatePlugin();

  // Terminate the hung content process unconditionally.
  // Valid for any type of hang.
  void terminateProcess();

  // Ask the content process to start up the slow script debugger.
  // Only valid for SLOW_SCRIPT reports.
  void beginStartingDebugger();

  // Inform the content process that the slow script debugger has finished
  // spinning up. The content process will run a nested event loop until this
  // method is called.
  // Only valid for SLOW_SCRIPT reports.
  void endStartingDebugger();

  // Inquire whether the report is for a content process loaded by the given
  // frameloader.
  bool isReportForBrowser(in nsIFrameLoader aFrameLoader);
};
back to top