2012-05-21 15:12:37 +04:00
|
|
|
/* 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/. */
|
2005-08-23 20:38:28 +04:00
|
|
|
|
|
|
|
#include "nsISupports.idl"
|
|
|
|
|
|
|
|
interface nsIDOMWindow;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* nsIBrowserGlue is a dirty and rather fluid interface to host shared utility
|
|
|
|
* methods used by browser UI code, but which are not local to a browser window.
|
|
|
|
* The component implementing this interface is meant to be a singleton
|
|
|
|
* (service) and should progressively replace some of the shared "glue" code
|
|
|
|
* scattered in browser/base/content (e.g. bits of utilOverlay.js,
|
|
|
|
* contentAreaUtils.js, globalOverlay.js, browser.js), avoiding dynamic
|
|
|
|
* inclusion and initialization of a ton of JS code for *each* window.
|
|
|
|
* Dued to its nature and origin, this interface won't probably be the most
|
|
|
|
* elegant or stable in the mozilla codebase, but its aim is rather pragmatic:
|
|
|
|
* 1) reducing the performance overhead which affects browser window load;
|
|
|
|
* 2) allow global hooks (e.g. startup and shutdown observers) which survive
|
|
|
|
* browser windows to accomplish browser-related activities, such as shutdown
|
|
|
|
* sanitization (see bug #284086)
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2015-04-01 20:09:26 +03:00
|
|
|
[scriptable, uuid(ea083cb7-6b9d-4695-8b34-2e8f6ce2a860)]
|
2005-08-23 20:38:28 +04:00
|
|
|
interface nsIBrowserGlue : nsISupports
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Deletes privacy sensitive data according to user preferences
|
|
|
|
*
|
2005-12-05 00:02:38 +03:00
|
|
|
* @param aParentWindow an optionally null window which is the parent of the
|
2009-01-02 03:00:49 +03:00
|
|
|
* sanitization dialog
|
2005-08-23 20:38:28 +04:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
void sanitize(in nsIDOMWindow aParentWindow);
|
2007-11-27 03:08:50 +03:00
|
|
|
|
2008-10-31 09:42:02 +03:00
|
|
|
/**
|
|
|
|
* Gets the most recent window that's a browser (but not a popup)
|
|
|
|
*/
|
|
|
|
nsIDOMWindow getMostRecentBrowserWindow();
|
2005-08-23 20:38:28 +04:00
|
|
|
};
|