Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2925)

Unified Diff: chrome/browser/instant/instant_page.h

Issue 12386019: Instant: Use only one hidden WebContents per profile. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 7 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/instant/instant_page.h
diff --git a/chrome/browser/instant/instant_page.h b/chrome/browser/instant/instant_page.h
index 024d44be4b148b524a409a2a68eaec934ebef3e1..3d002f4bccccf08156811359bb45daf6311cbeba 100644
--- a/chrome/browser/instant/instant_page.h
+++ b/chrome/browser/instant/instant_page.h
@@ -9,12 +9,16 @@
#include "base/basictypes.h"
#include "base/compiler_specific.h"
+#include "base/memory/scoped_ptr.h"
#include "base/string16.h"
#include "chrome/common/instant_types.h"
+#include "chrome/common/omnibox_types.h"
#include "content/public/browser/web_contents_observer.h"
#include "content/public/common/page_transition_types.h"
+#include "ui/base/window_open_disposition.h"
class GURL;
+class InstantService;
namespace content {
class WebContents;
@@ -24,10 +28,12 @@ namespace gfx {
class Rect;
}
+namespace IPC {
+class Message;
+}
+
// InstantPage is used to exchange messages with a page that implements the
// Instant/Embedded Search API (http://dev.chromium.org/embeddedsearch).
-// InstantPage is not used directly but via one of its derived classes:
-// InstantOverlay, InstantNTP and InstantTab.
class InstantPage : public content::WebContentsObserver {
public:
// InstantPage calls its delegate in response to messages received from the
@@ -35,205 +41,115 @@ class InstantPage : public content::WebContentsObserver {
// we are observing.
class Delegate {
public:
- // Called when a RenderView is created, so that state can be initialized.
- virtual void InstantPageRenderViewCreated(
- const content::WebContents* contents) = 0;
-
- // Called upon determination of Instant API support. Either in response to
- // the page loading or because we received some other message.
- virtual void InstantSupportDetermined(const content::WebContents* contents,
- bool supports_instant) = 0;
-
// Called when the underlying RenderView crashed.
- virtual void InstantPageRenderViewGone(
- const content::WebContents* contents) = 0;
+ virtual void RenderViewGone(const content::WebContents* contents) = 0;
- // Called when the page is about to navigate to |url|.
- virtual void InstantPageAboutToNavigateMainFrame(
- const content::WebContents* contents,
- const GURL& url) = 0;
+ // Called to request the delegate to initialize searchbox state, such as
+ // theme, omnibox font, size, width, margin, Instant preference, etc.
+ virtual void InitSearchBox(const content::WebContents* contents) = 0;
- // Called when the page has suggestions. Usually in response to Update(),
- // SendAutocompleteResults() or UpOrDownKeyPressed().
- virtual void SetSuggestions(
- const content::WebContents* contents,
- const std::vector<InstantSuggestion>& suggestions) = 0;
-
- // Called when the page wants to be shown. Usually in response to Update()
- // or SendAutocompleteResults().
- virtual void ShowInstantOverlay(const content::WebContents* contents,
- InstantShownReason reason,
- int height,
- InstantSizeUnits units) = 0;
-
- // Called when the page wants the omnibox to be focused.
- virtual void FocusOmnibox(const content::WebContents* contents) = 0;
-
- // Called when the page wants the omnibox to start capturing user key
- // strokes. If this call is processed successfully, the omnibox will not
- // look focused visibly but any user key strokes will go to the omnibox.
- // Currently, this is implemented by focusing the omnibox invisibly.
- virtual void StartCapturingKeyStrokes(
+ // Called whem messages are received from the page. See instant_messages.h
+ // for details.
+ virtual void InstantSupportDetermined(
const content::WebContents* contents) = 0;
-
- // Called when the page wants the omnibox to stop capturing user key
- // strokes.
- virtual void StopCapturingKeyStrokes(content::WebContents* contents) = 0;
-
- // Called when the page wants to navigate to |url|. Usually used by the
- // page to navigate to privileged destinations (e.g. chrome:// URLs) or to
- // navigate to URLs that are hidden from the page using Restricted IDs (rid
- // in the API).
+ virtual void SetSuggestion(const content::WebContents* contents,
+ const InstantSuggestion& suggestion) = 0;
virtual void NavigateToURL(const content::WebContents* contents,
const GURL& url,
content::PageTransition transition,
WindowOpenDisposition disposition) = 0;
-
- // Called when the SearchBox wants to delete a Most Visited item.
- virtual void DeleteMostVisitedItem(const GURL& url) = 0;
-
- // Called when the SearchBox wants to undo a Most Visited deletion.
- virtual void UndoMostVisitedDeletion(const GURL& url) = 0;
-
- // Called when the SearchBox wants to undo all Most Visited deletions.
- virtual void UndoAllMostVisitedDeletions() = 0;
+ virtual void ShowOverlay(const content::WebContents* contents,
+ int height,
+ InstantSizeUnits height_units) = 0;
+ virtual void SetFocusState(const content::WebContents* contents,
Jered 2013/03/26 16:36:42 Can we call this SetOmniboxFocusState?
+ OmniboxFocusState focus_state) = 0;
+ virtual void DeleteMostVisitedItem(const content::WebContents* contents,
+ const GURL& url) = 0;
+ virtual void UndoMostVisitedItemDeletion(
+ const content::WebContents* contents,
+ const GURL& url) = 0;
+ virtual void UndoAllMostVisitedItemDeletions(
+ const content::WebContents* contents) = 0;
protected:
virtual ~Delegate();
};
+ InstantPage(Delegate* delegate, InstantService* service);
virtual ~InstantPage();
// The WebContents corresponding to the page we're talking to. May be NULL.
content::WebContents* contents() const { return web_contents(); }
+ // Starts observing / communicating with |contents|. If |contents| is NULL,
+ // effectively stops all communication.
+ void SetContents(content::WebContents* contents);
+
// Returns true if the page is known to support the Instant API. This starts
// out false, and is set to true whenever we get any message from the page.
- // Once true, it never becomes false (the page isn't expected to drop API
- // support suddenly).
+ // Once true, it never becomes false as long as the page doesn't navigate (the
+ // page isn't expected to drop API support suddenly).
bool supports_instant() const { return supports_instant_; }
-
- // Tells the page that the user typed |text| into the omnibox. If |verbatim|
- // is false, the page predicts the query the user means to type and fetches
- // results for the prediction. If |verbatim| is true, |text| is taken as the
- // exact query (no prediction is made).
- virtual void Update(const string16& text,
- size_t selection_start,
- size_t selection_end,
- bool verbatim);
-
- // Tells the page that the user pressed Enter in the omnibox.
- void Submit(const string16& text);
-
- // Tells the page that the user clicked on it. Nothing is being cancelled; the
- // poor choice of name merely reflects the IPC of the same (poor) name.
- void Cancel(const string16& text);
-
- // Tells the page the bounds of the omnibox dropdown (in screen coordinates).
- // This is used by the page to offset the results to avoid them being covered
- // by the omnibox dropdown.
- void SetPopupBounds(const gfx::Rect& bounds);
-
- // Tells the page the bounds of the omnibox (in screen coordinates). This is
- // used by the page to align text or assets properly with the omnibox.
- void SetOmniboxBounds(const gfx::Rect& bounds);
-
- // Tells the page about the font information.
- void InitializeFonts();
-
- // Grant renderer-side chrome-search: access rights for select origins.
- void GrantChromeSearchAccessFromOrigin(const GURL& origin_url);
-
- // Tells the renderer to determine if the page supports the Instant API, which
- // results in a call to InstantSupportDetermined() when the reply is received.
- void DetermineIfPageSupportsInstant();
-
- // Tells the page about the available autocomplete results.
- void SendAutocompleteResults(
+ void set_supports_instant(bool supports_instant) {
+ supports_instant_ = supports_instant;
+ }
+
+ // Returns true if the page has navigated since the last call to Change().
+ bool navigated_after_change() const { return navigated_after_change_; }
+
+ // Sends messages to the page. See instant_messages.h for details.
+ void DetermineInstantSupport();
+ void Change(const string16& query,
+ bool verbatim,
+ size_t selection_start,
+ size_t selection_end);
+ void Submit(const string16& query);
+ void AutocompleteResults(
const std::vector<InstantAutocompleteResult>& results);
-
- // Tells the page that the user pressed Up or Down in the omnibox. |count| is
- // a repeat count, negative for moving up, positive for moving down.
- void UpOrDownKeyPressed(int count);
-
- // Tells the page that the user pressed Esc in the omnibox after having
- // arrowed down in the suggestions. The page should reset the selection to
- // the first suggestion. |user_text| is what the omnibox has been reset to.
- void CancelSelection(const string16& user_text);
-
- // Tells the page about the current theme background.
- void SendThemeBackgroundInfo(const ThemeBackgroundInfo& theme_info);
-
- // Tells the page whether it is allowed to display Instant results.
- void SetDisplayInstantResults(bool display_instant_results);
-
- // Tells the page whether the browser is capturing user key strokes.
+ void Select(int count);
+ void Cancel(const string16& query);
+ void Blur(const string16& query);
+ void PopupBounds(const gfx::Rect& bounds);
+ void OmniboxBounds(const gfx::Rect& bounds);
void KeyCaptureChanged(bool is_key_capture_enabled);
-
- // Tells the page about new Most Visited data.
- void SendMostVisitedItems(const std::vector<MostVisitedItem>& items);
-
- protected:
- explicit InstantPage(Delegate* delegate);
-
- // Sets |contents| as the page to communicate with. |contents| may be NULL,
- // which effectively stops all communication.
- void SetContents(content::WebContents* contents);
-
- Delegate* delegate() const { return delegate_; }
-
- // These functions are called before processing messages received from the
samarth 2013/03/11 19:03:24 I can't see InstantExtendedController yet, but are
- // page. By default, all messages are handled, but any derived classes may
- // choose to ingore some or all of the received messages by overriding these
- // methods.
- virtual bool ShouldProcessRenderViewCreated();
- virtual bool ShouldProcessRenderViewGone();
- virtual bool ShouldProcessAboutToNavigateMainFrame();
- virtual bool ShouldProcessSetSuggestions();
- virtual bool ShouldProcessShowInstantOverlay();
- virtual bool ShouldProcessFocusOmnibox();
- virtual bool ShouldProcessStartCapturingKeyStrokes();
- virtual bool ShouldProcessStopCapturingKeyStrokes();
- virtual bool ShouldProcessNavigateToURL();
+ void DisplayInstantResults(bool display_instant_results);
+ void ThemeChanged(const ThemeBackgroundInfo& theme_info);
+ void FontChanged(const string16& font_name, size_t font_size);
+ void MostVisitedItems(const std::vector<MostVisitedItem>& items);
+ void GrantChromeSearchAccessFromOrigin(const GURL& origin_url);
private:
// Overridden from content::WebContentsObserver:
- virtual void RenderViewCreated(
- content::RenderViewHost* render_view_host) OVERRIDE;
+ virtual void RenderViewGone(base::TerminationStatus status) OVERRIDE;
+ virtual void DidNavigateMainFrame(
+ const content::LoadCommittedDetails& details,
+ const content::FrameNavigateParams& params) OVERRIDE;
virtual void DidFinishLoad(
int64 frame_id,
const GURL& validated_url,
bool is_main_frame,
content::RenderViewHost* render_view_host) OVERRIDE;
virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE;
- virtual void RenderViewGone(base::TerminationStatus status) OVERRIDE;
- virtual void DidCommitProvisionalLoadForFrame(
- int64 frame_id,
- bool is_main_frame,
- const GURL& url,
- content::PageTransition transition_type,
- content::RenderViewHost* render_view_host) OVERRIDE;
- void OnSetSuggestions(int page_id,
- const std::vector<InstantSuggestion>& suggestions);
+ void SendMessage(scoped_ptr<IPC::Message> message);
+
void OnInstantSupportDetermined(int page_id, bool supports_instant);
- void OnShowInstantOverlay(int page_id,
- InstantShownReason reason,
- int height,
- InstantSizeUnits units);
- void OnFocusOmnibox(int page_id);
- void OnStartCapturingKeyStrokes(int page_id);
- void OnStopCapturingKeyStrokes(int page_id);
- void OnSearchBoxNavigate(int page_id,
- const GURL& url,
- content::PageTransition transition,
- WindowOpenDisposition disposition);
- void OnDeleteMostVisitedItem(const GURL& url);
- void OnUndoMostVisitedDeletion(const GURL& url);
- void OnUndoAllMostVisitedDeletions();
+ void OnSetSuggestion(int page_id, const InstantSuggestion& suggestion);
+ void OnNavigateToURL(int page_id,
+ const GURL& url,
+ content::PageTransition transition,
+ WindowOpenDisposition disposition);
+ void OnShowOverlay(int page_id, int height, InstantSizeUnits height_units);
+ void OnSetFocusState(int page_id, OmniboxFocusState focus_state);
+ void OnDeleteMostVisitedItem(int page_id, const GURL& url);
+ void OnUndoMostVisitedItemDeletion(int page_id, const GURL& url);
+ void OnUndoAllMostVisitedItemDeletions(int page_id);
Delegate* const delegate_;
+ InstantService* const service_;
+ int routing_id_;
bool supports_instant_;
+ bool navigated_after_change_;
DISALLOW_COPY_AND_ASSIGN(InstantPage);
};

Powered by Google App Engine
This is Rietveld 408576698