diff options
Diffstat (limited to 'Source/WebCore/dom/PseudoElement.h')
-rw-r--r-- | Source/WebCore/dom/PseudoElement.h | 41 |
1 files changed, 16 insertions, 25 deletions
diff --git a/Source/WebCore/dom/PseudoElement.h b/Source/WebCore/dom/PseudoElement.h index 10bb186a6..367ada576 100644 --- a/Source/WebCore/dom/PseudoElement.h +++ b/Source/WebCore/dom/PseudoElement.h @@ -24,47 +24,45 @@ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#ifndef PseudoElement_h -#define PseudoElement_h +#pragma once #include "Element.h" #include "Event.h" -#include "RenderStyle.h" #include <wtf/Forward.h> namespace WebCore { class PseudoElement final : public Element { public: - static PassRefPtr<PseudoElement> create(Element& host, PseudoId pseudoId) + static Ref<PseudoElement> create(Element& host, PseudoId pseudoId) { - return adoptRef(new PseudoElement(host, pseudoId)); + return adoptRef(*new PseudoElement(host, pseudoId)); } virtual ~PseudoElement(); Element* hostElement() const { return m_hostElement; } - void clearHostElement() { m_hostElement = nullptr; } + void clearHostElement(); - virtual PassRefPtr<RenderStyle> customStyleForRenderer() override; - virtual void didAttachRenderers() override; - virtual bool rendererIsNeeded(const RenderStyle&) override; + std::optional<ElementStyle> resolveCustomStyle(const RenderStyle& parentStyle, const RenderStyle* shadowHostStyle) override; + void didAttachRenderers() override; + void didRecalcStyle(Style::Change) override; + bool rendererIsNeeded(const RenderStyle&) override; // As per http://dev.w3.org/csswg/css3-regions/#flow-into, pseudo-elements such as ::first-line, ::first-letter, ::before or ::after // cannot be directly collected into a named flow. #if ENABLE(CSS_REGIONS) - virtual bool shouldMoveToFlowThread(const RenderStyle&) const override { return false; } + bool shouldMoveToFlowThread(const RenderStyle&) const override { return false; } #endif - virtual bool canStartSelection() const override { return false; } - virtual bool canContainRangeEndPoint() const override { return false; } + bool canStartSelection() const override { return false; } + bool canContainRangeEndPoint() const override { return false; } static String pseudoElementNameForEvents(PseudoId); private: PseudoElement(Element&, PseudoId); - virtual void didRecalcStyle(Style::Change) override; - virtual PseudoId customPseudoId() const override { return m_pseudoId; } + PseudoId customPseudoId() const override { return m_pseudoId; } Element* m_hostElement; PseudoId m_pseudoId; @@ -72,15 +70,8 @@ private: const QualifiedName& pseudoElementTagName(); -inline bool pseudoElementRendererIsNeeded(const RenderStyle* style) -{ - return style && style->display() != NONE && (style->contentData() || style->hasFlowFrom()); -} +} // namespace WebCore -void isPseudoElement(const PseudoElement&); // Catch unnecessary runtime check of type known at compile time. -inline bool isPseudoElement(const Node& node) { return node.isPseudoElement(); } -NODE_TYPE_CASTS(PseudoElement) - -} // namespace - -#endif +SPECIALIZE_TYPE_TRAITS_BEGIN(WebCore::PseudoElement) + static bool isType(const WebCore::Node& node) { return node.isPseudoElement(); } +SPECIALIZE_TYPE_TRAITS_END() |