/* 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 nsIArray; interface nsIArrayExtensions; interface nsIDOMCharacterData; interface nsIDOMElement; interface nsIDOMDocument; interface nsIDOMCSSRule; interface nsIDOMCSSStyleRule; interface nsIDOMNode; interface nsIDOMNodeList; interface nsIDOMFontFaceList; interface nsIDOMRange; interface nsIDOMCSSStyleSheet; [scriptable, uuid(362e98c3-82c2-4ad8-8dcb-00e8e4eab497)] interface inIDOMUtils : nsISupports { // CSS utilities void getAllStyleSheets (in nsIDOMDocument aDoc, [optional] out unsigned long aLength, [array, size_is (aLength), retval] out nsISupports aSheets); nsIArrayExtensions getCSSStyleRules(in nsIDOMElement aElement, [optional] in DOMString aPseudo); /** * Get the line number of a rule. * * @param nsIDOMCSSRule aRule The rule. * @return The rule's line number. Line numbers are 1-based. */ unsigned long getRuleLine(in nsIDOMCSSRule aRule); /** * Get the column number of a rule. * * @param nsIDOMCSSRule aRule The rule. * @return The rule's column number. Column numbers are 1-based. */ unsigned long getRuleColumn(in nsIDOMCSSRule aRule); /** * Like getRuleLine, but if the rule is in a <style> element, * returns a line number relative to the start of the element. * * @param nsIDOMCSSRule aRule the rule to examine * @return the line number of the rule, possibly relative to the * <style> element */ unsigned long getRelativeRuleLine(in nsIDOMCSSRule aRule); [implicit_jscontext] jsval getCSSLexer(in DOMString aText); // Utilities for working with selectors. We don't have a JS OM representation // of a single selector or a selector list yet, but given a rule we can index // into the selector list. // // This is a somewhat backwards API; once we move StyleRule to WebIDL we // should consider using [ChromeOnly] APIs on that. unsigned long getSelectorCount(in nsIDOMCSSStyleRule aRule); // For all three functions below, aSelectorIndex is 0-based AString getSelectorText(in nsIDOMCSSStyleRule aRule, in unsigned long aSelectorIndex); unsigned long long getSpecificity(in nsIDOMCSSStyleRule aRule, in unsigned long aSelectorIndex); // Note: This does not handle scoped selectors correctly, because it has no // idea what the right scope is. bool selectorMatchesElement(in nsIDOMElement aElement, in nsIDOMCSSStyleRule aRule, in unsigned long aSelectorIndex, [optional] in DOMString aPseudo); // Utilities for working with CSS properties // // Returns true if the string names a property that is inherited by default. bool isInheritedProperty(in AString aPropertyName); // Get a list of all our supported property names. Optionally // shorthands can be excluded or property aliases included. const unsigned long EXCLUDE_SHORTHANDS = (1<<0); const unsigned long INCLUDE_ALIASES = (1<<1); void getCSSPropertyNames([optional] in unsigned long aFlags, [optional] out unsigned long aCount, [retval, array, size_is(aCount)] out wstring aProps); // Get a list of all valid keywords and colors for aProperty. void getCSSValuesForProperty(in AString aProperty, [optional] out unsigned long aLength, [array, size_is(aLength), retval] out wstring aValues); // Utilities for working with CSS colors [implicit_jscontext] jsval colorNameToRGB(in DOMString aColorName); AString rgbToColorName(in octet aR, in octet aG, in octet aB); // Convert a given CSS color string to rgba. Returns null on failure or an // InspectorRGBATuple on success. // // NOTE: Converting a color to RGBA may be lossy when converting from some // formats e.g. CMYK. [implicit_jscontext] jsval colorToRGBA(in DOMString aColorString); // Check whether a given color is a valid CSS color. bool isValidCSSColor(in AString aColorString); // Utilities for obtaining information about a CSS property. // Check whether a CSS property and value are a valid combination. If the // property is pref-disabled it will still be processed. // aPropertyName: A property name e.g. "color" // aPropertyValue: A property value e.g. "red" or "red !important" bool cssPropertyIsValid(in AString aPropertyName, in AString aPropertyValue); // Get a list of the longhands corresponding to the given CSS property. If // the property is a longhand already, just returns the property itself. // Throws on unsupported property names. void getSubpropertiesForCSSProperty(in AString aProperty, [optional] out unsigned long aLength, [array, size_is(aLength), retval] out wstring aValues); // Check whether a given CSS property is a shorthand. Throws on unsupported // property names. bool cssPropertyIsShorthand(in AString aProperty); // Check whether values of the given type are valid values for the property. // For shorthands, checks whether there's a corresponding longhand property // that accepts values of this type. Throws on unsupported properties or // unknown types. const unsigned long TYPE_LENGTH = 0; const unsigned long TYPE_PERCENTAGE = 1; const unsigned long TYPE_COLOR = 2; const unsigned long TYPE_URL = 3; const unsigned long TYPE_ANGLE = 4; const unsigned long TYPE_FREQUENCY = 5; const unsigned long TYPE_TIME = 6; const unsigned long TYPE_GRADIENT = 7; const unsigned long TYPE_TIMING_FUNCTION = 8; const unsigned long TYPE_IMAGE_RECT = 9; const unsigned long TYPE_NUMBER = 10; bool cssPropertySupportsType(in AString aProperty, in unsigned long type); // DOM Node utilities boolean isIgnorableWhitespace(in nsIDOMCharacterData aDataNode); // Returns the "parent" of a node. The parent of a document node is the // frame/iframe containing that document. aShowingAnonymousContent says // whether we are showing anonymous content. nsIDOMNode getParentForNode(in nsIDOMNode aNode, in boolean aShowingAnonymousContent); nsIDOMNodeList getChildrenForNode(in nsIDOMNode aNode, in boolean aShowingAnonymousContent); // XBL utilities nsIArray getBindingURLs(in nsIDOMElement aElement); // content state utilities unsigned long long getContentState(in nsIDOMElement aElement); /** * Setting and removing content state on an element. Both these functions * calling EventStateManager::SetContentState internally, the difference is * that for the remove case we simply pass in nullptr for the element. * Use them accordingly. * * @return Returns true if the state was set successfully. See more details * in EventStateManager.h SetContentState. */ bool setContentState(in nsIDOMElement aElement, in unsigned long long aState); bool removeContentState(in nsIDOMElement aElement, in unsigned long long aState); nsIDOMFontFaceList getUsedFontFaces(in nsIDOMRange aRange); /** * Get the names of all the supported pseudo-elements. * Pseudo-elements which are only accepted in UA style sheets are * not included. * * @param {unsigned long} aCount the number of items returned * @param {wstring[]} aNames the names */ void getCSSPseudoElementNames([optional] out unsigned long aCount, [retval, array, size_is(aCount)] out wstring aNames); // pseudo-class style locking methods. aPseudoClass must be a valid pseudo-class // selector string, e.g. ":hover". ":any-link" and non-event-state // pseudo-classes are ignored. void addPseudoClassLock(in nsIDOMElement aElement, in DOMString aPseudoClass); void removePseudoClassLock(in nsIDOMElement aElement, in DOMString aPseudoClass); bool hasPseudoClassLock(in nsIDOMElement aElement, in DOMString aPseudoClass); void clearPseudoClassLocks(in nsIDOMElement aElement); /** * Parse CSS and update the style sheet in place. * * @param DOMCSSStyleSheet aSheet * @param DOMString aInput * The new source string for the style sheet. */ void parseStyleSheet(in nsIDOMCSSStyleSheet aSheet, in DOMString aInput); /** * Scroll an element completely into view, if possible. * This is similar to ensureElementIsVisible but for all ancestors. * * @param DOMElement aElement */ void scrollElementIntoView(in nsIDOMElement aElement); }; %{ C++ #define IN_DOMUTILS_CONTRACTID "@mozilla.org/inspector/dom-utils;1" %}