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

Unified Diff: chrome/browser/ui/toolbar/toolbar_model_impl.h

Issue 11040055: Adds a FakeToolbarModel for use in testing. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: git try Created 8 years, 2 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
« no previous file with comments | « chrome/browser/ui/toolbar/toolbar_model.cc ('k') | chrome/browser/ui/toolbar/toolbar_model_impl.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/toolbar/toolbar_model_impl.h
diff --git a/chrome/browser/ui/toolbar/toolbar_model_impl.h b/chrome/browser/ui/toolbar/toolbar_model_impl.h
new file mode 100644
index 0000000000000000000000000000000000000000..e65efc33f7e217eceb528dc259ea695586f80d9c
--- /dev/null
+++ b/chrome/browser/ui/toolbar/toolbar_model_impl.h
@@ -0,0 +1,72 @@
+// Copyright 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CHROME_BROWSER_UI_TOOLBAR_TOOLBAR_MODEL_IMPL_H_
+#define CHROME_BROWSER_UI_TOOLBAR_TOOLBAR_MODEL_IMPL_H_
+
+#include <string>
+
+#include "base/basictypes.h"
+#include "base/compiler_specific.h"
+#include "base/string16.h"
+#include "chrome/browser/ui/toolbar/toolbar_model.h"
+#include "googleurl/src/gurl.h"
+
+class Profile;
+class ToolbarModelDelegate;
+
+namespace content {
+class NavigationController;
+}
+
+namespace net {
+class X509Certificate;
+}
+
+// This class is the model used by the toolbar, location bar and autocomplete
+// edit. It populates its states from the current navigation entry retrieved
+// from the navigation controller returned by GetNavigationController().
+class ToolbarModelImpl : public ToolbarModel {
+ public:
+ explicit ToolbarModelImpl(ToolbarModelDelegate* delegate);
+ virtual ~ToolbarModelImpl();
+
+ // Overriden from ToolbarModel.
+ virtual string16 GetText(
+ bool display_search_urls_as_search_terms) const OVERRIDE;
+ virtual GURL GetURL() const OVERRIDE;
+ virtual bool WouldReplaceSearchURLWithSearchTerms() const OVERRIDE;
+ virtual SecurityLevel GetSecurityLevel() const OVERRIDE;
+ virtual int GetIcon() const OVERRIDE;
+ virtual string16 GetEVCertName() const OVERRIDE;
+ virtual bool ShouldDisplayURL() const OVERRIDE;
+ virtual void SetInputInProgress(bool value) OVERRIDE;
+ virtual bool GetInputInProgress() const OVERRIDE;
+
+ // Returns "<organization_name> [<country>]".
+ static string16 GetEVCertName(const net::X509Certificate& cert);
+
+ private:
+ // Returns the navigation controller used to retrieve the navigation entry
+ // from which the states are retrieved.
+ // If this returns NULL, default values are used.
+ content::NavigationController* GetNavigationController() const;
+
+ // Attempt to extract search terms from |url|. Called by GetText if
+ // |display_search_urls_as_search_terms| is true and by
+ // WouldReplaceSearchURLWithSearchTerms.
+ string16 TryToExtractSearchTermsFromURL(const GURL& url) const;
+
+ // Helper method to extract the profile from the navigation controller.
+ Profile* GetProfile() const;
+
+ ToolbarModelDelegate* delegate_;
+
+ // Whether the text in the location bar is currently being edited.
+ bool input_in_progress_;
+
+ DISALLOW_IMPLICIT_CONSTRUCTORS(ToolbarModelImpl);
+};
+
+#endif // CHROME_BROWSER_UI_TOOLBAR_TOOLBAR_MODEL_IMPL_H_
« no previous file with comments | « chrome/browser/ui/toolbar/toolbar_model.cc ('k') | chrome/browser/ui/toolbar/toolbar_model_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698