summaryrefslogtreecommitdiff
path: root/Source/WebCore/html/HTMLFrameElement.cpp
diff options
context:
space:
mode:
authorKonstantin Tokarev <annulen@yandex.ru>2016-08-25 19:20:41 +0300
committerKonstantin Tokarev <annulen@yandex.ru>2017-02-02 12:30:55 +0000
commit6882a04fb36642862b11efe514251d32070c3d65 (patch)
treeb7959826000b061fd5ccc7512035c7478742f7b0 /Source/WebCore/html/HTMLFrameElement.cpp
parentab6df191029eeeb0b0f16f127d553265659f739e (diff)
downloadqtwebkit-6882a04fb36642862b11efe514251d32070c3d65.tar.gz
Imported QtWebKit TP3 (git b57bc6801f1876c3220d5a4bfea33d620d477443)
Change-Id: I3b1d8a2808782c9f34d50240000e20cb38d3680f Reviewed-by: Konstantin Tokarev <annulen@yandex.ru>
Diffstat (limited to 'Source/WebCore/html/HTMLFrameElement.cpp')
-rw-r--r--Source/WebCore/html/HTMLFrameElement.cpp39
1 files changed, 15 insertions, 24 deletions
diff --git a/Source/WebCore/html/HTMLFrameElement.cpp b/Source/WebCore/html/HTMLFrameElement.cpp
index ed5b9b826..ef0da38d1 100644
--- a/Source/WebCore/html/HTMLFrameElement.cpp
+++ b/Source/WebCore/html/HTMLFrameElement.cpp
@@ -24,7 +24,6 @@
#include "config.h"
#include "HTMLFrameElement.h"
-#include "Attribute.h"
#include "Frame.h"
#include "HTMLFrameSetElement.h"
#include "HTMLNames.h"
@@ -34,52 +33,44 @@ namespace WebCore {
using namespace HTMLNames;
-inline HTMLFrameElement::HTMLFrameElement(const QualifiedName& tagName, Document* document)
+inline HTMLFrameElement::HTMLFrameElement(const QualifiedName& tagName, Document& document)
: HTMLFrameElementBase(tagName, document)
, m_frameBorder(true)
, m_frameBorderSet(false)
{
ASSERT(hasTagName(frameTag));
+ setHasCustomStyleResolveCallbacks();
}
-PassRefPtr<HTMLFrameElement> HTMLFrameElement::create(const QualifiedName& tagName, Document* document)
+Ref<HTMLFrameElement> HTMLFrameElement::create(const QualifiedName& tagName, Document& document)
{
- return adoptRef(new HTMLFrameElement(tagName, document));
+ return adoptRef(*new HTMLFrameElement(tagName, document));
}
-bool HTMLFrameElement::rendererIsNeeded(const NodeRenderingContext&)
+bool HTMLFrameElement::rendererIsNeeded(const RenderStyle&)
{
// For compatibility, frames render even when display: none is set.
return isURLAllowed();
}
-RenderObject* HTMLFrameElement::createRenderer(RenderArena* arena, RenderStyle*)
+RenderPtr<RenderElement> HTMLFrameElement::createElementRenderer(Ref<RenderStyle>&& style, const RenderTreePosition&)
{
- return new (arena) RenderFrame(this);
-}
-
-static inline HTMLFrameSetElement* containingFrameSetElement(Node* node)
-{
- while ((node = node->parentNode())) {
- if (node->hasTagName(framesetTag))
- return static_cast<HTMLFrameSetElement*>(node);
- }
- return 0;
+ return createRenderer<RenderFrame>(*this, WTFMove(style));
}
bool HTMLFrameElement::noResize() const
{
- return hasAttribute(noresizeAttr);
+ return fastHasAttribute(noresizeAttr);
}
-void HTMLFrameElement::attach(const AttachContext& context)
+void HTMLFrameElement::didAttachRenderers()
{
- HTMLFrameElementBase::attach(context);
-
- if (HTMLFrameSetElement* frameSetElement = containingFrameSetElement(this)) {
- if (!m_frameBorderSet)
- m_frameBorder = frameSetElement->hasFrameBorder();
- }
+ HTMLFrameElementBase::didAttachRenderers();
+ const HTMLFrameSetElement* containingFrameSet = HTMLFrameSetElement::findContaining(this);
+ if (!containingFrameSet)
+ return;
+ if (!m_frameBorderSet)
+ m_frameBorder = containingFrameSet->hasFrameBorder();
}
void HTMLFrameElement::parseAttribute(const QualifiedName& name, const AtomicString& value)