| 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_;
|
|
|