diff options
author | Cary Clark <cary@android.com> | 2011-02-16 07:56:22 -0800 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2011-02-16 07:56:22 -0800 |
commit | ab420739ed8c917b526cbe0823415288df13baf8 (patch) | |
tree | 7cbd1d85cb1600567c3d412ce63e86a03bd75523 /WebCore/page/History.cpp | |
parent | 944d70ebdb065af6f4c2438f418c7defb18a3aee (diff) | |
parent | 35d2bd6c7e3a089eb4a8d6e074f53a13f471289e (diff) | |
download | external_webkit-ab420739ed8c917b526cbe0823415288df13baf8.zip external_webkit-ab420739ed8c917b526cbe0823415288df13baf8.tar.gz external_webkit-ab420739ed8c917b526cbe0823415288df13baf8.tar.bz2 |
Merge "apply essential security patches"
Diffstat (limited to 'WebCore/page/History.cpp')
-rw-r--r-- | WebCore/page/History.cpp | 33 |
1 files changed, 28 insertions, 5 deletions
diff --git a/WebCore/page/History.cpp b/WebCore/page/History.cpp index 95b1350..f0a75fe 100644 --- a/WebCore/page/History.cpp +++ b/WebCore/page/History.cpp @@ -27,6 +27,7 @@ #include "History.h" #include "BackForwardController.h" +#include "Document.h" #include "ExceptionCode.h" #include "Frame.h" #include "FrameLoader.h" @@ -62,22 +63,44 @@ unsigned History::length() const void History::back() { - if (!m_frame) - return; - m_frame->navigationScheduler()->scheduleHistoryNavigation(-1); + go(-1); +} + +void History::back(ScriptExecutionContext* context) +{ + go(context, -1); } void History::forward() { + go(1); +} + +void History::forward(ScriptExecutionContext* context) +{ + go(context, 1); +} + +void History::go(int distance) +{ if (!m_frame) return; - m_frame->navigationScheduler()->scheduleHistoryNavigation(1); + m_frame->navigationScheduler()->scheduleHistoryNavigation(distance); } -void History::go(int distance) +void History::go(ScriptExecutionContext* context, int distance) { if (!m_frame) return; + + ASSERT(WTF::isMainThread()); + Frame* activeFrame = static_cast<Document*>(context)->frame(); + if (!activeFrame) + return; + + if (!activeFrame->loader()->shouldAllowNavigation(m_frame)) + return; + m_frame->navigationScheduler()->scheduleHistoryNavigation(distance); } |