123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214 |
- /* 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"
- %}
|