/* -*- Mode: C++; 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/. */ /* * Base class for all our document implementations. */ #ifndef nsDocument_h___ #define nsDocument_h___ #include "nsIDocument.h" #include "nsCOMPtr.h" #include "nsAutoPtr.h" #include "nsCRT.h" #include "nsWeakReference.h" #include "nsWeakPtr.h" #include "nsVoidArray.h" #include "nsTArray.h" #include "nsIDOMXMLDocument.h" #include "nsIDOMDocumentXBL.h" #include "nsStubDocumentObserver.h" #include "nsIDOMStyleSheetList.h" #include "nsIScriptGlobalObject.h" #include "nsIContent.h" #include "nsEventListenerManager.h" #include "nsIPrincipal.h" #include "nsIParser.h" #include "nsBindingManager.h" #include "nsINodeInfo.h" #include "nsInterfaceHashtable.h" #include "nsJSThingHashtable.h" #include "nsIBoxObject.h" #include "nsPIBoxObject.h" #include "nsIScriptObjectPrincipal.h" #include "nsIURI.h" #include "nsScriptLoader.h" #include "nsIRadioGroupContainer.h" #include "nsILayoutHistoryState.h" #include "nsIRequest.h" #include "nsILoadGroup.h" #include "nsTObserverArray.h" #include "nsStubMutationObserver.h" #include "nsIChannel.h" #include "nsCycleCollectionParticipant.h" #include "nsContentList.h" #include "nsGkAtoms.h" #include "nsIApplicationCache.h" #include "nsIApplicationCacheContainer.h" #include "nsStyleSet.h" #include "pldhash.h" #include "nsAttrAndChildArray.h" #include "nsDOMAttributeMap.h" #include "nsThreadUtils.h" #include "nsIContentViewer.h" #include "nsIDOMXPathNSResolver.h" #include "nsIInterfaceRequestor.h" #include "nsILoadContext.h" #include "nsIProgressEventSink.h" #include "nsISecurityEventSink.h" #include "nsIChannelEventSink.h" #include "imgIRequest.h" #include "mozilla/MemoryReporting.h" #include "mozilla/dom/DOMImplementation.h" #include "nsIDOMTouchEvent.h" #include "nsDataHashtable.h" #include "mozilla/TimeStamp.h" #include "mozilla/Attributes.h" #define XML_DECLARATION_BITS_DECLARATION_EXISTS (1 << 0) #define XML_DECLARATION_BITS_ENCODING_EXISTS (1 << 1) #define XML_DECLARATION_BITS_STANDALONE_EXISTS (1 << 2) #define XML_DECLARATION_BITS_STANDALONE_YES (1 << 3) class nsEventListenerManager; class nsDOMStyleSheetList; class nsDOMStyleSheetSetList; class nsIOutputStream; class nsDocument; class nsIDTD; class nsIRadioVisitor; class nsIFormControl; struct nsRadioGroupStruct; class nsOnloadBlocker; class nsUnblockOnloadEvent; class nsChildContentList; class nsHTMLStyleSheet; class nsHTMLCSSStyleSheet; class nsDOMNavigationTiming; class nsWindowSizes; class nsHtml5TreeOpExecutor; class nsDocumentOnStack; class nsPointerLockPermissionRequest; class nsISecurityConsoleMessage; namespace mozilla { namespace dom { class UndoManager; } } /** * Right now our identifier map entries contain information for 'name' * and 'id' mappings of a given string. This is so that * nsHTMLDocument::ResolveName only has to do one hash lookup instead * of two. It's not clear whether this still matters for performance. * * We also store the document.all result list here. This is mainly so that * when all elements with the given ID are removed and we remove * the ID's nsIdentifierMapEntry, the document.all result is released too. * Perhaps the document.all results should have their own hashtable * in nsHTMLDocument. */ class nsIdentifierMapEntry : public nsStringHashKey { public: typedef mozilla::dom::Element Element; nsIdentifierMapEntry(const nsAString& aKey) : nsStringHashKey(&aKey), mNameContentList(nullptr) { } nsIdentifierMapEntry(const nsAString *aKey) : nsStringHashKey(aKey), mNameContentList(nullptr) { } nsIdentifierMapEntry(const nsIdentifierMapEntry& aOther) : nsStringHashKey(&aOther.GetKey()) { NS_ERROR("Should never be called"); } ~nsIdentifierMapEntry(); void AddNameElement(nsIDocument* aDocument, Element* aElement); void RemoveNameElement(Element* aElement); bool IsEmpty(); nsBaseContentList* GetNameContentList() { return mNameContentList; } bool HasNameElement() const { return mNameContentList && mNameContentList->Length() != 0; } /** * Returns the element if we know the element associated with this * id. Otherwise returns null. */ Element* GetIdElement(); /** * Returns the list of all elements associated with this id. */ const nsSmallVoidArray* GetIdElements() const { return &mIdContentList; } /** * If this entry has a non-null image element set (using SetImageElement), * the image element will be returned, otherwise the same as GetIdElement(). */ Element* GetImageIdElement(); /** * Append all the elements with this id to aElements */ void AppendAllIdContent(nsCOMArray* aElements); /** * This can fire ID change callbacks. * @return true if the content could be added, false if we failed due * to OOM. */ bool AddIdElement(Element* aElement); /** * This can fire ID change callbacks. */ void RemoveIdElement(Element* aElement); /** * Set the image element override for this ID. This will be returned by * GetIdElement(true) if non-null. */ void SetImageElement(Element* aElement); bool HasIdElementExposedAsHTMLDocumentProperty(); bool HasContentChangeCallback() { return mChangeCallbacks != nullptr; } void AddContentChangeCallback(nsIDocument::IDTargetObserver aCallback, void* aData, bool aForImage); void RemoveContentChangeCallback(nsIDocument::IDTargetObserver aCallback, void* aData, bool aForImage); void Traverse(nsCycleCollectionTraversalCallback* aCallback); void SetDocAllList(nsContentList* aContentList) { mDocAllList = aContentList; } nsContentList* GetDocAllList() { return mDocAllList; } struct ChangeCallback { nsIDocument::IDTargetObserver mCallback; void* mData; bool mForImage; }; struct ChangeCallbackEntry : public PLDHashEntryHdr { typedef const ChangeCallback KeyType; typedef const ChangeCallback* KeyTypePointer; ChangeCallbackEntry(const ChangeCallback* key) : mKey(*key) { } ChangeCallbackEntry(const ChangeCallbackEntry& toCopy) : mKey(toCopy.mKey) { } KeyType GetKey() const { return mKey; } bool KeyEquals(KeyTypePointer aKey) const { return aKey->mCallback == mKey.mCallback && aKey->mData == mKey.mData && aKey->mForImage == mKey.mForImage; } static KeyTypePointer KeyToPointer(KeyType& aKey) { return &aKey; } static PLDHashNumber HashKey(KeyTypePointer aKey) { return mozilla::HashGeneric(aKey->mCallback, aKey->mData); } enum { ALLOW_MEMMOVE = true }; ChangeCallback mKey; }; static size_t SizeOfExcludingThis(nsIdentifierMapEntry* aEntry, mozilla::MallocSizeOf aMallocSizeOf, void* aArg); private: void FireChangeCallbacks(Element* aOldElement, Element* aNewElement, bool aImageOnly = false); // empty if there are no elements with this ID. // The elements are stored as weak pointers. nsSmallVoidArray mIdContentList; nsRefPtr mNameContentList; nsRefPtr mDocAllList; nsAutoPtr > mChangeCallbacks; nsRefPtr mImageElement; }; class nsDocHeaderData { public: nsDocHeaderData(nsIAtom* aField, const nsAString& aData) : mField(aField), mData(aData), mNext(nullptr) { } ~nsDocHeaderData(void) { delete mNext; } nsCOMPtr mField; nsString mData; nsDocHeaderData* mNext; }; class nsDOMStyleSheetList : public nsIDOMStyleSheetList, public nsStubDocumentObserver { public: nsDOMStyleSheetList(nsIDocument *aDocument); virtual ~nsDOMStyleSheetList(); NS_DECL_ISUPPORTS NS_DECL_NSIDOMSTYLESHEETLIST // nsIDocumentObserver NS_DECL_NSIDOCUMENTOBSERVER_STYLESHEETADDED NS_DECL_NSIDOCUMENTOBSERVER_STYLESHEETREMOVED // nsIMutationObserver NS_DECL_NSIMUTATIONOBSERVER_NODEWILLBEDESTROYED nsIStyleSheet* GetItemAt(uint32_t aIndex); static nsDOMStyleSheetList* FromSupports(nsISupports* aSupports) { nsIDOMStyleSheetList* list = static_cast(aSupports); #ifdef DEBUG { nsCOMPtr list_qi = do_QueryInterface(aSupports); // If this assertion fires the QI implementation for the object in // question doesn't use the nsIDOMStyleSheetList pointer as the // nsISupports pointer. That must be fixed, or we'll crash... NS_ASSERTION(list_qi == list, "Uh, fix QI!"); } #endif return static_cast(list); } protected: int32_t mLength; nsIDocument* mDocument; }; class nsOnloadBlocker MOZ_FINAL : public nsIRequest { public: nsOnloadBlocker() {} NS_DECL_ISUPPORTS NS_DECL_NSIREQUEST private: ~nsOnloadBlocker() {} }; class nsExternalResourceMap { public: typedef nsIDocument::ExternalResourceLoad ExternalResourceLoad; nsExternalResourceMap(); /** * Request an external resource document. This does exactly what * nsIDocument::RequestExternalResource is documented to do. */ nsIDocument* RequestResource(nsIURI* aURI, nsINode* aRequestingNode, nsDocument* aDisplayDocument, ExternalResourceLoad** aPendingLoad); /** * Enumerate the resource documents. See * nsIDocument::EnumerateExternalResources. */ void EnumerateResources(nsIDocument::nsSubDocEnumFunc aCallback, void* aData); /** * Traverse ourselves for cycle-collection */ void Traverse(nsCycleCollectionTraversalCallback* aCallback) const; /** * Shut ourselves down (used for cycle-collection unlink), as well * as for document destruction. */ void Shutdown() { mPendingLoads.Clear(); mMap.Clear(); mHaveShutDown = true; } bool HaveShutDown() const { return mHaveShutDown; } // Needs to be public so we can traverse them sanely struct ExternalResource { ~ExternalResource(); nsCOMPtr mDocument; nsCOMPtr mViewer; nsCOMPtr mLoadGroup; }; // Hide all our viewers void HideViewers(); // Show all our viewers void ShowViewers(); protected: class PendingLoad : public ExternalResourceLoad, public nsIStreamListener { public: PendingLoad(nsDocument* aDisplayDocument) : mDisplayDocument(aDisplayDocument) {} NS_DECL_ISUPPORTS NS_DECL_NSISTREAMLISTENER NS_DECL_NSIREQUESTOBSERVER /** * Start aURI loading. This will perform the necessary security checks and * so forth. */ nsresult StartLoad(nsIURI* aURI, nsINode* aRequestingNode); /** * Set up an nsIContentViewer based on aRequest. This is guaranteed to * put null in *aViewer and *aLoadGroup on all failures. */ nsresult SetupViewer(nsIRequest* aRequest, nsIContentViewer** aViewer, nsILoadGroup** aLoadGroup); private: nsRefPtr mDisplayDocument; nsCOMPtr mTargetListener; nsCOMPtr mURI; }; friend class PendingLoad; class LoadgroupCallbacks MOZ_FINAL : public nsIInterfaceRequestor { public: LoadgroupCallbacks(nsIInterfaceRequestor* aOtherCallbacks) : mCallbacks(aOtherCallbacks) {} NS_DECL_ISUPPORTS NS_DECL_NSIINTERFACEREQUESTOR private: // The only reason it's safe to hold a strong ref here without leaking is // that the notificationCallbacks on a loadgroup aren't the docshell itself // but a shim that holds a weak reference to the docshell. nsCOMPtr mCallbacks; // Use shims for interfaces that docshell implements directly so that we // don't hand out references to the docshell. The shims should all allow // getInterface back on us, but other than that each one should only // implement one interface. // XXXbz I wish we could just derive the _allcaps thing from _i #define DECL_SHIM(_i, _allcaps) \ class _i##Shim MOZ_FINAL : public nsIInterfaceRequestor, \ public _i \ { \ public: \ _i##Shim(nsIInterfaceRequestor* aIfreq, _i* aRealPtr) \ : mIfReq(aIfreq), mRealPtr(aRealPtr) \ { \ NS_ASSERTION(mIfReq, "Expected non-null here"); \ NS_ASSERTION(mRealPtr, "Expected non-null here"); \ } \ NS_DECL_ISUPPORTS \ NS_FORWARD_NSIINTERFACEREQUESTOR(mIfReq->) \ NS_FORWARD_##_allcaps(mRealPtr->) \ private: \ nsCOMPtr mIfReq; \ nsCOMPtr<_i> mRealPtr; \ }; DECL_SHIM(nsILoadContext, NSILOADCONTEXT) DECL_SHIM(nsIProgressEventSink, NSIPROGRESSEVENTSINK) DECL_SHIM(nsIChannelEventSink, NSICHANNELEVENTSINK) DECL_SHIM(nsISecurityEventSink, NSISECURITYEVENTSINK) DECL_SHIM(nsIApplicationCacheContainer, NSIAPPLICATIONCACHECONTAINER) #undef DECL_SHIM }; /** * Add an ExternalResource for aURI. aViewer and aLoadGroup might be null * when this is called if the URI didn't result in an XML document. This * function makes sure to remove the pending load for aURI, if any, from our * hashtable, and to notify its observers, if any. */ nsresult AddExternalResource(nsIURI* aURI, nsIContentViewer* aViewer, nsILoadGroup* aLoadGroup, nsIDocument* aDisplayDocument); nsClassHashtable mMap; nsRefPtrHashtable mPendingLoads; bool mHaveShutDown; }; class CSPErrorQueue { public: /** * Note this was designed to be passed string literals. If you give it * a dynamically allocated string, it is your responsibility to make sure * it never dies and is properly freed! */ void Add(const char* aMessageName); void Flush(nsIDocument* aDocument); CSPErrorQueue() { } ~CSPErrorQueue() { } private: nsAutoTArray mErrors; }; // Base class for our document implementations. // // Note that this class *implements* nsIDOMXMLDocument, but it's not // really an nsIDOMXMLDocument. The reason for implementing // nsIDOMXMLDocument on this class is to avoid having to duplicate all // its inherited methods on document classes that *are* // nsIDOMXMLDocument's. nsDocument's QI should *not* claim to support // nsIDOMXMLDocument unless someone writes a real implementation of // the interface. class nsDocument : public nsIDocument, public nsIDOMXMLDocument, // inherits nsIDOMDocument public nsIDOMDocumentXBL, public nsSupportsWeakReference, public nsIScriptObjectPrincipal, public nsIRadioGroupContainer, public nsIApplicationCacheContainer, public nsStubMutationObserver, public nsIObserver { public: typedef mozilla::dom::Element Element; using nsIDocument::GetElementsByTagName; NS_DECL_CYCLE_COLLECTING_ISUPPORTS NS_DECL_SIZEOF_EXCLUDING_THIS virtual void Reset(nsIChannel *aChannel, nsILoadGroup *aLoadGroup) MOZ_OVERRIDE; virtual void ResetToURI(nsIURI *aURI, nsILoadGroup *aLoadGroup, nsIPrincipal* aPrincipal) MOZ_OVERRIDE; // StartDocumentLoad is pure virtual so that subclasses must override it. // The nsDocument StartDocumentLoad does some setup, but does NOT set // *aDocListener; this is the job of subclasses. virtual nsresult StartDocumentLoad(const char* aCommand, nsIChannel* aChannel, nsILoadGroup* aLoadGroup, nsISupports* aContainer, nsIStreamListener **aDocListener, bool aReset = true, nsIContentSink* aContentSink = nullptr) MOZ_OVERRIDE = 0; virtual void StopDocumentLoad() MOZ_OVERRIDE; virtual void NotifyPossibleTitleChange(bool aBoundTitleElement) MOZ_OVERRIDE; virtual void SetDocumentURI(nsIURI* aURI) MOZ_OVERRIDE; /** * Set the principal responsible for this document. */ virtual void SetPrincipal(nsIPrincipal *aPrincipal) MOZ_OVERRIDE; /** * Get the Content-Type of this document. */ // NS_IMETHOD GetContentType(nsAString& aContentType); // Already declared in nsIDOMDocument /** * Set the Content-Type of this document. */ virtual void SetContentType(const nsAString& aContentType) MOZ_OVERRIDE; virtual nsresult SetBaseURI(nsIURI* aURI) MOZ_OVERRIDE; /** * Get/Set the base target of a link in a document. */ virtual void GetBaseTarget(nsAString &aBaseTarget) MOZ_OVERRIDE; /** * Return a standard name for the document's character set. This will * trigger a startDocumentLoad if necessary to answer the question. */ virtual void SetDocumentCharacterSet(const nsACString& aCharSetID) MOZ_OVERRIDE; /** * Add an observer that gets notified whenever the charset changes. */ virtual nsresult AddCharSetObserver(nsIObserver* aObserver) MOZ_OVERRIDE; /** * Remove a charset observer. */ virtual void RemoveCharSetObserver(nsIObserver* aObserver) MOZ_OVERRIDE; virtual Element* AddIDTargetObserver(nsIAtom* aID, IDTargetObserver aObserver, void* aData, bool aForImage) MOZ_OVERRIDE; virtual void RemoveIDTargetObserver(nsIAtom* aID, IDTargetObserver aObserver, void* aData, bool aForImage) MOZ_OVERRIDE; /** * Access HTTP header data (this may also get set from other sources, like * HTML META tags). */ virtual void GetHeaderData(nsIAtom* aHeaderField, nsAString& aData) const MOZ_OVERRIDE; virtual void SetHeaderData(nsIAtom* aheaderField, const nsAString& aData) MOZ_OVERRIDE; /** * Create a new presentation shell that will use aContext for * its presentation context (presentation contexts must not be * shared among multiple presentation shells). */ virtual already_AddRefed CreateShell(nsPresContext* aContext, nsViewManager* aViewManager, nsStyleSet* aStyleSet) MOZ_OVERRIDE; virtual void DeleteShell() MOZ_OVERRIDE; virtual nsresult GetAllowPlugins(bool* aAllowPlugins) MOZ_OVERRIDE; virtual already_AddRefed GetUndoManager() MOZ_OVERRIDE; virtual nsresult SetSubDocumentFor(Element* aContent, nsIDocument* aSubDoc) MOZ_OVERRIDE; virtual nsIDocument* GetSubDocumentFor(nsIContent* aContent) const MOZ_OVERRIDE; virtual Element* FindContentForSubDocument(nsIDocument *aDocument) const MOZ_OVERRIDE; virtual Element* GetRootElementInternal() const MOZ_OVERRIDE; /** * Get the style sheets owned by this document. * These are ordered, highest priority last */ virtual int32_t GetNumberOfStyleSheets() const MOZ_OVERRIDE; virtual nsIStyleSheet* GetStyleSheetAt(int32_t aIndex) const MOZ_OVERRIDE; virtual int32_t GetIndexOfStyleSheet(nsIStyleSheet* aSheet) const MOZ_OVERRIDE; virtual void AddStyleSheet(nsIStyleSheet* aSheet) MOZ_OVERRIDE; virtual void RemoveStyleSheet(nsIStyleSheet* aSheet) MOZ_OVERRIDE; virtual void UpdateStyleSheets(nsCOMArray& aOldSheets, nsCOMArray& aNewSheets) MOZ_OVERRIDE; virtual void AddStyleSheetToStyleSets(nsIStyleSheet* aSheet); virtual void RemoveStyleSheetFromStyleSets(nsIStyleSheet* aSheet); virtual void InsertStyleSheetAt(nsIStyleSheet* aSheet, int32_t aIndex) MOZ_OVERRIDE; virtual void SetStyleSheetApplicableState(nsIStyleSheet* aSheet, bool aApplicable) MOZ_OVERRIDE; virtual int32_t GetNumberOfCatalogStyleSheets() const MOZ_OVERRIDE; virtual nsIStyleSheet* GetCatalogStyleSheetAt(int32_t aIndex) const MOZ_OVERRIDE; virtual void AddCatalogStyleSheet(nsCSSStyleSheet* aSheet) MOZ_OVERRIDE; virtual void EnsureCatalogStyleSheet(const char *aStyleSheetURI) MOZ_OVERRIDE; virtual nsresult LoadAdditionalStyleSheet(additionalSheetType aType, nsIURI* aSheetURI) MOZ_OVERRIDE; virtual void RemoveAdditionalStyleSheet(additionalSheetType aType, nsIURI* sheetURI) MOZ_OVERRIDE; virtual nsIStyleSheet* FirstAdditionalAuthorSheet() MOZ_OVERRIDE; virtual nsIChannel* GetChannel() const MOZ_OVERRIDE { return mChannel; } virtual void SetScriptGlobalObject(nsIScriptGlobalObject* aGlobalObject) MOZ_OVERRIDE; virtual void SetScriptHandlingObject(nsIScriptGlobalObject* aScriptObject) MOZ_OVERRIDE; virtual nsIGlobalObject* GetScopeObject() const MOZ_OVERRIDE; void SetScopeObject(nsIGlobalObject* aGlobal) MOZ_OVERRIDE; /** * Get the script loader for this document */ virtual nsScriptLoader* ScriptLoader() MOZ_OVERRIDE; /** * Add/Remove an element to the document's id and name hashes */ virtual void AddToIdTable(Element* aElement, nsIAtom* aId) MOZ_OVERRIDE; virtual void RemoveFromIdTable(Element* aElement, nsIAtom* aId) MOZ_OVERRIDE; virtual void AddToNameTable(Element* aElement, nsIAtom* aName) MOZ_OVERRIDE; virtual void RemoveFromNameTable(Element* aElement, nsIAtom* aName) MOZ_OVERRIDE; /** * Add a new observer of document change notifications. Whenever * content is changed, appended, inserted or removed the observers are * informed. */ virtual void AddObserver(nsIDocumentObserver* aObserver) MOZ_OVERRIDE; /** * Remove an observer of document change notifications. This will * return false if the observer cannot be found. */ virtual bool RemoveObserver(nsIDocumentObserver* aObserver) MOZ_OVERRIDE; // Observation hooks used to propagate notifications to document // observers. virtual void BeginUpdate(nsUpdateType aUpdateType) MOZ_OVERRIDE; virtual void EndUpdate(nsUpdateType aUpdateType) MOZ_OVERRIDE; virtual void BeginLoad() MOZ_OVERRIDE; virtual void EndLoad() MOZ_OVERRIDE; virtual void SetReadyStateInternal(ReadyState rs) MOZ_OVERRIDE; virtual void ContentStateChanged(nsIContent* aContent, nsEventStates aStateMask) MOZ_OVERRIDE; virtual void DocumentStatesChanged(nsEventStates aStateMask) MOZ_OVERRIDE; virtual void StyleRuleChanged(nsIStyleSheet* aStyleSheet, nsIStyleRule* aOldStyleRule, nsIStyleRule* aNewStyleRule) MOZ_OVERRIDE; virtual void StyleRuleAdded(nsIStyleSheet* aStyleSheet, nsIStyleRule* aStyleRule) MOZ_OVERRIDE; virtual void StyleRuleRemoved(nsIStyleSheet* aStyleSheet, nsIStyleRule* aStyleRule) MOZ_OVERRIDE; virtual void FlushPendingNotifications(mozFlushType aType) MOZ_OVERRIDE; virtual void FlushExternalResources(mozFlushType aType) MOZ_OVERRIDE; virtual void SetXMLDeclaration(const PRUnichar *aVersion, const PRUnichar *aEncoding, const int32_t aStandalone) MOZ_OVERRIDE; virtual void GetXMLDeclaration(nsAString& aVersion, nsAString& aEncoding, nsAString& Standalone) MOZ_OVERRIDE; virtual bool IsScriptEnabled() MOZ_OVERRIDE; virtual void OnPageShow(bool aPersisted, mozilla::dom::EventTarget* aDispatchStartTarget) MOZ_OVERRIDE; virtual void OnPageHide(bool aPersisted, mozilla::dom::EventTarget* aDispatchStartTarget) MOZ_OVERRIDE; virtual void WillDispatchMutationEvent(nsINode* aTarget) MOZ_OVERRIDE; virtual void MutationEventDispatched(nsINode* aTarget) MOZ_OVERRIDE; // nsINode virtual bool IsNodeOfType(uint32_t aFlags) const MOZ_OVERRIDE; virtual nsIContent *GetChildAt(uint32_t aIndex) const MOZ_OVERRIDE; virtual nsIContent * const * GetChildArray(uint32_t* aChildCount) const MOZ_OVERRIDE; virtual int32_t IndexOf(const nsINode* aPossibleChild) const MOZ_OVERRIDE; virtual uint32_t GetChildCount() const MOZ_OVERRIDE; virtual nsresult InsertChildAt(nsIContent* aKid, uint32_t aIndex, bool aNotify) MOZ_OVERRIDE; virtual nsresult AppendChildTo(nsIContent* aKid, bool aNotify); virtual void RemoveChildAt(uint32_t aIndex, bool aNotify) MOZ_OVERRIDE; virtual nsresult Clone(nsINodeInfo *aNodeInfo, nsINode **aResult) const MOZ_OVERRIDE { return NS_ERROR_NOT_IMPLEMENTED; } // nsIRadioGroupContainer NS_IMETHOD WalkRadioGroup(const nsAString& aName, nsIRadioVisitor* aVisitor, bool aFlushContent) MOZ_OVERRIDE; virtual void SetCurrentRadioButton(const nsAString& aName, mozilla::dom::HTMLInputElement* aRadio) MOZ_OVERRIDE; virtual mozilla::dom::HTMLInputElement* GetCurrentRadioButton(const nsAString& aName) MOZ_OVERRIDE; NS_IMETHOD GetNextRadioButton(const nsAString& aName, const bool aPrevious, mozilla::dom::HTMLInputElement* aFocusedRadio, mozilla::dom::HTMLInputElement** aRadioOut) MOZ_OVERRIDE; virtual void AddToRadioGroup(const nsAString& aName, nsIFormControl* aRadio) MOZ_OVERRIDE; virtual void RemoveFromRadioGroup(const nsAString& aName, nsIFormControl* aRadio) MOZ_OVERRIDE; virtual uint32_t GetRequiredRadioCount(const nsAString& aName) const MOZ_OVERRIDE; virtual void RadioRequiredChanged(const nsAString& aName, nsIFormControl* aRadio) MOZ_OVERRIDE; virtual bool GetValueMissingState(const nsAString& aName) const MOZ_OVERRIDE; virtual void SetValueMissingState(const nsAString& aName, bool aValue) MOZ_OVERRIDE; // for radio group nsRadioGroupStruct* GetRadioGroup(const nsAString& aName) const; nsRadioGroupStruct* GetOrCreateRadioGroup(const nsAString& aName); virtual nsViewportInfo GetViewportInfo(uint32_t aDisplayWidth, uint32_t aDisplayHeight) MOZ_OVERRIDE; private: nsRadioGroupStruct* GetRadioGroupInternal(const nsAString& aName) const; void SendToConsole(nsCOMArray& aMessages); public: // nsIDOMNode NS_FORWARD_NSIDOMNODE_TO_NSINODE_OVERRIDABLE // nsIDOMDocument NS_DECL_NSIDOMDOCUMENT // nsIDOMXMLDocument NS_DECL_NSIDOMXMLDOCUMENT // nsIDOMDocumentXBL NS_DECL_NSIDOMDOCUMENTXBL // nsIDOMEventTarget virtual nsresult PreHandleEvent(nsEventChainPreVisitor& aVisitor) MOZ_OVERRIDE; virtual nsEventListenerManager* GetListenerManager(bool aCreateIfNotFound) MOZ_OVERRIDE; // nsIScriptObjectPrincipal virtual nsIPrincipal* GetPrincipal() MOZ_OVERRIDE; // nsIApplicationCacheContainer NS_DECL_NSIAPPLICATIONCACHECONTAINER // nsIObserver NS_DECL_NSIOBSERVER virtual nsresult Init(); virtual nsresult CreateElem(const nsAString& aName, nsIAtom *aPrefix, int32_t aNamespaceID, nsIContent **aResult) MOZ_OVERRIDE; virtual NS_HIDDEN_(void) Sanitize(); virtual NS_HIDDEN_(void) EnumerateSubDocuments(nsSubDocEnumFunc aCallback, void *aData); virtual NS_HIDDEN_(bool) CanSavePresentation(nsIRequest *aNewRequest); virtual NS_HIDDEN_(void) Destroy(); virtual NS_HIDDEN_(void) RemovedFromDocShell(); virtual NS_HIDDEN_(already_AddRefed) GetLayoutHistoryState() const; virtual NS_HIDDEN_(void) BlockOnload(); virtual NS_HIDDEN_(void) UnblockOnload(bool aFireSync); virtual NS_HIDDEN_(void) AddStyleRelevantLink(mozilla::dom::Link* aLink); virtual NS_HIDDEN_(void) ForgetLink(mozilla::dom::Link* aLink); NS_HIDDEN_(void) ClearBoxObjectFor(nsIContent* aContent); already_AddRefed GetBoxObjectFor(mozilla::dom::Element* aElement, mozilla::ErrorResult& aRv) MOZ_OVERRIDE; virtual NS_HIDDEN_(Element*) GetAnonymousElementByAttribute(nsIContent* aElement, nsIAtom* aAttrName, const nsAString& aAttrValue) const; virtual NS_HIDDEN_(Element*) ElementFromPointHelper(float aX, float aY, bool aIgnoreRootScrollFrame, bool aFlushLayout); virtual NS_HIDDEN_(nsresult) NodesFromRectHelper(float aX, float aY, float aTopSize, float aRightSize, float aBottomSize, float aLeftSize, bool aIgnoreRootScrollFrame, bool aFlushLayout, nsIDOMNodeList** aReturn); virtual NS_HIDDEN_(void) FlushSkinBindings(); virtual NS_HIDDEN_(nsresult) InitializeFrameLoader(nsFrameLoader* aLoader); virtual NS_HIDDEN_(nsresult) FinalizeFrameLoader(nsFrameLoader* aLoader); virtual NS_HIDDEN_(void) TryCancelFrameLoaderInitialization(nsIDocShell* aShell); virtual NS_HIDDEN_(bool) FrameLoaderScheduledToBeFinalized(nsIDocShell* aShell); virtual NS_HIDDEN_(nsIDocument*) RequestExternalResource(nsIURI* aURI, nsINode* aRequestingNode, ExternalResourceLoad** aPendingLoad); virtual NS_HIDDEN_(void) EnumerateExternalResources(nsSubDocEnumFunc aCallback, void* aData); nsTArray mHostObjectURIs; // Returns our (lazily-initialized) animation controller. // If HasAnimationController is true, this is guaranteed to return non-null. nsSMILAnimationController* GetAnimationController() MOZ_OVERRIDE; void SetImagesNeedAnimating(bool aAnimating) MOZ_OVERRIDE; virtual void SuppressEventHandling(uint32_t aIncrease) MOZ_OVERRIDE; virtual void UnsuppressEventHandlingAndFireEvents(bool aFireEvents) MOZ_OVERRIDE; void DecreaseEventSuppression() { --mEventsSuppressed; MaybeRescheduleAnimationFrameNotifications(); } virtual nsIDocument* GetTemplateContentsOwner() MOZ_OVERRIDE; NS_DECL_CYCLE_COLLECTION_SKIPPABLE_SCRIPT_HOLDER_CLASS_AMBIGUOUS(nsDocument, nsIDocument) void DoNotifyPossibleTitleChange(); nsExternalResourceMap& ExternalResourceMap() { return mExternalResourceMap; } void SetLoadedAsData(bool aLoadedAsData) { mLoadedAsData = aLoadedAsData; } void SetLoadedAsInteractiveData(bool aLoadedAsInteractiveData) { mLoadedAsInteractiveData = aLoadedAsInteractiveData; } nsresult CloneDocHelper(nsDocument* clone) const; void MaybeInitializeFinalizeFrameLoaders(); void MaybeEndOutermostXBLUpdate(); virtual void MaybePreLoadImage(nsIURI* uri, const nsAString &aCrossOriginAttr) MOZ_OVERRIDE; virtual void PreloadStyle(nsIURI* uri, const nsAString& charset, const nsAString& aCrossOriginAttr) MOZ_OVERRIDE; virtual nsresult LoadChromeSheetSync(nsIURI* uri, bool isAgentSheet, nsCSSStyleSheet** sheet) MOZ_OVERRIDE; virtual nsISupports* GetCurrentContentSink() MOZ_OVERRIDE; virtual nsEventStates GetDocumentState() MOZ_OVERRIDE; virtual void RegisterHostObjectUri(const nsACString& aUri) MOZ_OVERRIDE; virtual void UnregisterHostObjectUri(const nsACString& aUri) MOZ_OVERRIDE; // Only BlockOnload should call this! void AsyncBlockOnload(); virtual void SetScrollToRef(nsIURI *aDocumentURI) MOZ_OVERRIDE; virtual void ScrollToRef() MOZ_OVERRIDE; virtual void ResetScrolledToRefAlready() MOZ_OVERRIDE; virtual void SetChangeScrollPosWhenScrollingToRef(bool aValue) MOZ_OVERRIDE; virtual Element *GetElementById(const nsAString& aElementId) MOZ_OVERRIDE; virtual const nsSmallVoidArray* GetAllElementsForId(const nsAString& aElementId) const MOZ_OVERRIDE; virtual Element *LookupImageElement(const nsAString& aElementId) MOZ_OVERRIDE; virtual void MozSetImageElement(const nsAString& aImageElementId, Element* aElement) MOZ_OVERRIDE; virtual NS_HIDDEN_(nsresult) AddImage(imgIRequest* aImage); virtual NS_HIDDEN_(nsresult) RemoveImage(imgIRequest* aImage, uint32_t aFlags); virtual NS_HIDDEN_(nsresult) SetImageLockingState(bool aLocked); // AddPlugin adds a plugin-related element to mPlugins when the element is // added to the tree. virtual nsresult AddPlugin(nsIObjectLoadingContent* aPlugin) MOZ_OVERRIDE; // RemovePlugin removes a plugin-related element to mPlugins when the // element is removed from the tree. virtual void RemovePlugin(nsIObjectLoadingContent* aPlugin) MOZ_OVERRIDE; // GetPlugins returns the plugin-related elements from // the frame and any subframes. virtual void GetPlugins(nsTArray& aPlugins) MOZ_OVERRIDE; virtual nsresult GetStateObject(nsIVariant** aResult) MOZ_OVERRIDE; virtual nsDOMNavigationTiming* GetNavigationTiming() const MOZ_OVERRIDE; virtual nsresult SetNavigationTiming(nsDOMNavigationTiming* aTiming) MOZ_OVERRIDE; virtual Element* FindImageMap(const nsAString& aNormalizedMapName) MOZ_OVERRIDE; virtual void NotifyAudioAvailableListener() MOZ_OVERRIDE; bool HasAudioAvailableListeners() MOZ_OVERRIDE { return mHasAudioAvailableListener; } virtual Element* GetFullScreenElement() MOZ_OVERRIDE; virtual void AsyncRequestFullScreen(Element* aElement) MOZ_OVERRIDE; virtual void RestorePreviousFullScreenState() MOZ_OVERRIDE; virtual bool IsFullscreenLeaf() MOZ_OVERRIDE; virtual bool IsFullScreenDoc() MOZ_OVERRIDE; virtual void SetApprovedForFullscreen(bool aIsApproved) MOZ_OVERRIDE; virtual nsresult RemoteFrameFullscreenChanged(nsIDOMElement* aFrameElement, const nsAString& aNewOrigin) MOZ_OVERRIDE; virtual nsresult RemoteFrameFullscreenReverted() MOZ_OVERRIDE; virtual nsIDocument* GetFullscreenRoot() MOZ_OVERRIDE; virtual void SetFullscreenRoot(nsIDocument* aRoot) MOZ_OVERRIDE; static void ExitFullscreen(nsIDocument* aDoc); // This is called asynchronously by nsIDocument::AsyncRequestFullScreen() // to move this document into full-screen mode if allowed. aWasCallerChrome // should be true when nsIDocument::AsyncRequestFullScreen() was called // by chrome code. aNotifyOnOriginChange denotes whether we should send a // fullscreen-origin-change notification if requesting fullscreen in this // document causes the origin which is fullscreen to change. We may want to // *not* send this notification if we're calling RequestFullscreen() as part // of a continuation of a request in a subdocument, whereupon the caller will // need to send the notification with the origin of the document which // originally requested fullscreen, not *this* document's origin. void RequestFullScreen(Element* aElement, bool aWasCallerChrome, bool aNotifyOnOriginChange); // Removes all elements from the full-screen stack, removing full-scren // styles from the top element in the stack. void CleanupFullscreenState(); // Add/remove "fullscreen-approved" observer service notification listener. // Chrome sends us a notification when fullscreen is approved for a // document, with the notification subject as the document that was approved. // We maintain this listener while in fullscreen mode. nsresult AddFullscreenApprovedObserver(); nsresult RemoveFullscreenApprovedObserver(); // Pushes aElement onto the full-screen stack, and removes full-screen styles // from the former full-screen stack top, and its ancestors, and applies the // styles to aElement. aElement becomes the new "full-screen element". bool FullScreenStackPush(Element* aElement); // Remove the top element from the full-screen stack. Removes the full-screen // styles from the former top element, and applies them to the new top // element, if there is one. void FullScreenStackPop(); // Returns the top element from the full-screen stack. Element* FullScreenStackTop(); // DOM-exposed fullscreen API virtual bool MozFullScreenEnabled() MOZ_OVERRIDE; virtual Element* GetMozFullScreenElement(mozilla::ErrorResult& rv) MOZ_OVERRIDE; void RequestPointerLock(Element* aElement) MOZ_OVERRIDE; bool ShouldLockPointer(Element* aElement, Element* aCurrentLock, bool aNoFocusCheck = false); bool SetPointerLock(Element* aElement, int aCursorStyle); static void UnlockPointer(nsIDocument* aDoc = nullptr); // This method may fire a DOM event; if it does so it will happen // synchronously. void UpdateVisibilityState(); // Posts an event to call UpdateVisibilityState virtual void PostVisibilityUpdateEvent() MOZ_OVERRIDE; virtual void DocSizeOfExcludingThis(nsWindowSizes* aWindowSizes) const MOZ_OVERRIDE; // DocSizeOfIncludingThis is inherited from nsIDocument. virtual nsIDOMNode* AsDOMNode() MOZ_OVERRIDE { return this; } void GetCustomPrototype(const nsAString& aElementName, JS::MutableHandle prototype) { mCustomPrototypes.Get(aElementName, prototype.address()); } static bool RegisterEnabled(); // WebIDL bits virtual mozilla::dom::DOMImplementation* GetImplementation(mozilla::ErrorResult& rv) MOZ_OVERRIDE; virtual JSObject* Register(JSContext* aCx, const nsAString& aName, const mozilla::dom::ElementRegistrationOptions& aOptions, mozilla::ErrorResult& rv) MOZ_OVERRIDE; virtual nsIDOMStyleSheetList* StyleSheets() MOZ_OVERRIDE; virtual void SetSelectedStyleSheetSet(const nsAString& aSheetSet) MOZ_OVERRIDE; virtual void GetLastStyleSheetSet(nsString& aSheetSet) MOZ_OVERRIDE; virtual nsIDOMDOMStringList* StyleSheetSets() MOZ_OVERRIDE; virtual void EnableStyleSheetsForSet(const nsAString& aSheetSet) MOZ_OVERRIDE; protected: friend class nsNodeUtils; friend class nsDocumentOnStack; void IncreaseStackRefCnt() { ++mStackRefCnt; } void DecreaseStackRefCnt() { if (--mStackRefCnt == 0 && mNeedsReleaseAfterStackRefCntRelease) { mNeedsReleaseAfterStackRefCntRelease = false; NS_RELEASE_THIS(); } } // Returns true if a request for DOM full-screen is currently enabled in // this document. This returns true if there are no windowed plugins in this // doc tree, and if the document is visible, and if the api is not // disabled by pref. aIsCallerChrome must contain the return value of // nsContentUtils::IsCallerChrome() from the context we're checking. // If aLogFailure is true, an appropriate warning message is logged to the // console, and a "mozfullscreenerror" event is dispatched to this document. bool IsFullScreenEnabled(bool aIsCallerChrome, bool aLogFailure); /** * Check that aId is not empty and log a message to the console * service if it is. * @returns true if aId looks correct, false otherwise. */ inline bool CheckGetElementByIdArg(const nsAString& aId) { if (aId.IsEmpty()) { ReportEmptyGetElementByIdArg(); return false; } return true; } void ReportEmptyGetElementByIdArg(); void DispatchContentLoadedEvents(); void RetrieveRelevantHeaders(nsIChannel *aChannel); void TryChannelCharset(nsIChannel *aChannel, int32_t& aCharsetSource, nsACString& aCharset, nsHtml5TreeOpExecutor* aExecutor); // Call this before the document does something that will unbind all content. // That will stop us from doing a lot of work as each element is removed. void DestroyElementMaps(); // Refreshes the hrefs of all the links in the document. void RefreshLinkHrefs(); nsIContent* GetFirstBaseNodeWithHref(); nsresult SetFirstBaseNodeWithHref(nsIContent *node); // Get the first element with the given IsNodeOfType type, or // return null if there isn't one nsIContent* GetTitleContent(uint32_t aNodeType); // Find the first "title" element in the given IsNodeOfType type and // append the concatenation of its text node children to aTitle. Do // nothing if there is no such element. void GetTitleFromElement(uint32_t aNodeType, nsAString& aTitle); public: // Get our title virtual void GetTitle(nsString& aTitle) MOZ_OVERRIDE; // Set our title virtual void SetTitle(const nsAString& aTitle, mozilla::ErrorResult& rv) MOZ_OVERRIDE; static void XPCOMShutdown(); bool mIsTopLevelContentDocument:1; bool IsTopLevelContentDocument(); void SetIsTopLevelContentDocument(bool aIsTopLevelContentDocument); js::ExpandoAndGeneration mExpandoAndGeneration; protected: already_AddRefed<nsIPresShell> doCreateShell(nsPresContext* aContext, nsViewManager* aViewManager, nsStyleSet* aStyleSet, nsCompatibility aCompatMode); void RemoveDocStyleSheetsFromStyleSets(); void RemoveStyleSheetsFromStyleSets(nsCOMArray<nsIStyleSheet>& aSheets, nsStyleSet::sheetType aType); void ResetStylesheetsToURI(nsIURI* aURI); void FillStyleSet(nsStyleSet* aStyleSet); // Return whether all the presshells for this document are safe to flush bool IsSafeToFlush() const; void DispatchPageTransition(mozilla::dom::EventTarget* aDispatchTarget, const nsAString& aType, bool aPersisted); virtual nsPIDOMWindow *GetWindowInternal() const MOZ_OVERRIDE; virtual nsIScriptGlobalObject* GetScriptHandlingObjectInternal() const MOZ_OVERRIDE; virtual bool InternalAllowXULXBL() MOZ_OVERRIDE; #define NS_DOCUMENT_NOTIFY_OBSERVERS(func_, params_) \ NS_OBSERVER_ARRAY_NOTIFY_XPCOM_OBSERVERS(mObservers, nsIDocumentObserver, \ func_, params_); #ifdef DEBUG void VerifyRootContentState(); #endif nsDocument(const char* aContentType); virtual ~nsDocument(); void EnsureOnloadBlocker(); nsTArray<nsIObserver*> mCharSetObservers; PLDHashTable *mSubDocuments; // Array of owning references to all children nsAttrAndChildArray mChildren; // Pointer to our parser if we're currently in the process of being // parsed into. nsCOMPtr<nsIParser> mParser; // Weak reference to our sink for in case we no longer have a parser. This // will allow us to flush out any pending stuff from the sink even if // EndLoad() has already happened. nsWeakPtr mWeakSink; nsCOMArray<nsIStyleSheet> mStyleSheets; nsCOMArray<nsIStyleSheet> mCatalogSheets; nsCOMArray<nsIStyleSheet> mAdditionalSheets[SheetTypeCount]; // Array of observers nsTObserverArray<nsIDocumentObserver*> mObservers; // Weak reference to the scope object (aka the script global object) // that, unlike mScriptGlobalObject, is never unset once set. This // is a weak reference to avoid leaks due to circular references. nsWeakPtr mScopeObject; // Stack of full-screen elements. When we request full-screen we push the // full-screen element onto this stack, and when we cancel full-screen we // pop one off this stack, restoring the previous full-screen state nsTArray<nsWeakPtr> mFullScreenStack; // The root of the doc tree in which this document is in. This is only // non-null when this document is in fullscreen mode. nsWeakPtr mFullscreenRoot; // Hashtable for custom element prototypes in web components. // Custom prototypes are in the document's compartment. nsJSThingHashtable<nsStringHashKey, JSObject*> mCustomPrototypes; nsRefPtr<nsEventListenerManager> mListenerManager; nsCOMPtr<nsIDOMStyleSheetList> mDOMStyleSheets; nsRefPtr<nsDOMStyleSheetSetList> mStyleSheetSetList; nsRefPtr<nsScriptLoader> mScriptLoader; nsDocHeaderData* mHeaderData; /* mIdentifierMap works as follows for IDs: * 1) Attribute changes affect the table immediately (removing and adding * entries as needed). * 2) Removals from the DOM affect the table immediately * 3) Additions to the DOM always update existing entries for names, and add * new ones for IDs. */ nsTHashtable<nsIdentifierMapEntry> mIdentifierMap; nsClassHashtable<nsStringHashKey, nsRadioGroupStruct> mRadioGroups; // Recorded time of change to 'loading' state. mozilla::TimeStamp mLoadingTimeStamp; // True if the document has been detached from its content viewer. bool mIsGoingAway:1; // True if the document is being destroyed. bool mInDestructor:1; // True if this document has ever had an HTML or SVG <title> element // bound to it bool mMayHaveTitleElement:1; bool mHasWarnedAboutBoxObjects:1; bool mDelayFrameLoaderInitialization:1; bool mSynchronousDOMContentLoaded:1; bool mInXBLUpdate:1; // Whether we're currently holding a lock on all of our images. bool mLockingImages:1; // Whether we currently require our images to animate bool mAnimatingImages:1; // Whether some node in this document has a listener for the // "mozaudioavailable" event. bool mHasAudioAvailableListener:1; // Whether we're currently under a FlushPendingNotifications call to // our presshell. This is used to handle flush reentry correctly. bool mInFlush:1; // Parser aborted. True if the parser of this document was forcibly // terminated instead of letting it finish at its own pace. bool mParserAborted:1; // Whether this document has been approved for fullscreen, either by explicit // approval via the fullscreen-approval UI, or because it received // approval because its document's host already had the "fullscreen" // permission granted when the document requested fullscreen. // // Note if a document's principal doesn't have a host, the permission manager // can't store permissions for it, so we can only manage approval using this // flag. // // Note we must track this separately from the "fullscreen" permission, // so that pending pointer lock requests can determine whether documents // whose principal doesn't have a host (i.e. those which can't store // permissions in the permission manager) have been approved for fullscreen. bool mIsApprovedForFullscreen:1; // Whether this document has a fullscreen approved observer. Only documents // which request fullscreen and which don't have a pre-existing approval for // fullscreen will have an observer. bool mHasFullscreenApprovedObserver:1; friend class nsPointerLockPermissionRequest; friend class nsCallRequestFullScreen; // When set, trying to lock the pointer doesn't require permission from the // user. bool mAllowRelocking:1; bool mAsyncFullscreenPending:1; uint32_t mCancelledPointerLockRequests; uint8_t mXMLDeclarationBits; nsInterfaceHashtable<nsPtrHashKey<nsIContent>, nsPIBoxObject> *mBoxObjectTable; // A document "without a browsing context" that owns the content of // HTMLTemplateElement. nsCOMPtr<nsIDocument> mTemplateContentsOwner; // Our update nesting level uint32_t mUpdateNestLevel; // The application cache that this document is associated with, if // any. This can change during the lifetime of the document. nsCOMPtr<nsIApplicationCache> mApplicationCache; nsCOMPtr<nsIContent> mFirstBaseNodeWithHref; nsEventStates mDocumentState; nsEventStates mGotDocumentState; nsRefPtr<nsDOMNavigationTiming> mTiming; private: friend class nsUnblockOnloadEvent; // Recomputes the visibility state but doesn't set the new value. mozilla::dom::VisibilityState GetVisibilityState() const; void NotifyStyleSheetAdded(nsIStyleSheet* aSheet, bool aDocumentSheet); void NotifyStyleSheetRemoved(nsIStyleSheet* aSheet, bool aDocumentSheet); void PostUnblockOnloadEvent(); void DoUnblockOnload(); nsresult CheckFrameOptions(); nsresult InitCSP(nsIChannel* aChannel); void FlushCSPWebConsoleErrorQueue() { mCSPWebConsoleErrorQueue.Flush(this); } /** * Find the (non-anonymous) content in this document for aFrame. It will * be aFrame's content node if that content is in this document and not * anonymous. Otherwise, when aFrame is in a subdocument, we use the frame * element containing the subdocument containing aFrame, and/or find the * nearest non-anonymous ancestor in this document. * Returns null if there is no such element. */ nsIContent* GetContentInThisDocument(nsIFrame* aFrame) const; // Just like EnableStyleSheetsForSet, but doesn't check whether // aSheetSet is null and allows the caller to control whether to set // aSheetSet as the preferred set in the CSSLoader. void EnableStyleSheetsForSetInternal(const nsAString& aSheetSet, bool aUpdateCSSLoader); // Revoke any pending notifications due to mozRequestAnimationFrame calls void RevokeAnimationFrameNotifications(); // Reschedule any notifications we need to handle // mozRequestAnimationFrame, if it's OK to do so. void MaybeRescheduleAnimationFrameNotifications(); // These are not implemented and not supported. nsDocument(const nsDocument& aOther); nsDocument& operator=(const nsDocument& aOther); nsCOMPtr<nsISupports> mXPathEvaluatorTearoff; // The layout history state that should be used by nodes in this // document. We only actually store a pointer to it when: // 1) We have no script global object. // 2) We haven't had Destroy() called on us yet. nsCOMPtr<nsILayoutHistoryState> mLayoutHistoryState; // Currently active onload blockers uint32_t mOnloadBlockCount; // Onload blockers which haven't been activated yet uint32_t mAsyncOnloadBlockCount; nsCOMPtr<nsIRequest> mOnloadBlocker; // A hashtable of styled links keyed by address pointer. nsTHashtable<nsPtrHashKey<mozilla::dom::Link> > mStyledLinks; #ifdef DEBUG // Indicates whether mStyledLinks was cleared or not. This is used to track // state so we can provide useful assertions to consumers of ForgetLink and // AddStyleRelevantLink. bool mStyledLinksCleared; #endif // Member to store out last-selected stylesheet set. nsString mLastStyleSheetSet; nsTArray<nsRefPtr<nsFrameLoader> > mInitializableFrameLoaders; nsTArray<nsRefPtr<nsFrameLoader> > mFinalizableFrameLoaders; nsRefPtr<nsRunnableMethod<nsDocument> > mFrameLoaderRunner; nsRevocableEventPtr<nsRunnableMethod<nsDocument, void, false> > mPendingTitleChangeEvent; nsExternalResourceMap mExternalResourceMap; // All images in process of being preloaded nsCOMArray<imgIRequest> mPreloadingImages; nsRefPtr<mozilla::dom::DOMImplementation> mDOMImplementation; nsRefPtr<nsContentList> mImageMaps; nsCString mScrollToRef; uint8_t mScrolledToRefAlready : 1; uint8_t mChangeScrollPosWhenScrollingToRef : 1; // Tracking for images in the document. nsDataHashtable< nsPtrHashKey<imgIRequest>, uint32_t> mImageTracker; // Tracking for plugins in the document. nsTHashtable< nsPtrHashKey<nsIObjectLoadingContent> > mPlugins; nsRefPtr<mozilla::dom::UndoManager> mUndoManager; enum ViewportType { DisplayWidthHeight, Specified, Unknown }; ViewportType mViewportType; // These member variables cache information about the viewport so we don't have to // recalculate it each time. bool mValidWidth, mValidHeight; float mScaleMinFloat, mScaleMaxFloat, mScaleFloat, mPixelRatio; bool mAutoSize, mAllowZoom, mValidScaleFloat, mValidMaxScale, mScaleStrEmpty, mWidthStrEmpty; uint32_t mViewportWidth, mViewportHeight; nsrefcnt mStackRefCnt; bool mNeedsReleaseAfterStackRefCntRelease; CSPErrorQueue mCSPWebConsoleErrorQueue; #ifdef DEBUG protected: bool mWillReparent; #endif }; class nsDocumentOnStack { public: nsDocumentOnStack(nsDocument* aDoc) : mDoc(aDoc) { mDoc->IncreaseStackRefCnt(); } ~nsDocumentOnStack() { mDoc->DecreaseStackRefCnt(); } private: nsDocument* mDoc; }; #endif /* nsDocument_h___ */