Update To 11.40.268.0
[platform/framework/web/crosswalk.git] / src / third_party / WebKit / Source / web / WebLocalFrameImpl.h
index 5991c02..068c4d5 100644 (file)
 #include "wtf/RefCounted.h"
 #include "wtf/text/WTFString.h"
 
-namespace WebCore {
-class GraphicsContext;
-class HTMLInputElement;
-class HistoryItem;
-class IntSize;
-class KURL;
-class Node;
-class Range;
-class SubstituteData;
-struct FrameLoadRequest;
-struct WindowFeatures;
-}
-
 namespace blink {
+
 class ChromePrintContext;
 class GeolocationClientProxy;
+class IntSize;
+class KURL;
+class Range;
+class ScriptSourceCode;
 class SharedWorkerRepositoryClientImpl;
 class TextFinder;
 class WebDataSourceImpl;
-class WebInputElement;
 class WebFrameClient;
 class WebPerformance;
 class WebPlugin;
 class WebPluginContainerImpl;
+class WebScriptExecutionCallback;
 class WebView;
 class WebViewImpl;
+struct FrameLoadRequest;
 struct WebPrintParams;
 
 template <typename T> class WebVector;
 
 // Implementation of WebFrame, note that this is a reference counted object.
-class WebLocalFrameImpl FINAL
-    : public WebLocalFrame
-    , public RefCounted<WebLocalFrameImpl> {
+class WebLocalFrameImpl final : public RefCountedWillBeGarbageCollectedFinalized<WebLocalFrameImpl>, public WebLocalFrame {
 public:
     // WebFrame methods:
-    virtual bool isWebLocalFrame() const OVERRIDE;
-    virtual WebLocalFrame* toWebLocalFrame() OVERRIDE;
-    virtual bool isWebRemoteFrame() const OVERRIDE;
-    virtual WebRemoteFrame* toWebRemoteFrame() OVERRIDE;
-    virtual void close() OVERRIDE;
-    virtual WebString uniqueName() const OVERRIDE;
-    virtual WebString assignedName() const OVERRIDE;
-    virtual void setName(const WebString&) OVERRIDE;
-    virtual WebVector<WebIconURL> iconURLs(int iconTypesMask) const OVERRIDE;
-    virtual void setIsRemote(bool) OVERRIDE;
-    virtual void setRemoteWebLayer(WebLayer*) OVERRIDE;
-    virtual void setPermissionClient(WebPermissionClient*) OVERRIDE;
-    virtual void setSharedWorkerRepositoryClient(WebSharedWorkerRepositoryClient*) OVERRIDE;
-    virtual WebSize scrollOffset() const OVERRIDE;
-    virtual void setScrollOffset(const WebSize&) OVERRIDE;
-    virtual WebSize minimumScrollOffset() const OVERRIDE;
-    virtual WebSize maximumScrollOffset() const OVERRIDE;
-    virtual WebSize contentsSize() const OVERRIDE;
-    virtual bool hasVisibleContent() const OVERRIDE;
-    virtual WebRect visibleContentRect() const OVERRIDE;
-    virtual bool hasHorizontalScrollbar() const OVERRIDE;
-    virtual bool hasVerticalScrollbar() const OVERRIDE;
-    virtual WebView* view() const OVERRIDE;
-    virtual void setOpener(WebFrame*) OVERRIDE;
-    virtual WebDocument document() const OVERRIDE;
-    virtual WebPerformance performance() const OVERRIDE;
-    virtual bool dispatchBeforeUnloadEvent() OVERRIDE;
-    virtual void dispatchUnloadEvent() OVERRIDE;
-    virtual NPObject* windowObject() const OVERRIDE;
-    virtual void bindToWindowObject(const WebString& name, NPObject*) OVERRIDE;
-    virtual void bindToWindowObject(const WebString& name, NPObject*, void*) OVERRIDE;
-    virtual void executeScript(const WebScriptSource&) OVERRIDE;
+    virtual bool isWebLocalFrame() const override;
+    virtual WebLocalFrame* toWebLocalFrame() override;
+    virtual bool isWebRemoteFrame() const override;
+    virtual WebRemoteFrame* toWebRemoteFrame() override;
+    virtual void close() override;
+    virtual WebString uniqueName() const override;
+    virtual WebString assignedName() const override;
+    virtual void setName(const WebString&) override;
+    virtual WebVector<WebIconURL> iconURLs(int iconTypesMask) const override;
+    virtual void setRemoteWebLayer(WebLayer*) override;
+    virtual void setPermissionClient(WebPermissionClient*) override;
+    virtual void setSharedWorkerRepositoryClient(WebSharedWorkerRepositoryClient*) override;
+    virtual WebSize scrollOffset() const override;
+    virtual void setScrollOffset(const WebSize&) override;
+    virtual WebSize minimumScrollOffset() const override;
+    virtual WebSize maximumScrollOffset() const override;
+    virtual WebSize contentsSize() const override;
+    virtual bool hasVisibleContent() const override;
+    virtual WebRect visibleContentRect() const override;
+    virtual bool hasHorizontalScrollbar() const override;
+    virtual bool hasVerticalScrollbar() const override;
+    virtual WebView* view() const override;
+    virtual void setOpener(WebFrame*) override;
+    virtual WebDocument document() const override;
+    virtual WebPerformance performance() const override;
+    virtual bool dispatchBeforeUnloadEvent() override;
+    virtual void dispatchUnloadEvent() override;
+    virtual NPObject* windowObject() const override;
+    virtual void bindToWindowObject(const WebString& name, NPObject*) override;
+    virtual void bindToWindowObject(const WebString& name, NPObject*, void*) override;
+    virtual void executeScript(const WebScriptSource&) override;
     virtual void executeScriptInIsolatedWorld(
         int worldID, const WebScriptSource* sources, unsigned numSources,
-        int extensionGroup) OVERRIDE;
-    virtual void setIsolatedWorldSecurityOrigin(int worldID, const WebSecurityOrigin&) OVERRIDE;
-    virtual void setIsolatedWorldContentSecurityPolicy(int worldID, const WebString&) OVERRIDE;
-    virtual void addMessageToConsole(const WebConsoleMessage&) OVERRIDE;
-    virtual void collectGarbage() OVERRIDE;
-    virtual bool checkIfRunInsecureContent(const WebURL&) const OVERRIDE;
+        int extensionGroup) override;
+    virtual void setIsolatedWorldSecurityOrigin(int worldID, const WebSecurityOrigin&) override;
+    virtual void setIsolatedWorldContentSecurityPolicy(int worldID, const WebString&) override;
+    virtual void setIsolatedWorldHumanReadableName(int worldID, const WebString&) override;
+    virtual void addMessageToConsole(const WebConsoleMessage&) override;
+    virtual void collectGarbage() override;
+    virtual bool checkIfRunInsecureContent(const WebURL&) const override;
     virtual v8::Handle<v8::Value> executeScriptAndReturnValue(
-        const WebScriptSource&) OVERRIDE;
+        const WebScriptSource&) override;
+    virtual void requestExecuteScriptAndReturnValue(
+        const WebScriptSource&, bool userGesture, WebScriptExecutionCallback*) override;
     virtual void executeScriptInIsolatedWorld(
         int worldID, const WebScriptSource* sourcesIn, unsigned numSources,
-        int extensionGroup, WebVector<v8::Local<v8::Value> >* results) OVERRIDE;
+        int extensionGroup, WebVector<v8::Local<v8::Value> >* results) override;
+    virtual void requestExecuteScriptInIsolatedWorld(
+        int worldID, const WebScriptSource* sourceIn, unsigned numSources,
+        int extensionGroup, bool userGesture, WebScriptExecutionCallback*) override;
     virtual v8::Handle<v8::Value> callFunctionEvenIfScriptDisabled(
         v8::Handle<v8::Function>,
         v8::Handle<v8::Value>,
         int argc,
-        v8::Handle<v8::Value> argv[]) OVERRIDE;
-    virtual v8::Local<v8::Context> mainWorldScriptContext() const OVERRIDE;
-    virtual void reload(bool ignoreCache) OVERRIDE;
-    virtual void reloadWithOverrideURL(const WebURL& overrideUrl, bool ignoreCache) OVERRIDE;
-    virtual void loadRequest(const WebURLRequest&) OVERRIDE;
-    virtual void loadHistoryItem(const WebHistoryItem&, WebHistoryLoadType, WebURLRequest::CachePolicy) OVERRIDE;
+        v8::Handle<v8::Value> argv[]) override;
+    virtual v8::Local<v8::Context> mainWorldScriptContext() const override;
+    virtual void reload(bool ignoreCache) override;
+    virtual void reloadWithOverrideURL(const WebURL& overrideUrl, bool ignoreCache) override;
+    virtual void loadRequest(const WebURLRequest&) override;
+    virtual void loadHistoryItem(const WebHistoryItem&, WebHistoryLoadType, WebURLRequest::CachePolicy) override;
     virtual void loadData(
         const WebData&, const WebString& mimeType, const WebString& textEncoding,
-        const WebURL& baseURL, const WebURL& unreachableURL, bool replace) OVERRIDE;
+        const WebURL& baseURL, const WebURL& unreachableURL, bool replace) override;
     virtual void loadHTMLString(
         const WebData& html, const WebURL& baseURL, const WebURL& unreachableURL,
-        bool replace) OVERRIDE;
-    virtual bool isLoading() const OVERRIDE;
-    virtual void stopLoading() OVERRIDE;
-    virtual WebDataSource* provisionalDataSource() const OVERRIDE;
-    virtual WebDataSource* dataSource() const OVERRIDE;
-    virtual void enableViewSourceMode(bool enable) OVERRIDE;
-    virtual bool isViewSourceModeEnabled() const OVERRIDE;
-    virtual void setReferrerForRequest(WebURLRequest&, const WebURL& referrer) OVERRIDE;
-    virtual void dispatchWillSendRequest(WebURLRequest&) OVERRIDE;
-    virtual WebURLLoader* createAssociatedURLLoader(const WebURLLoaderOptions&) OVERRIDE;
-    virtual unsigned unloadListenerCount() const OVERRIDE;
-    virtual void replaceSelection(const WebString&) OVERRIDE;
-    virtual void insertText(const WebString&) OVERRIDE;
-    virtual void setMarkedText(const WebString&, unsigned location, unsigned length) OVERRIDE;
-    virtual void unmarkText() OVERRIDE;
-    virtual bool hasMarkedText() const OVERRIDE;
-    virtual WebRange markedRange() const OVERRIDE;
-    virtual bool firstRectForCharacterRange(unsigned location, unsigned length, WebRect&) const OVERRIDE;
-    virtual size_t characterIndexForPoint(const WebPoint&) const OVERRIDE;
-    virtual bool executeCommand(const WebString&, const WebNode& = WebNode()) OVERRIDE;
-    virtual bool executeCommand(const WebString&, const WebString& value, const WebNode& = WebNode()) OVERRIDE;
-    virtual bool isCommandEnabled(const WebString&) const OVERRIDE;
-    virtual void enableContinuousSpellChecking(bool) OVERRIDE;
-    virtual bool isContinuousSpellCheckingEnabled() const OVERRIDE;
-    virtual void requestTextChecking(const WebElement&) OVERRIDE;
-    virtual void replaceMisspelledRange(const WebString&) OVERRIDE;
-    virtual void removeSpellingMarkers() OVERRIDE;
-    virtual bool hasSelection() const OVERRIDE;
-    virtual WebRange selectionRange() const OVERRIDE;
-    virtual WebString selectionAsText() const OVERRIDE;
-    virtual WebString selectionAsMarkup() const OVERRIDE;
-    virtual bool selectWordAroundCaret() OVERRIDE;
-    virtual void selectRange(const WebPoint& base, const WebPoint& extent) OVERRIDE;
-    virtual void selectRange(const WebRange&) OVERRIDE;
-    virtual void moveRangeSelection(const WebPoint& base, const WebPoint& extent) OVERRIDE;
-    virtual void moveCaretSelection(const WebPoint&) OVERRIDE;
-    virtual bool setEditableSelectionOffsets(int start, int end) OVERRIDE;
-    virtual bool setCompositionFromExistingText(int compositionStart, int compositionEnd, const WebVector<WebCompositionUnderline>& underlines) OVERRIDE;
-    virtual void extendSelectionAndDelete(int before, int after) OVERRIDE;
-    virtual void setCaretVisible(bool) OVERRIDE;
-    virtual int printBegin(const WebPrintParams&, const WebNode& constrainToNode) OVERRIDE;
-    virtual float printPage(int pageToPrint, WebCanvas*) OVERRIDE;
-    virtual float getPrintPageShrink(int page) OVERRIDE;
-    virtual void printEnd() OVERRIDE;
-    virtual bool isPrintScalingDisabledForPlugin(const WebNode&) OVERRIDE;
-    virtual bool hasCustomPageSizeStyle(int pageIndex) OVERRIDE;
-    virtual bool isPageBoxVisible(int pageIndex) OVERRIDE;
+        bool replace) override;
+    virtual void stopLoading() override;
+    virtual WebDataSource* provisionalDataSource() const override;
+    virtual WebDataSource* dataSource() const override;
+    virtual void enableViewSourceMode(bool enable) override;
+    virtual bool isViewSourceModeEnabled() const override;
+    virtual void setReferrerForRequest(WebURLRequest&, const WebURL& referrer) override;
+    virtual void dispatchWillSendRequest(WebURLRequest&) override;
+    virtual WebURLLoader* createAssociatedURLLoader(const WebURLLoaderOptions&) override;
+    virtual unsigned unloadListenerCount() const override;
+    virtual void replaceSelection(const WebString&) override;
+    virtual void insertText(const WebString&) override;
+    virtual void setMarkedText(const WebString&, unsigned location, unsigned length) override;
+    virtual void unmarkText() override;
+    virtual bool hasMarkedText() const override;
+    virtual WebRange markedRange() const override;
+    virtual bool firstRectForCharacterRange(unsigned location, unsigned length, WebRect&) const override;
+    virtual size_t characterIndexForPoint(const WebPoint&) const override;
+    virtual bool executeCommand(const WebString&, const WebNode& = WebNode()) override;
+    virtual bool executeCommand(const WebString&, const WebString& value, const WebNode& = WebNode()) override;
+    virtual bool isCommandEnabled(const WebString&) const override;
+    virtual void enableContinuousSpellChecking(bool) override;
+    virtual bool isContinuousSpellCheckingEnabled() const override;
+    virtual void requestTextChecking(const WebElement&) override;
+    virtual void replaceMisspelledRange(const WebString&) override;
+    virtual void removeSpellingMarkers() override;
+    virtual bool hasSelection() const override;
+    virtual WebRange selectionRange() const override;
+    virtual WebString selectionAsText() const override;
+    virtual WebString selectionAsMarkup() const override;
+    virtual bool selectWordAroundCaret() override;
+    virtual void selectRange(const WebPoint& base, const WebPoint& extent) override;
+    virtual void selectRange(const WebRange&) override;
+    virtual void moveRangeSelectionExtent(const WebPoint&) override;
+    virtual void moveRangeSelection(const WebPoint& base, const WebPoint& extent) override;
+    virtual void moveCaretSelection(const WebPoint&) override;
+    virtual bool setEditableSelectionOffsets(int start, int end) override;
+    virtual bool setCompositionFromExistingText(int compositionStart, int compositionEnd, const WebVector<WebCompositionUnderline>& underlines) override;
+    virtual void extendSelectionAndDelete(int before, int after) override;
+    virtual void setCaretVisible(bool) override;
+    virtual int printBegin(const WebPrintParams&, const WebNode& constrainToNode) override;
+    virtual float printPage(int pageToPrint, WebCanvas*) override;
+    virtual float getPrintPageShrink(int page) override;
+    virtual void printEnd() override;
+    virtual bool isPrintScalingDisabledForPlugin(const WebNode&) override;
+    virtual int getPrintCopiesForPlugin(const WebNode&) override;
+    virtual bool hasCustomPageSizeStyle(int pageIndex) override;
+    virtual bool isPageBoxVisible(int pageIndex) override;
     virtual void pageSizeAndMarginsInPixels(
         int pageIndex,
         WebSize& pageSize,
         int& marginTop,
         int& marginRight,
         int& marginBottom,
-        int& marginLeft) OVERRIDE;
-    virtual WebString pageProperty(const WebString& propertyName, int pageIndex) OVERRIDE;
-    virtual void printPagesWithBoundaries(WebCanvas*, const WebSize&) OVERRIDE;
+        int& marginLeft) override;
+    virtual WebString pageProperty(const WebString& propertyName, int pageIndex) override;
+    virtual void printPagesWithBoundaries(WebCanvas*, const WebSize&) override;
     virtual bool find(
         int identifier, const WebString& searchText, const WebFindOptions&,
-        bool wrapWithinFrame, WebRect* selectionRect) OVERRIDE;
-    virtual void stopFinding(bool clearSelection) OVERRIDE;
+        bool wrapWithinFrame, WebRect* selectionRect) override;
+    virtual void stopFinding(bool clearSelection) override;
     virtual void scopeStringMatches(
         int identifier, const WebString& searchText, const WebFindOptions&,
-        bool reset) OVERRIDE;
-    virtual void cancelPendingScopingEffort() OVERRIDE;
-    virtual void increaseMatchCount(int count, int identifier) OVERRIDE;
-    virtual void resetMatchCount() OVERRIDE;
-    virtual int findMatchMarkersVersion() const OVERRIDE;
-    virtual WebFloatRect activeFindMatchRect() OVERRIDE;
-    virtual void findMatchRects(WebVector<WebFloatRect>&) OVERRIDE;
-    virtual int selectNearestFindMatch(const WebFloatPoint&, WebRect* selectionRect) OVERRIDE;
-    virtual void setTickmarks(const WebVector<WebRect>&) OVERRIDE;
-
-    virtual void sendOrientationChangeEvent() OVERRIDE;
+        bool reset) override;
+    virtual void cancelPendingScopingEffort() override;
+    virtual void increaseMatchCount(int count, int identifier) override;
+    virtual void resetMatchCount() override;
+    virtual int findMatchMarkersVersion() const override;
+    virtual WebFloatRect activeFindMatchRect() override;
+    virtual void findMatchRects(WebVector<WebFloatRect>&) override;
+    virtual int selectNearestFindMatch(const WebFloatPoint&, WebRect* selectionRect) override;
+    virtual void setTickmarks(const WebVector<WebRect>&) override;
 
     virtual void dispatchMessageEventWithOriginCheck(
         const WebSecurityOrigin& intendedTargetOrigin,
-        const WebDOMEvent&) OVERRIDE;
+        const WebDOMEvent&) override;
 
-    virtual WebString contentAsText(size_t maxChars) const OVERRIDE;
-    virtual WebString contentAsMarkup() const OVERRIDE;
-    virtual WebString renderTreeAsText(RenderAsTextControls toShow = RenderAsTextNormal) const OVERRIDE;
-    virtual WebString markerTextForListItem(const WebElement&) const OVERRIDE;
-    virtual WebRect selectionBoundsRect() const OVERRIDE;
+    virtual WebString contentAsText(size_t maxChars) const override;
+    virtual WebString contentAsMarkup() const override;
+    virtual WebString renderTreeAsText(RenderAsTextControls toShow = RenderAsTextNormal) const override;
+    virtual WebString markerTextForListItem(const WebElement&) const override;
+    virtual WebRect selectionBoundsRect() const override;
 
-    virtual bool selectionStartHasSpellingMarkerFor(int from, int length) const OVERRIDE;
-    virtual WebString layerTreeAsText(bool showDebugInfo = false) const OVERRIDE;
+    virtual bool selectionStartHasSpellingMarkerFor(int from, int length) const override;
+    virtual WebString layerTreeAsText(bool showDebugInfo = false) const override;
 
     // WebLocalFrame methods:
-    virtual void addStyleSheetByURL(const WebString& url) OVERRIDE;
+    virtual void initializeToReplaceRemoteFrame(WebRemoteFrame*) override;
+    virtual void sendPings(const WebNode& linkNode, const WebURL& destinationURL) override;
+    virtual bool isLoading() const override;
+    virtual bool isResourceLoadInProgress() const override;
+    virtual void addStyleSheetByURL(const WebString& url) override;
+    virtual void navigateToSandboxedMarkup(const WebData& markup) override;
+    virtual void sendOrientationChangeEvent() override;
+    virtual v8::Handle<v8::Value> executeScriptAndReturnValueForTests(
+        const WebScriptSource&) override;
 
     void willDetachParent();
 
     static WebLocalFrameImpl* create(WebFrameClient*);
     virtual ~WebLocalFrameImpl();
 
-    // Called by the WebViewImpl to initialize the main frame for the page.
-    void initializeAsMainFrame(WebCore::Page*);
+    PassRefPtrWillBeRawPtr<LocalFrame> initializeCoreFrame(FrameHost*, FrameOwner*, const AtomicString& name, const AtomicString& fallbackName);
 
-    PassRefPtr<WebCore::LocalFrame> createChildFrame(
-        const WebCore::FrameLoadRequest&, WebCore::HTMLFrameOwnerElement*);
+    PassRefPtrWillBeRawPtr<LocalFrame> createChildFrame(const FrameLoadRequest&, HTMLFrameOwnerElement*);
 
-    void didChangeContentsSize(const WebCore::IntSize&);
+    void didChangeContentsSize(const IntSize&);
 
     void createFrameView();
 
-    static WebLocalFrameImpl* fromFrame(WebCore::LocalFrame*);
-    static WebLocalFrameImpl* fromFrame(WebCore::LocalFrame&);
-    static WebLocalFrameImpl* fromFrameOwnerElement(WebCore::Element*);
+    static WebLocalFrameImpl* fromFrame(LocalFrame*);
+    static WebLocalFrameImpl* fromFrame(LocalFrame&);
+    static WebLocalFrameImpl* fromFrameOwnerElement(Element*);
 
     // If the frame hosts a PluginDocument, this method returns the WebPluginContainerImpl
     // that hosts the plugin.
-    static WebPluginContainerImpl* pluginContainerFromFrame(WebCore::LocalFrame*);
+    static WebPluginContainerImpl* pluginContainerFromFrame(LocalFrame*);
 
     // If the frame hosts a PluginDocument, this method returns the WebPluginContainerImpl
     // that hosts the plugin. If the provided node is a plugin, then it runs its
     // WebPluginContainerImpl.
-    static WebPluginContainerImpl* pluginContainerFromNode(WebCore::LocalFrame*, const WebNode&);
+    static WebPluginContainerImpl* pluginContainerFromNode(LocalFrame*, const WebNode&);
 
     WebViewImpl* viewImpl() const;
 
-    WebCore::FrameView* frameView() const { return frame() ? frame()->view() : 0; }
+    FrameView* frameView() const { return frame() ? frame()->view() : 0; }
 
     // Getters for the impls corresponding to Get(Provisional)DataSource. They
     // may return 0 if there is no corresponding data source.
@@ -273,7 +274,7 @@ public:
 
     // Returns the active match in the current frame. Could be a null range if
     // the local frame has no active match.
-    WebCore::Range* activeMatch() const;
+    Range* activeMatch() const;
 
     // When a Find operation ends, we want to set the selection to what was active
     // and set focus to the first focusable node we find (starting with the first
@@ -283,23 +284,23 @@ public:
     // allows us to navigate by pressing Enter after closing the Find box.
     void setFindEndstateFocusAndSelection();
 
-    void didFail(const WebCore::ResourceError&, bool wasProvisional);
+    void didFail(const ResourceError&, bool wasProvisional);
 
     // Sets whether the WebLocalFrameImpl allows its document to be scrolled.
     // If the parameter is true, allow the document to be scrolled.
     // Otherwise, disallow scrolling.
-    virtual void setCanHaveScrollbars(bool) OVERRIDE;
+    virtual void setCanHaveScrollbars(bool) override;
 
-    WebCore::LocalFrame* frame() const { return m_frame.get(); }
+    LocalFrame* frame() const { return m_frame.get(); }
     WebFrameClient* client() const { return m_client; }
     void setClient(WebFrameClient* client) { m_client = client; }
 
     WebPermissionClient* permissionClient() { return m_permissionClient; }
     SharedWorkerRepositoryClientImpl* sharedWorkerRepositoryClient() const { return m_sharedWorkerRepositoryClient.get(); }
 
-    void setInputEventsTransformForEmulation(const WebCore::IntSize&, float);
+    void setInputEventsTransformForEmulation(const IntSize&, float);
 
-    static void selectWordAroundPosition(WebCore::LocalFrame*, WebCore::VisiblePosition);
+    static void selectWordAroundPosition(LocalFrame*, VisiblePosition);
 
     // Returns the text finder object if it already exists.
     // Otherwise creates it and then returns.
@@ -311,20 +312,22 @@ public:
     // Invalidates both content area and the scrollbar.
     void invalidateAll() const;
 
-    PassRefPtr<WebCore::LocalFrame> initializeAsChildFrame(WebCore::FrameHost*, WebCore::FrameOwner*, const AtomicString& name, const AtomicString& fallbackName);
-
     // Returns a hit-tested VisiblePosition for the given point
-    WebCore::VisiblePosition visiblePositionForWindowPoint(const WebPoint&);
+    VisiblePosition visiblePositionForWindowPoint(const WebPoint&);
+
+#if ENABLE(OILPAN)
+    void trace(Visitor*);
+#endif
 
 private:
     friend class FrameLoaderClientImpl;
 
     explicit WebLocalFrameImpl(WebFrameClient*);
 
-    // Sets the local WebCore frame and registers destruction observers.
-    void setWebCoreFrame(PassRefPtr<WebCore::LocalFrame>);
+    // Sets the local core frame and registers destruction observers.
+    void setCoreFrame(PassRefPtrWillBeRawPtr<LocalFrame>);
 
-    void loadJavaScriptURL(const WebCore::KURL&);
+    void loadJavaScriptURL(const KURL&);
 
     WebPlugin* focusedPluginIfInputMethodSupported();
 
@@ -333,30 +336,37 @@ private:
     // The embedder retains a reference to the WebCore LocalFrame while it is active in the DOM. This
     // reference is released when the frame is removed from the DOM or the entire page is closed.
     // FIXME: These will need to change to WebFrame when we introduce WebFrameProxy.
-    RefPtr<WebCore::LocalFrame> m_frame;
-
-    // Indicate whether the current LocalFrame is local or remote. Remote frames are
-    // rendered in a different process from their parent frames.
-    bool m_isRemote;
+    RefPtrWillBeMember<LocalFrame> m_frame;
 
     WebFrameClient* m_client;
     WebPermissionClient* m_permissionClient;
     OwnPtr<SharedWorkerRepositoryClientImpl> m_sharedWorkerRepositoryClient;
 
     // Will be initialized after first call to find() or scopeStringMatches().
-    OwnPtr<TextFinder> m_textFinder;
+    OwnPtrWillBeMember<TextFinder> m_textFinder;
 
     // Valid between calls to BeginPrint() and EndPrint(). Containts the print
     // information. Is used by PrintPage().
-    OwnPtr<ChromePrintContext> m_printContext;
+    OwnPtrWillBeMember<ChromePrintContext> m_printContext;
 
     // Stores the additional input events offset and scale when device metrics emulation is enabled.
-    WebCore::IntSize m_inputEventsOffsetForEmulation;
+    IntSize m_inputEventsOffsetForEmulation;
     float m_inputEventsScaleFactorForEmulation;
 
     UserMediaClientImpl m_userMediaClientImpl;
 
-    OwnPtr<GeolocationClientProxy> m_geolocationClientProxy;
+    OwnPtrWillBeMember<GeolocationClientProxy> m_geolocationClientProxy;
+
+#if ENABLE(OILPAN)
+    // Oilpan: to provide the guarantee of having the frame live until
+    // close() is called, an instance keep a self-persistent. It is
+    // cleared upon calling close(). This avoids having to assume that
+    // an embedder's WebFrame references are all discovered via thread
+    // state (stack, registers) should an Oilpan GC strike while we're
+    // in the process of detaching.
+    GC_PLUGIN_IGNORE("340522")
+    Persistent<WebLocalFrameImpl> m_selfKeepAlive;
+#endif
 };
 
 DEFINE_TYPE_CASTS(WebLocalFrameImpl, WebFrame, frame, frame->isWebLocalFrame(), frame.isWebLocalFrame());