forked from mirrors/gecko-dev
		
	 6917a38081
			
		
	
	
		6917a38081
		
	
	
	
	
		
			
			BindContext was going to have way more information at first, but then I realized
that most of the things I wanted to know were basically a flag away using the
parent node.
Still I think it's worth it, now experimenting with BindToTree will only mean
adding a field to a struct that's included from a couple cpp files, instead of a
massive pain.
I also think this is clearer, and doing this highlights quite a few
inconsistencies in our code which I've left untouched, but commented with
FIXMEs.
Steps are:
$ for file in $(rg 'nsresult BindToTree\(' | cut -d : -f 1 | sort | uniq); do sed -i 's#nsresult BindToTree(Document\* aDocument, nsIContent\* aParent,#nsresult BindToTree(BindContext\&, nsINode\& aParent)#g' $file; done
$ for file in $(rg 'nsresult BindToTree\(' | cut -d : -f 1 | sort | uniq); do sed -i 's#                      nsIContent\* aBindingParent) override#override#g' $file; done
$ for file in $(rg '::BindToTree\(' | cut -d : -f 1 | sort | uniq); do sed -i 's#::BindToTree(Document\* aDocument, nsIContent\* aParent,#::BindToTree(BindContext\& aContext, nsINode\& aParent)#g' $file; done
$ for file in $(rg '::BindToTree\(' | cut -d : -f 1 | sort | uniq); do sed -i 's#nsIContent\* aBindingParent)##g' $file; done
$ for file in $(rg '::BindToTree\(' | cut -d : -f 1 | sort | uniq); do sed -i 's#::BindToTree(aDocument, aParent, aBindingParent)#::BindToTree(aContext, aParent)#g' $file; done
$ ./mach clang-format
Then manual fixups.
Depends on D32948
Differential Revision: https://phabricator.services.mozilla.com/D32949
		
	
			
		
			
				
	
	
		
			127 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
	
		
			4.8 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 HTMLBodyElement_h___
 | |
| #define HTMLBodyElement_h___
 | |
| 
 | |
| #include "mozilla/Attributes.h"
 | |
| #include "nsGenericHTMLElement.h"
 | |
| 
 | |
| namespace mozilla {
 | |
| 
 | |
| class TextEditor;
 | |
| 
 | |
| namespace dom {
 | |
| 
 | |
| class OnBeforeUnloadEventHandlerNonNull;
 | |
| 
 | |
| class HTMLBodyElement final : public nsGenericHTMLElement {
 | |
|  public:
 | |
|   using Element::GetText;
 | |
| 
 | |
|   explicit HTMLBodyElement(already_AddRefed<mozilla::dom::NodeInfo>&& aNodeInfo)
 | |
|       : nsGenericHTMLElement(std::move(aNodeInfo)) {}
 | |
| 
 | |
|   // nsISupports
 | |
|   NS_INLINE_DECL_REFCOUNTING_INHERITED(HTMLBodyElement, nsGenericHTMLElement)
 | |
| 
 | |
|   NS_IMPL_FROMNODE_HTML_WITH_TAG(HTMLBodyElement, body);
 | |
| 
 | |
|   // Event listener stuff; we need to declare only the ones we need to
 | |
|   // forward to window that don't come from nsIDOMHTMLBodyElement.
 | |
| #define EVENT(name_, id_, type_, struct_) /* nothing; handled by the shim */
 | |
| #define WINDOW_EVENT_HELPER(name_, type_) \
 | |
|   type_* GetOn##name_();                  \
 | |
|   void SetOn##name_(type_* handler);
 | |
| #define WINDOW_EVENT(name_, id_, type_, struct_) \
 | |
|   WINDOW_EVENT_HELPER(name_, EventHandlerNonNull)
 | |
| #define BEFOREUNLOAD_EVENT(name_, id_, type_, struct_) \
 | |
|   WINDOW_EVENT_HELPER(name_, OnBeforeUnloadEventHandlerNonNull)
 | |
| #include "mozilla/EventNameList.h"  // IWYU pragma: keep
 | |
| #undef BEFOREUNLOAD_EVENT
 | |
| #undef WINDOW_EVENT
 | |
| #undef WINDOW_EVENT_HELPER
 | |
| #undef EVENT
 | |
| 
 | |
|   void GetText(nsAString& aText) { GetHTMLAttr(nsGkAtoms::text, aText); }
 | |
|   void SetText(const nsAString& aText) { SetHTMLAttr(nsGkAtoms::text, aText); }
 | |
|   void SetText(const nsAString& aText, ErrorResult& aError) {
 | |
|     SetHTMLAttr(nsGkAtoms::text, aText, aError);
 | |
|   }
 | |
|   void GetLink(nsAString& aLink) { GetHTMLAttr(nsGkAtoms::link, aLink); }
 | |
|   void SetLink(const nsAString& aLink) { SetHTMLAttr(nsGkAtoms::link, aLink); }
 | |
|   void SetLink(const nsAString& aLink, ErrorResult& aError) {
 | |
|     SetHTMLAttr(nsGkAtoms::link, aLink, aError);
 | |
|   }
 | |
|   void GetVLink(nsAString& aVLink) { GetHTMLAttr(nsGkAtoms::vlink, aVLink); }
 | |
|   void SetVLink(const nsAString& aVLink) {
 | |
|     SetHTMLAttr(nsGkAtoms::vlink, aVLink);
 | |
|   }
 | |
|   void SetVLink(const nsAString& aVLink, ErrorResult& aError) {
 | |
|     SetHTMLAttr(nsGkAtoms::vlink, aVLink, aError);
 | |
|   }
 | |
|   void GetALink(nsAString& aALink) { GetHTMLAttr(nsGkAtoms::alink, aALink); }
 | |
|   void SetALink(const nsAString& aALink) {
 | |
|     SetHTMLAttr(nsGkAtoms::alink, aALink);
 | |
|   }
 | |
|   void SetALink(const nsAString& aALink, ErrorResult& aError) {
 | |
|     SetHTMLAttr(nsGkAtoms::alink, aALink, aError);
 | |
|   }
 | |
|   void GetBgColor(nsAString& aBgColor) {
 | |
|     GetHTMLAttr(nsGkAtoms::bgcolor, aBgColor);
 | |
|   }
 | |
|   void SetBgColor(const nsAString& aBgColor) {
 | |
|     SetHTMLAttr(nsGkAtoms::bgcolor, aBgColor);
 | |
|   }
 | |
|   void SetBgColor(const nsAString& aBgColor, ErrorResult& aError) {
 | |
|     SetHTMLAttr(nsGkAtoms::bgcolor, aBgColor, aError);
 | |
|   }
 | |
|   void GetBackground(DOMString& aBackground) {
 | |
|     GetHTMLAttr(nsGkAtoms::background, aBackground);
 | |
|   }
 | |
|   void GetBackground(nsAString& aBackground) {
 | |
|     GetHTMLAttr(nsGkAtoms::background, aBackground);
 | |
|   }
 | |
|   void SetBackground(const nsAString& aBackground, ErrorResult& aError) {
 | |
|     SetHTMLAttr(nsGkAtoms::background, aBackground, aError);
 | |
|   }
 | |
| 
 | |
|   virtual bool ParseAttribute(int32_t aNamespaceID, nsAtom* aAttribute,
 | |
|                               const nsAString& aValue,
 | |
|                               nsIPrincipal* aMaybeScriptedPrincipal,
 | |
|                               nsAttrValue& aResult) override;
 | |
|   virtual nsMapRuleToAttributesFunc GetAttributeMappingFunction()
 | |
|       const override;
 | |
|   NS_IMETHOD_(bool) IsAttributeMapped(const nsAtom* aAttribute) const override;
 | |
|   virtual already_AddRefed<TextEditor> GetAssociatedEditor() override;
 | |
|   virtual nsresult Clone(dom::NodeInfo*, nsINode** aResult) const override;
 | |
| 
 | |
|   virtual bool IsEventAttributeNameInternal(nsAtom* aName) override;
 | |
| 
 | |
|   virtual nsresult BindToTree(BindContext&, nsINode& aParent) override;
 | |
|   /**
 | |
|    * Called when an attribute has just been changed
 | |
|    */
 | |
|   virtual nsresult AfterSetAttr(int32_t aNameSpaceID, nsAtom* aName,
 | |
|                                 const nsAttrValue* aValue,
 | |
|                                 const nsAttrValue* aOldValue,
 | |
|                                 nsIPrincipal* aSubjectPrincipal,
 | |
|                                 bool aNotify) override;
 | |
| 
 | |
|  protected:
 | |
|   virtual ~HTMLBodyElement();
 | |
| 
 | |
|   virtual JSObject* WrapNode(JSContext* aCx,
 | |
|                              JS::Handle<JSObject*> aGivenProto) override;
 | |
| 
 | |
|  private:
 | |
|   static void MapAttributesIntoRule(const nsMappedAttributes* aAttributes,
 | |
|                                     MappedDeclarations&);
 | |
| };
 | |
| 
 | |
| }  // namespace dom
 | |
| }  // namespace mozilla
 | |
| 
 | |
| #endif /* HTMLBodyElement_h___ */
 |