summaryrefslogtreecommitdiff
path: root/Source/WebCore/dom/PseudoElement.h
diff options
context:
space:
mode:
Diffstat (limited to 'Source/WebCore/dom/PseudoElement.h')
-rw-r--r--Source/WebCore/dom/PseudoElement.h41
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()