diff options
author | Simon Hausmann <simon.hausmann@nokia.com> | 2012-02-03 09:55:33 +0100 |
---|---|---|
committer | Simon Hausmann <simon.hausmann@nokia.com> | 2012-02-03 09:55:33 +0100 |
commit | cd44dc59cdfc39534aef4d417e9f3c412e3be139 (patch) | |
tree | 8d89889ba95ed6ec9322e733846cc9cce9d7dff1 /Source/WebCore/html/HTMLFrameElementBase.cpp | |
parent | d11f84f5b5cdc0d92a08af01b13472fdd5f9acb9 (diff) | |
download | qtwebkit-cd44dc59cdfc39534aef4d417e9f3c412e3be139.tar.gz |
Imported WebKit commit fce473cb4d55aa9fe9d0b0322a2fffecb731b961 (http://svn.webkit.org/repository/webkit/trunk@106560)
Diffstat (limited to 'Source/WebCore/html/HTMLFrameElementBase.cpp')
-rw-r--r-- | Source/WebCore/html/HTMLFrameElementBase.cpp | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/Source/WebCore/html/HTMLFrameElementBase.cpp b/Source/WebCore/html/HTMLFrameElementBase.cpp index f5d22a418..fddec7f92 100644 --- a/Source/WebCore/html/HTMLFrameElementBase.cpp +++ b/Source/WebCore/html/HTMLFrameElementBase.cpp @@ -201,16 +201,14 @@ void HTMLFrameElementBase::insertedIntoDocument() if (!document()->frame()) return; - // Loads may cause synchronous javascript execution (e.g. beforeload or - // src=javascript), which could try to access the renderer before the normal - // parser machinery would call lazyAttach() and set us as needing style - // resolve. Any code which expects this to be attached will resolve style - // before using renderer(), so this will make sure we attach in time. - // FIXME: Normally lazyAttach marks the renderer as attached(), but we don't - // want to do that here, as as callers expect to call attach() right after - // this and attach() will ASSERT(!attached()) - ASSERT(!renderer()); // This recalc is unecessary if we already have a renderer. - lazyAttach(DoNotSetAttached); + // JavaScript in src=javascript: and beforeonload can access the renderer + // during attribute parsing *before* the normal parser machinery would + // attach the element. To support this, we lazyAttach here, but only + // if we don't already have a renderer (if we're inserted + // as part of a DocumentFragment, insertedIntoDocument from an earlier element + // could have forced a style resolve and already attached us). + if (!renderer()) + lazyAttach(DoNotSetAttached); setNameAndOpenURL(); } |