forked from mirrors/gecko-dev
		
	
		
			
				
	
	
		
			151 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
 | |
| /* vim: set ts=8 sts=2 et sw=2 tw=80: */
 | |
| /* 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/. */
 | |
| 
 | |
| #ifndef DOM_BASE_MUTATIONOBSERVERS_H_
 | |
| #define DOM_BASE_MUTATIONOBSERVERS_H_
 | |
| 
 | |
| #include "nsIContent.h"  // for use in inline function (ParentChainChanged)
 | |
| #include "nsIMutationObserver.h"  // for use in inline function (ParentChainChanged)
 | |
| #include "mozilla/dom/Document.h"
 | |
| #include "js/TypeDecls.h"
 | |
| #include "nsContentUtils.h"
 | |
| 
 | |
| struct CharacterDataChangeInfo;
 | |
| namespace mozilla {
 | |
| namespace dom {
 | |
| class Animation;
 | |
| 
 | |
| class MutationObservers {
 | |
|  public:
 | |
|   /**
 | |
|    * Send CharacterDataWillChange notifications to nsIMutationObservers.
 | |
|    * @param aContent  Node whose data changed
 | |
|    * @param aInfo     Struct with information details about the change
 | |
|    * @see nsIMutationObserver::CharacterDataWillChange
 | |
|    */
 | |
|   static void NotifyCharacterDataWillChange(nsIContent* aContent,
 | |
|                                             const CharacterDataChangeInfo&);
 | |
| 
 | |
|   /**
 | |
|    * Send CharacterDataChanged notifications to nsIMutationObservers.
 | |
|    * @param aContent  Node whose data changed
 | |
|    * @param aInfo     Struct with information details about the change
 | |
|    * @see nsIMutationObserver::CharacterDataChanged
 | |
|    */
 | |
|   static void NotifyCharacterDataChanged(nsIContent* aContent,
 | |
|                                          const CharacterDataChangeInfo&);
 | |
| 
 | |
|   /**
 | |
|    * Send AttributeWillChange notifications to nsIMutationObservers.
 | |
|    * @param aElement      Element whose data will change
 | |
|    * @param aNameSpaceID  Namespace of changing attribute
 | |
|    * @param aAttribute    Local-name of changing attribute
 | |
|    * @param aModType      Type of change (add/change/removal)
 | |
|    * @param aNewValue     The parsed new value, but only if BeforeSetAttr
 | |
|    *                      preparsed it!!!
 | |
|    * @see nsIMutationObserver::AttributeWillChange
 | |
|    */
 | |
|   static void NotifyAttributeWillChange(mozilla::dom::Element* aElement,
 | |
|                                         int32_t aNameSpaceID,
 | |
|                                         nsAtom* aAttribute, int32_t aModType);
 | |
| 
 | |
|   /**
 | |
|    * Send AttributeChanged notifications to nsIMutationObservers.
 | |
|    * @param aElement      Element whose data changed
 | |
|    * @param aNameSpaceID  Namespace of changed attribute
 | |
|    * @param aAttribute    Local-name of changed attribute
 | |
|    * @param aModType      Type of change (add/change/removal)
 | |
|    * @param aOldValue     If the old value was StoresOwnData() (or absent),
 | |
|    *                      that value, otherwise null
 | |
|    * @see nsIMutationObserver::AttributeChanged
 | |
|    */
 | |
|   static void NotifyAttributeChanged(mozilla::dom::Element* aElement,
 | |
|                                      int32_t aNameSpaceID, nsAtom* aAttribute,
 | |
|                                      int32_t aModType,
 | |
|                                      const nsAttrValue* aOldValue);
 | |
| 
 | |
|   /**
 | |
|    * Send AttributeSetToCurrentValue notifications to nsIMutationObservers.
 | |
|    * @param aElement      Element whose data changed
 | |
|    * @param aNameSpaceID  Namespace of the attribute
 | |
|    * @param aAttribute    Local-name of the attribute
 | |
|    * @see nsIMutationObserver::AttributeSetToCurrentValue
 | |
|    */
 | |
|   static void NotifyAttributeSetToCurrentValue(mozilla::dom::Element* aElement,
 | |
|                                                int32_t aNameSpaceID,
 | |
|                                                nsAtom* aAttribute);
 | |
| 
 | |
|   /**
 | |
|    * Send ContentAppended notifications to nsIMutationObservers
 | |
|    * @param aContainer           Node into which new child/children were added
 | |
|    * @param aFirstNewContent     First new child
 | |
|    * @see nsIMutationObserver::ContentAppended
 | |
|    */
 | |
|   static void NotifyContentAppended(nsIContent* aContainer,
 | |
|                                     nsIContent* aFirstNewContent);
 | |
| 
 | |
|   /**
 | |
|    * Send NativeAnonymousChildList notifications to nsIMutationObservers
 | |
|    * @param aContent             Anonymous node that's been added or removed
 | |
|    * @param aIsRemove            True if it's a removal, false if an addition
 | |
|    * @see nsIMutationObserver::NativeAnonymousChildListChange
 | |
|    */
 | |
|   static void NotifyNativeAnonymousChildListChange(nsIContent* aContent,
 | |
|                                                    bool aIsRemove);
 | |
| 
 | |
|   /**
 | |
|    * Send ContentInserted notifications to nsIMutationObservers
 | |
|    * @param aContainer        Node into which new child was inserted
 | |
|    * @param aChild            Newly inserted child
 | |
|    * @see nsIMutationObserver::ContentInserted
 | |
|    */
 | |
|   static void NotifyContentInserted(nsINode* aContainer, nsIContent* aChild);
 | |
|   /**
 | |
|    * Send ContentRemoved notifications to nsIMutationObservers
 | |
|    * @param aContainer        Node from which child was removed
 | |
|    * @param aChild            Removed child
 | |
|    * @param aPreviousSibling  Previous sibling of the removed child
 | |
|    * @see nsIMutationObserver::ContentRemoved
 | |
|    */
 | |
|   static void NotifyContentRemoved(nsINode* aContainer, nsIContent* aChild,
 | |
|                                    nsIContent* aPreviousSibling);
 | |
| 
 | |
|   /**
 | |
|    * Send ParentChainChanged notifications to nsIMutationObservers
 | |
|    * @param aContent  The piece of content that had its parent changed.
 | |
|    * @see nsIMutationObserver::ParentChainChanged
 | |
|    */
 | |
|   static inline void NotifyParentChainChanged(nsIContent* aContent) {
 | |
|     nsINode::nsSlots* slots = aContent->GetExistingSlots();
 | |
|     if (slots && !slots->mMutationObservers.IsEmpty()) {
 | |
|       NS_OBSERVER_ARRAY_NOTIFY_OBSERVERS(slots->mMutationObservers,
 | |
|                                          ParentChainChanged, (aContent));
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Notify that an animation is added/changed/removed.
 | |
|    * @param aAnimation The animation we added/changed/removed.
 | |
|    */
 | |
|   static void NotifyAnimationAdded(mozilla::dom::Animation* aAnimation);
 | |
|   static void NotifyAnimationChanged(mozilla::dom::Animation* aAnimation);
 | |
|   static void NotifyAnimationRemoved(mozilla::dom::Animation* aAnimation);
 | |
| 
 | |
|  private:
 | |
|   enum class AnimationMutationType { Added, Changed, Removed };
 | |
|   /**
 | |
|    * Notify the observers of the target of an animation
 | |
|    * @param aAnimation The mutated animation.
 | |
|    * @param aMutationType The mutation type of this animation. It could be
 | |
|    *                      Added, Changed, or Removed.
 | |
|    */
 | |
|   static void NotifyAnimationMutated(mozilla::dom::Animation* aAnimation,
 | |
|                                      AnimationMutationType aMutatedType);
 | |
| };
 | |
| }  // namespace dom
 | |
| }  // namespace mozilla
 | |
| 
 | |
| #endif  // DOM_BASE_MUTATIONOBSERVERS_H_
 | 
