Index: mandoline/ui/browser/browser.h |
diff --git a/mandoline/ui/browser/browser.h b/mandoline/ui/browser/browser.h |
index 85a2cee6d96f392edca4a7c9203385fd88da71ca..b07f36317505c22194d1737fe70ef3b520720b53 100644 |
--- a/mandoline/ui/browser/browser.h |
+++ b/mandoline/ui/browser/browser.h |
@@ -12,11 +12,13 @@ |
#include "components/window_manager/window_manager_delegate.h" |
#include "mandoline/services/navigation/public/interfaces/navigation.mojom.h" |
#include "mandoline/ui/browser/navigator_host_impl.h" |
+#include "mandoline/ui/browser/omnibox.mojom.h" |
#include "third_party/mojo/src/mojo/public/cpp/application/application_delegate.h" |
#include "third_party/mojo/src/mojo/public/cpp/application/application_impl.h" |
#include "third_party/mojo/src/mojo/public/cpp/application/connect.h" |
#include "third_party/mojo/src/mojo/public/cpp/application/service_provider_impl.h" |
#include "ui/mojo/events/input_events.mojom.h" |
+#include "url/gurl.h" |
namespace mandoline { |
@@ -26,6 +28,7 @@ class MergedServiceProvider; |
class Browser : public mojo::ApplicationDelegate, |
public mojo::ViewManagerDelegate, |
public window_manager::WindowManagerDelegate, |
+ public OmniboxClient, |
public mojo::InterfaceFactory<mojo::NavigatorHost> { |
public: |
Browser(); |
@@ -35,6 +38,11 @@ class Browser : public mojo::ApplicationDelegate, |
void ReplaceContentWithURL(const mojo::String& url); |
+ mojo::View* content() { return content_; } |
+ mojo::View* omnibox() { return omnibox_; } |
+ |
+ const GURL& current_url() const { return current_url_; } |
+ |
private: |
// Overridden from mojo::ApplicationDelegate: |
void Initialize(mojo::ApplicationImpl* app) override; |
@@ -57,16 +65,24 @@ class Browser : public mojo::ApplicationDelegate, |
mojo::KeyboardCode keyboard_code, |
mojo::EventFlags flags) override; |
+ // Overridden from OmniboxClient: |
+ void OpenURL(const mojo::String& url) override; |
+ |
// Overridden from mojo::InterfaceFactory<mojo::NavigatorHost>: |
void Create(mojo::ApplicationConnection* connection, |
mojo::InterfaceRequest<mojo::NavigatorHost> request) override; |
+ void ShowOmnibox(const mojo::String& url, |
+ mojo::InterfaceRequest<mojo::ServiceProvider> services, |
+ mojo::ServiceProviderPtr exposed_services); |
+ |
scoped_ptr<window_manager::WindowManagerApp> window_manager_app_; |
// Only support being embedded once, so both application-level |
// and embedding-level state are shared on the same object. |
mojo::View* root_; |
mojo::View* content_; |
+ mojo::View* omnibox_; |
std::string default_url_; |
std::string pending_url_; |
@@ -75,6 +91,8 @@ class Browser : public mojo::ApplicationDelegate, |
NavigatorHostImpl navigator_host_; |
+ GURL current_url_; |
+ |
scoped_ptr<BrowserUI> ui_; |
base::WeakPtrFactory<Browser> weak_factory_; |