2012-03-31 04:42:20 +00:00
|
|
|
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* 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/.
|
|
|
|
*
|
2012-12-22 08:27:27 +00:00
|
|
|
* The origin of this IDL file is:
|
|
|
|
* http://dom.spec.whatwg.org/#interface-document
|
|
|
|
* http://www.whatwg.org/specs/web-apps/current-work/#the-document-object
|
|
|
|
* http://dvcs.w3.org/hg/fullscreen/raw-file/tip/Overview.html#api
|
|
|
|
* http://dvcs.w3.org/hg/pointerlock/raw-file/default/index.html#extensions-to-the-document-interface
|
|
|
|
* http://dvcs.w3.org/hg/webperf/raw-file/tip/specs/PageVisibility/Overview.html#sec-document-interface
|
|
|
|
* http://dev.w3.org/csswg/cssom/#extensions-to-the-document-interface
|
|
|
|
* http://dev.w3.org/csswg/cssom-view/#extensions-to-the-document-interface
|
2012-03-31 04:42:20 +00:00
|
|
|
*
|
2012-12-22 08:27:27 +00:00
|
|
|
* http://mxr.mozilla.org/mozilla-central/source/dom/interfaces/core/nsIDOMDocument.idl
|
2012-03-31 04:42:20 +00:00
|
|
|
*/
|
|
|
|
|
2012-12-22 08:27:27 +00:00
|
|
|
interface StyleSheetList;
|
|
|
|
interface WindowProxy;
|
2012-12-23 22:33:33 +00:00
|
|
|
interface nsISupports;
|
2013-07-15 21:28:33 +00:00
|
|
|
interface URI;
|
2012-12-22 08:27:27 +00:00
|
|
|
|
2012-12-25 22:00:15 +00:00
|
|
|
enum VisibilityState { "hidden", "visible" };
|
|
|
|
|
2012-12-22 08:27:27 +00:00
|
|
|
/* http://dom.spec.whatwg.org/#interface-document */
|
|
|
|
[Constructor]
|
2012-03-31 04:42:20 +00:00
|
|
|
interface Document : Node {
|
2013-01-29 22:53:53 +00:00
|
|
|
[Throws]
|
2012-03-31 04:42:20 +00:00
|
|
|
readonly attribute DOMImplementation implementation;
|
|
|
|
readonly attribute DOMString URL;
|
|
|
|
readonly attribute DOMString documentURI;
|
|
|
|
readonly attribute DOMString compatMode;
|
|
|
|
readonly attribute DOMString characterSet;
|
|
|
|
readonly attribute DOMString contentType;
|
|
|
|
|
|
|
|
readonly attribute DocumentType? doctype;
|
|
|
|
readonly attribute Element? documentElement;
|
2012-12-22 08:27:27 +00:00
|
|
|
HTMLCollection getElementsByTagName(DOMString localName);
|
|
|
|
HTMLCollection getElementsByTagNameNS(DOMString? namespace, DOMString localName);
|
|
|
|
HTMLCollection getElementsByClassName(DOMString classNames);
|
2012-03-31 04:42:20 +00:00
|
|
|
Element? getElementById(DOMString elementId);
|
|
|
|
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-03-31 04:42:20 +00:00
|
|
|
Element createElement(DOMString localName);
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-03-31 04:42:20 +00:00
|
|
|
Element createElementNS(DOMString? namespace, DOMString qualifiedName);
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject]
|
2012-03-31 04:42:20 +00:00
|
|
|
DocumentFragment createDocumentFragment();
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject]
|
2012-03-31 04:42:20 +00:00
|
|
|
Text createTextNode(DOMString data);
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject]
|
2012-03-31 04:42:20 +00:00
|
|
|
Comment createComment(DOMString data);
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-03-31 04:42:20 +00:00
|
|
|
ProcessingInstruction createProcessingInstruction(DOMString target, DOMString data);
|
|
|
|
|
2012-12-22 08:27:27 +00:00
|
|
|
[Throws]
|
|
|
|
Node importNode(Node node, optional boolean deep = true);
|
|
|
|
[Throws]
|
2012-03-31 04:42:20 +00:00
|
|
|
Node adoptNode(Node node);
|
|
|
|
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-12-22 08:27:27 +00:00
|
|
|
Event createEvent(DOMString interface);
|
2012-03-31 04:42:20 +00:00
|
|
|
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-03-31 04:42:20 +00:00
|
|
|
Range createRange();
|
|
|
|
|
2012-12-22 08:27:27 +00:00
|
|
|
// NodeFilter.SHOW_ALL = 0xFFFFFFFF
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-12-22 08:27:27 +00:00
|
|
|
NodeIterator createNodeIterator(Node root, optional unsigned long whatToShow = 0xFFFFFFFF, optional NodeFilter? filter = null);
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-12-22 08:27:27 +00:00
|
|
|
TreeWalker createTreeWalker(Node root, optional unsigned long whatToShow = 0xFFFFFFFF, optional NodeFilter? filter = null);
|
2012-03-31 04:42:20 +00:00
|
|
|
|
|
|
|
// NEW
|
2012-12-22 08:27:27 +00:00
|
|
|
// No support for prepend/append yet
|
|
|
|
// void prepend((Node or DOMString)... nodes);
|
|
|
|
// void append((Node or DOMString)... nodes);
|
|
|
|
|
|
|
|
// These are not in the spec, but leave them for now for backwards compat.
|
|
|
|
// So sort of like Gecko extensions
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-12-22 08:27:27 +00:00
|
|
|
CDATASection createCDATASection(DOMString data);
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-12-22 08:27:27 +00:00
|
|
|
Attr createAttribute(DOMString name);
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Throws]
|
2012-12-22 08:27:27 +00:00
|
|
|
Attr createAttributeNS(DOMString? namespace, DOMString name);
|
|
|
|
readonly attribute DOMString? inputEncoding;
|
|
|
|
};
|
|
|
|
|
2013-01-10 15:49:07 +00:00
|
|
|
// http://www.whatwg.org/specs/web-apps/current-work/#the-document-object
|
2012-12-22 08:27:27 +00:00
|
|
|
partial interface Document {
|
|
|
|
[PutForwards=href, Unforgeable] readonly attribute Location? location;
|
|
|
|
//(HTML only) attribute DOMString domain;
|
|
|
|
readonly attribute DOMString referrer;
|
|
|
|
//(HTML only) attribute DOMString cookie;
|
|
|
|
readonly attribute DOMString lastModified;
|
|
|
|
readonly attribute DOMString readyState;
|
|
|
|
|
|
|
|
// DOM tree accessors
|
|
|
|
//(Not proxy yet)getter object (DOMString name);
|
|
|
|
[SetterThrows]
|
|
|
|
attribute DOMString title;
|
|
|
|
attribute DOMString dir;
|
|
|
|
//(HTML only) attribute HTMLElement? body;
|
|
|
|
//(HTML only)readonly attribute HTMLHeadElement? head;
|
|
|
|
//(HTML only)readonly attribute HTMLCollection images;
|
|
|
|
//(HTML only)readonly attribute HTMLCollection embeds;
|
|
|
|
//(HTML only)readonly attribute HTMLCollection plugins;
|
|
|
|
//(HTML only)readonly attribute HTMLCollection links;
|
|
|
|
//(HTML only)readonly attribute HTMLCollection forms;
|
|
|
|
//(HTML only)readonly attribute HTMLCollection scripts;
|
|
|
|
//(HTML only)NodeList getElementsByName(DOMString elementName);
|
|
|
|
//(HTML only)NodeList getItems(optional DOMString typeNames); // microdata
|
|
|
|
//(Not implemented)readonly attribute DOMElementMap cssElementMap;
|
|
|
|
|
|
|
|
// dynamic markup insertion
|
|
|
|
//(HTML only)Document open(optional DOMString type, optional DOMString replace);
|
|
|
|
//(HTML only)WindowProxy open(DOMString url, DOMString name, DOMString features, optional boolean replace);
|
|
|
|
//(HTML only)void close();
|
|
|
|
//(HTML only)void write(DOMString... text);
|
|
|
|
//(HTML only)void writeln(DOMString... text);
|
|
|
|
|
|
|
|
// user interaction
|
|
|
|
readonly attribute WindowProxy? defaultView;
|
|
|
|
readonly attribute Element? activeElement;
|
|
|
|
[Throws]
|
|
|
|
boolean hasFocus();
|
|
|
|
//(HTML only) attribute DOMString designMode;
|
|
|
|
//(HTML only)boolean execCommand(DOMString commandId);
|
|
|
|
//(HTML only)boolean execCommand(DOMString commandId, boolean showUI);
|
|
|
|
//(HTML only)boolean execCommand(DOMString commandId, boolean showUI, DOMString value);
|
|
|
|
//(HTML only)boolean queryCommandEnabled(DOMString commandId);
|
|
|
|
//(HTML only)boolean queryCommandIndeterm(DOMString commandId);
|
|
|
|
//(HTML only)boolean queryCommandState(DOMString commandId);
|
|
|
|
//(HTML only)boolean queryCommandSupported(DOMString commandId);
|
|
|
|
//(HTML only)DOMString queryCommandValue(DOMString commandId);
|
|
|
|
//(Not implemented)readonly attribute HTMLCollection commands;
|
|
|
|
|
|
|
|
// special event handler IDL attributes that only apply to Document objects
|
2013-09-17 11:01:28 +00:00
|
|
|
[LenientThis] attribute EventHandler onreadystatechange;
|
2012-12-22 08:27:27 +00:00
|
|
|
|
|
|
|
// Gecko extensions?
|
2013-09-17 11:01:28 +00:00
|
|
|
attribute EventHandler onwheel;
|
|
|
|
attribute EventHandler oncopy;
|
|
|
|
attribute EventHandler oncut;
|
|
|
|
attribute EventHandler onpaste;
|
|
|
|
attribute EventHandler onbeforescriptexecute;
|
|
|
|
attribute EventHandler onafterscriptexecute;
|
2012-12-22 08:27:27 +00:00
|
|
|
/**
|
|
|
|
* True if this document is synthetic : stand alone image, video, audio file,
|
|
|
|
* etc.
|
|
|
|
*/
|
|
|
|
[ChromeOnly] readonly attribute boolean mozSyntheticDocument;
|
|
|
|
/**
|
|
|
|
* Returns the script element whose script is currently being processed.
|
|
|
|
*
|
|
|
|
* @see <https://developer.mozilla.org/en/DOM/document.currentScript>
|
|
|
|
*/
|
|
|
|
readonly attribute Element? currentScript;
|
|
|
|
/**
|
|
|
|
* Release the current mouse capture if it is on an element within this
|
|
|
|
* document.
|
|
|
|
*
|
|
|
|
* @see <https://developer.mozilla.org/en/DOM/document.releaseCapture>
|
|
|
|
*/
|
|
|
|
void releaseCapture();
|
|
|
|
/**
|
|
|
|
* Use the given DOM element as the source image of target |-moz-element()|.
|
|
|
|
*
|
|
|
|
* This function introduces a new special ID (called "image element ID"),
|
|
|
|
* which is only used by |-moz-element()|, and associates it with the given
|
|
|
|
* DOM element. Image elements ID's have the higher precedence than general
|
|
|
|
* HTML id's, so if |document.mozSetImageElement(<id>, <element>)| is called,
|
|
|
|
* |-moz-element(#<id>)| uses |<element>| as the source image even if there
|
|
|
|
* is another element with id attribute = |<id>|. To unregister an image
|
|
|
|
* element ID |<id>|, call |document.mozSetImageElement(<id>, null)|.
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
* <script>
|
|
|
|
* canvas = document.createElement("canvas");
|
|
|
|
* canvas.setAttribute("width", 100);
|
|
|
|
* canvas.setAttribute("height", 100);
|
|
|
|
* // draw to canvas
|
|
|
|
* document.mozSetImageElement("canvasbg", canvas);
|
|
|
|
* </script>
|
|
|
|
* <div style="background-image: -moz-element(#canvasbg);"></div>
|
|
|
|
*
|
|
|
|
* @param aImageElementId an image element ID to associate with
|
|
|
|
* |aImageElement|
|
|
|
|
* @param aImageElement a DOM element to be used as the source image of
|
|
|
|
* |-moz-element(#aImageElementId)|. If this is null, the function will
|
|
|
|
* unregister the image element ID |aImageElementId|.
|
|
|
|
*
|
|
|
|
* @see <https://developer.mozilla.org/en/DOM/document.mozSetImageElement>
|
|
|
|
*/
|
|
|
|
void mozSetImageElement(DOMString aImageElementId,
|
|
|
|
Element? aImageElement);
|
|
|
|
|
2013-02-22 14:56:29 +00:00
|
|
|
[ChromeOnly]
|
|
|
|
readonly attribute URI? documentURIObject;
|
|
|
|
|
2012-12-22 08:27:27 +00:00
|
|
|
};
|
|
|
|
|
2013-01-10 15:49:07 +00:00
|
|
|
// http://dvcs.w3.org/hg/fullscreen/raw-file/tip/Overview.html#api
|
2012-12-22 08:27:27 +00:00
|
|
|
partial interface Document {
|
|
|
|
// Note: Per spec the 'S' in these two is lowercase, but the "Moz"
|
|
|
|
// versions hve it uppercase.
|
|
|
|
readonly attribute boolean mozFullScreenEnabled;
|
|
|
|
[Throws]
|
|
|
|
readonly attribute Element? mozFullScreenElement;
|
|
|
|
|
|
|
|
//(Renamed?)void exitFullscreen();
|
|
|
|
|
|
|
|
// Gecko-specific fullscreen bits
|
|
|
|
readonly attribute boolean mozFullScreen;
|
|
|
|
void mozCancelFullScreen();
|
|
|
|
};
|
|
|
|
|
2013-01-10 15:49:07 +00:00
|
|
|
// http://dvcs.w3.org/hg/pointerlock/raw-file/default/index.html#extensions-to-the-document-interface
|
2012-12-22 08:27:27 +00:00
|
|
|
partial interface Document {
|
|
|
|
readonly attribute Element? mozPointerLockElement;
|
|
|
|
void mozExitPointerLock ();
|
|
|
|
};
|
|
|
|
|
2012-11-01 18:18:08 +00:00
|
|
|
//http://dvcs.w3.org/hg/webcomponents/raw-file/tip/spec/custom/index.html#dfn-document-register
|
|
|
|
partial interface Document {
|
|
|
|
[Throws, Pref="dom.webcomponents.enabled"]
|
|
|
|
object register(DOMString name, optional ElementRegistrationOptions options);
|
|
|
|
};
|
|
|
|
|
2013-01-10 15:49:07 +00:00
|
|
|
// http://dvcs.w3.org/hg/webperf/raw-file/tip/specs/PageVisibility/Overview.html#sec-document-interface
|
2012-12-22 08:27:27 +00:00
|
|
|
partial interface Document {
|
|
|
|
readonly attribute boolean hidden;
|
|
|
|
readonly attribute boolean mozHidden;
|
2012-12-25 22:00:15 +00:00
|
|
|
readonly attribute VisibilityState visibilityState;
|
|
|
|
readonly attribute VisibilityState mozVisibilityState;
|
2012-12-22 08:27:27 +00:00
|
|
|
};
|
|
|
|
|
2013-01-10 15:49:07 +00:00
|
|
|
// http://dev.w3.org/csswg/cssom/#extensions-to-the-document-interface
|
2012-12-22 08:27:27 +00:00
|
|
|
partial interface Document {
|
|
|
|
[Constant]
|
|
|
|
readonly attribute StyleSheetList styleSheets;
|
|
|
|
attribute DOMString? selectedStyleSheetSet;
|
|
|
|
readonly attribute DOMString? lastStyleSheetSet;
|
|
|
|
readonly attribute DOMString? preferredStyleSheetSet;
|
|
|
|
[Constant]
|
|
|
|
readonly attribute DOMStringList styleSheetSets;
|
|
|
|
void enableStyleSheetsForSet (DOMString? name);
|
|
|
|
};
|
|
|
|
|
2013-01-10 15:49:07 +00:00
|
|
|
// http://dev.w3.org/csswg/cssom-view/#extensions-to-the-document-interface
|
2012-12-22 08:27:27 +00:00
|
|
|
partial interface Document {
|
|
|
|
Element? elementFromPoint (float x, float y);
|
2013-01-07 17:56:48 +00:00
|
|
|
|
|
|
|
CaretPosition? caretPositionFromPoint (float x, float y);
|
2013-01-04 06:54:26 +00:00
|
|
|
};
|
|
|
|
|
2013-01-10 15:49:07 +00:00
|
|
|
// http://dvcs.w3.org/hg/undomanager/raw-file/tip/undomanager.html
|
2013-01-04 06:54:26 +00:00
|
|
|
partial interface Document {
|
|
|
|
[Pref="dom.undo_manager.enabled"]
|
|
|
|
readonly attribute UndoManager? undoManager;
|
|
|
|
};
|
2012-12-22 08:27:27 +00:00
|
|
|
|
2013-01-10 15:49:07 +00:00
|
|
|
// http://dev.w3.org/2006/webapi/selectors-api2/#interface-definitions
|
2012-12-22 08:27:27 +00:00
|
|
|
partial interface Document {
|
|
|
|
[Throws]
|
|
|
|
Element? querySelector(DOMString selectors);
|
|
|
|
[Throws]
|
|
|
|
NodeList querySelectorAll(DOMString selectors);
|
|
|
|
|
|
|
|
//(Not implemented)Element? find(DOMString selectors, optional (Element or sequence<Node>)? refNodes);
|
|
|
|
//(Not implemented)NodeList findAll(DOMString selectors, optional (Element or sequence<Node>)? refNodes);
|
2013-01-10 15:49:07 +00:00
|
|
|
};
|
2012-12-22 08:27:27 +00:00
|
|
|
|
2013-01-10 15:49:07 +00:00
|
|
|
// Mozilla extensions of various sorts
|
|
|
|
partial interface Document {
|
2012-12-22 08:27:27 +00:00
|
|
|
// nsIDOMDocumentXBL. Wish we could make these [ChromeOnly], but
|
|
|
|
// that would likely break bindings running with the page principal.
|
2013-09-06 16:12:56 +00:00
|
|
|
[Func="IsChromeOrXBL"]
|
2012-12-22 08:27:27 +00:00
|
|
|
NodeList? getAnonymousNodes(Element elt);
|
2013-09-06 16:12:56 +00:00
|
|
|
[Func="IsChromeOrXBL"]
|
2012-12-22 08:27:27 +00:00
|
|
|
Element? getAnonymousElementByAttribute(Element elt, DOMString attrName,
|
|
|
|
DOMString attrValue);
|
2013-09-06 16:12:56 +00:00
|
|
|
[Func="IsChromeOrXBL"]
|
2012-12-22 08:27:27 +00:00
|
|
|
Element? getBindingParent(Node node);
|
2013-09-06 16:12:56 +00:00
|
|
|
[Throws, Func="IsChromeOrXBL"]
|
2012-12-22 08:27:27 +00:00
|
|
|
void loadBindingDocument(DOMString documentURL);
|
|
|
|
|
|
|
|
// nsIDOMDocumentTouch
|
|
|
|
// XXXbz I can't find the sane spec for this stuff, so just cribbing
|
|
|
|
// from our xpidl for now.
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Func="nsGenericHTMLElement::TouchEventsEnabled"]
|
2012-12-22 08:27:27 +00:00
|
|
|
Touch createTouch(optional Window? view = null,
|
2013-04-19 08:49:20 +00:00
|
|
|
optional EventTarget? target = null,
|
2012-12-22 08:27:27 +00:00
|
|
|
optional long identifier = 0,
|
|
|
|
optional long pageX = 0,
|
|
|
|
optional long pageY = 0,
|
|
|
|
optional long screenX = 0,
|
|
|
|
optional long screenY = 0,
|
|
|
|
optional long clientX = 0,
|
|
|
|
optional long clientY = 0,
|
|
|
|
optional long radiusX = 0,
|
|
|
|
optional long radiusY = 0,
|
|
|
|
optional float rotationAngle = 0,
|
|
|
|
optional float force = 0);
|
2012-12-31 18:37:22 +00:00
|
|
|
// XXXbz a hack to get around the fact that we don't support variadics as
|
|
|
|
// distinguishing arguments yet. Once this hack is removed. we can also
|
|
|
|
// remove the corresponding overload on nsIDocument, since Touch... and
|
|
|
|
// sequence<Touch> look the same in the C++.
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Func="nsGenericHTMLElement::TouchEventsEnabled"]
|
2012-12-31 18:37:22 +00:00
|
|
|
TouchList createTouchList(Touch touch, Touch... touches);
|
|
|
|
// XXXbz and another hack for the fact that we can't usefully have optional
|
|
|
|
// distinguishing arguments but need a working zero-arg form of
|
|
|
|
// createTouchList().
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Func="nsGenericHTMLElement::TouchEventsEnabled"]
|
2012-12-31 18:37:22 +00:00
|
|
|
TouchList createTouchList();
|
2013-09-30 16:32:22 +00:00
|
|
|
[NewObject, Func="nsGenericHTMLElement::TouchEventsEnabled"]
|
2012-12-22 08:27:27 +00:00
|
|
|
TouchList createTouchList(sequence<Touch> touches);
|
2013-05-16 07:13:35 +00:00
|
|
|
|
|
|
|
[ChromeOnly]
|
|
|
|
attribute boolean styleSheetChangeEventsEnabled;
|
2013-07-15 21:28:33 +00:00
|
|
|
|
|
|
|
[ChromeOnly, Throws]
|
|
|
|
void obsoleteSheet(URI sheetURI);
|
|
|
|
[ChromeOnly, Throws]
|
|
|
|
void obsoleteSheet(DOMString sheetURI);
|
2012-03-31 04:42:20 +00:00
|
|
|
};
|
|
|
|
|
2013-06-29 03:13:22 +00:00
|
|
|
// Extension to give chrome JS the ability to determine when a document was
|
|
|
|
// created to satisfy an iframe with srcdoc attribute.
|
|
|
|
partial interface Document {
|
|
|
|
[ChromeOnly] readonly attribute boolean isSrcdocDocument;
|
|
|
|
};
|
|
|
|
|
2012-12-22 08:27:27 +00:00
|
|
|
Document implements XPathEvaluator;
|
2013-01-29 13:44:00 +00:00
|
|
|
Document implements GlobalEventHandlers;
|
2013-02-19 16:54:41 +00:00
|
|
|
Document implements TouchEventHandlers;
|
2013-07-22 12:15:43 +00:00
|
|
|
Document implements ParentNode;
|
2013-10-08 15:51:15 +00:00
|
|
|
Document implements OnErrorEventHandlerForNodes;
|