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

Unified Diff: blimp/client/core/contents/blimp_navigation_controller_impl.h

Issue 2058263002: Tied up BlimpNavigationController to NavigationFeature (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@blimp_core
Patch Set: Moved NavigationFeature to blimp/client/core/contents Created 4 years, 5 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: blimp/client/core/contents/blimp_navigation_controller_impl.h
diff --git a/blimp/client/core/contents/blimp_navigation_controller_impl.h b/blimp/client/core/contents/blimp_navigation_controller_impl.h
index 6ae6fa036877b5371d2c5b36afd7bd74fbd63eb3..9579dd735873d5be94e20ea59350701144f67957 100644
--- a/blimp/client/core/contents/blimp_navigation_controller_impl.h
+++ b/blimp/client/core/contents/blimp_navigation_controller_impl.h
@@ -7,9 +7,12 @@
#include "base/macros.h"
#include "base/memory/weak_ptr.h"
+#include "blimp/client/core/contents/navigation_feature.h"
#include "blimp/client/public/contents/blimp_navigation_controller.h"
#include "url/gurl.h"
+class SkBitmap;
+
namespace blimp {
namespace client {
@@ -21,18 +24,40 @@ class BlimpNavigationControllerDelegate;
// The BlimpNavigationControllerImpl is the implementation part of
// BlimpNavigationController. It maintains the back-forward list for a
// BlimpContentsImpl and manages all navigation within that list.
-class BlimpNavigationControllerImpl : public BlimpNavigationController {
+class BlimpNavigationControllerImpl
+ : public BlimpNavigationController,
+ public NavigationFeature::NavigationFeatureDelegate {
public:
+ // TODO(shaktisahu): Provide NavigationFeature* in the constructor.
Kevin M 2016/07/27 23:35:17 Obsolete comment?
shaktisahu 2016/07/28 19:32:51 Done.
explicit BlimpNavigationControllerImpl(
Kevin M 2016/07/29 21:05:32 "explicit" not used for >1 param ctor
shaktisahu 2016/07/29 22:57:30 Done.
- BlimpNavigationControllerDelegate* delegate);
+ BlimpNavigationControllerDelegate* delegate,
+ NavigationFeature* feature);
Kevin M 2016/07/27 23:35:17 Document the lifetime requirements of |feature| ?
shaktisahu 2016/07/28 19:32:51 Added comments in the variables section. Regarding
Kevin M 2016/07/29 21:05:32 I meant, is it possible that the NavigationControl
shaktisahu 2016/07/29 22:57:30 Possibly not. The |feature| lives in BlimpClientSe
~BlimpNavigationControllerImpl() override;
// BlimpNavigationController implementation.
Kevin M 2016/07/27 23:35:17 Overrides go below non-overrides.
shaktisahu 2016/07/28 19:32:51 Since the only other non-override method is a forT
Kevin M 2016/07/29 21:05:32 Even though it might be a less-important method, t
shaktisahu 2016/07/29 22:57:30 Done.
void LoadURL(const GURL& url) override;
+ void Reload() override;
+ bool CanGoBack() const override;
+ bool CanGoForward() const override;
+ void GoBack() override;
+ void GoForward() override;
+
const GURL& GetURL() override;
+ // For testing only.
Kevin M 2016/07/27 23:35:17 Is this method necessary given that the ctor takes
shaktisahu 2016/07/28 19:32:51 Yes. It is used in blimp_contents_impl_unittest.cc
Kevin M 2016/07/29 21:05:32 Right, but the constructor already takes |feature|
shaktisahu 2016/07/29 22:57:30 Because this object is created inside BlimpContent
Kevin M 2016/08/01 23:41:57 That's true right now, but BlimpContentsImpl can e
shaktisahu 2016/08/02 17:47:52 Sure, that's a good idea. In that case, we are pro
+ void SetNavigationFeatureForTesting(NavigationFeature* feature);
+
private:
- void NotifyDelegateURLLoaded(const GURL& url);
+ // NavigationFeatureDelegate implementation.
+ void OnUrlChanged(int tab_id, const GURL& url) override;
+ void OnFaviconChanged(int tab_id, const SkBitmap& favicon) override;
+ void OnTitleChanged(int tab_id, const std::string& title) override;
+ void OnLoadingChanged(int tab_id, bool loading) override;
+ void OnPageLoadStatusUpdate(int tab_id, bool completed) override;
+
+ // The |navigation_feature_| is responsible for sending and receiving the
+ // navigation state to the server over the proto channel.
+ NavigationFeature* navigation_feature_;
// The delegate contains functionality required for the navigation controller
// to function correctly. It is also invoked on relevant state changes of the
@@ -42,9 +67,6 @@ class BlimpNavigationControllerImpl : public BlimpNavigationController {
// The currently active URL.
GURL current_url_;
- // TODO(shaktisahu): Remove this after integration with NavigationFeature.
- base::WeakPtrFactory<BlimpNavigationControllerImpl> weak_ptr_factory_;
-
DISALLOW_COPY_AND_ASSIGN(BlimpNavigationControllerImpl);
};

Powered by Google App Engine
This is Rietveld 408576698