Index: mojo/services/kiosk_wm/merged_service_provider.cc |
diff --git a/mojo/services/kiosk_wm/merged_service_provider.cc b/mojo/services/kiosk_wm/merged_service_provider.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..8987096dfbfa6d8f247d24e8707b24931a03ceba |
--- /dev/null |
+++ b/mojo/services/kiosk_wm/merged_service_provider.cc |
@@ -0,0 +1,35 @@ |
+// Copyright 2015 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. |
+ |
+#include "mojo/services/kiosk_wm/merged_service_provider.h" |
+ |
+namespace kiosk_wm { |
+ |
+MergedServiceProvider::MergedServiceProvider( |
+ mojo::ServiceProviderPtr exposed_services, |
+ mojo::InterfaceFactory<mojo::NavigatorHost>* factory) |
+ : exposed_services_(exposed_services.Pass()), factory_(factory) { |
+} |
+ |
+MergedServiceProvider::~MergedServiceProvider() { |
+} |
+ |
+mojo::ServiceProviderPtr MergedServiceProvider::GetServiceProviderPtr() { |
+ mojo::ServiceProviderPtr sp; |
+ binding_.reset(new mojo::Binding<mojo::ServiceProvider>(this, GetProxy(&sp))); |
+ return sp.Pass(); |
+} |
+ |
+void MergedServiceProvider::ConnectToService( |
+ const mojo::String& interface_name, |
+ mojo::ScopedMessagePipeHandle pipe) { |
+ if (interface_name == mojo::NavigatorHost::Name_) { |
+ factory_->Create(nullptr, |
+ mojo::MakeRequest<mojo::NavigatorHost>(pipe.Pass())); |
+ } else if (exposed_services_.get()) { |
+ exposed_services_->ConnectToService(interface_name, pipe.Pass()); |
+ } |
+} |
+ |
+} // namespace kiosk_wm |