| Index: Source/core/loader/FrameLoader.cpp | 
| diff --git a/Source/core/loader/FrameLoader.cpp b/Source/core/loader/FrameLoader.cpp | 
| index a7b1fe38c813e5e73d876542fe0950122acb6f25..6d6ab0fa563ed531b6ce7340634d5f925fc7f2c2 100644 | 
| --- a/Source/core/loader/FrameLoader.cpp | 
| +++ b/Source/core/loader/FrameLoader.cpp | 
| @@ -266,6 +266,36 @@ void FrameLoader::clear() | 
| m_stateMachine.advanceTo(FrameLoaderStateMachine::CommittedFirstRealLoad); | 
| } | 
|  | 
| +// This is only called by ScriptController::executeScriptIfJavaScriptURL | 
| +// and always contains the result of evaluating a javascript: url. | 
| +// This is the <iframe src="javascript:'html'"> case. | 
| +void FrameLoader::replaceDocument(const String& source, Document* ownerDocument) | 
| +{ | 
| +    if (!m_frame->document()->loader()) | 
| +        return; | 
| + | 
| +    // DocumentWriter::replaceDocument can cause the DocumentLoader to get deref'ed and possible destroyed, | 
| +    // so protect it with a RefPtr. | 
| +    RefPtr<DocumentLoader> documentLoader(m_frame->document()->loader()); | 
| + | 
| +    UseCounter::count(*m_frame->document(), UseCounter::ReplaceDocumentViaJavaScriptURL); | 
| + | 
| +    // Prepare a DocumentInit before clearing the frame, because it may need to | 
| +    // inherit an aliased security context. | 
| +    DocumentInit init(m_frame->document()->url(), m_frame); | 
| +    init.withNewRegistrationContext(); | 
| + | 
| +    stopAllLoaders(); | 
| +    clear(); | 
| + | 
| +    // clear() potentially detaches the frame from the document. The | 
| +    // loading cannot continue in that case. | 
| +    if (!m_frame->page()) | 
| +        return; | 
| + | 
| +    documentLoader->replaceDocument(init, source, ownerDocument); | 
| +} | 
| + | 
| void FrameLoader::setHistoryItemStateForCommit(HistoryCommitType historyCommitType, bool isPushOrReplaceState, PassRefPtr<SerializedScriptValue> stateObject) | 
| { | 
| if (m_provisionalItem) | 
|  |