Index: services/video_capture/service_manager_service_impl.h |
diff --git a/services/video_capture/service_manager_service_impl.h b/services/video_capture/service_manager_service_impl.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..24cbbb1d9033b27bb952f39e78e2aee8fed6ee9c |
--- /dev/null |
+++ b/services/video_capture/service_manager_service_impl.h |
@@ -0,0 +1,47 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
mcasas
2017/04/26 22:12:31
s/2016/2017/
chfremer
2017/04/26 23:33:36
Done.
|
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef SERVICES_VIDEO_CAPTURE_SERVICE_MANAGER_SERVICE_IMPL_H_ |
+#define SERVICES_VIDEO_CAPTURE_SERVICE_MANAGER_SERVICE_IMPL_H_ |
+ |
+#include <memory> |
+ |
+#include "mojo/public/cpp/bindings/binding_set.h" |
+#include "services/service_manager/public/cpp/binder_registry.h" |
+#include "services/service_manager/public/cpp/interface_factory.h" |
+#include "services/service_manager/public/cpp/service.h" |
+#include "services/service_manager/public/cpp/service_context_ref.h" |
+#include "services/video_capture/public/interfaces/service.mojom.h" |
+ |
+namespace video_capture { |
+ |
+class ServiceManagerServiceImpl : public service_manager::Service { |
Ken Rockot(use gerrit already)
2017/04/26 19:40:19
nit: Hmm, is this rename really necessary?
chfremer
2017/04/26 20:01:54
Hmm, not absolutely necessary, but I feel it is us
mcasas
2017/04/26 22:12:31
namespace disambiguates, right?
video_capture::Ser
chfremer
2017/04/26 23:33:36
Yes, to me too, but unfortunately both classes liv
|
+ public: |
+ ServiceManagerServiceImpl(); |
+ ~ServiceManagerServiceImpl() override; |
+ |
+ // service_manager::Service: |
mcasas
2017/04/26 22:12:31
// service_manager::Service implementation.
chfremer
2017/04/26 23:33:36
Done.
|
+ void OnStart() override; |
+ void OnBindInterface(const service_manager::ServiceInfo& source_info, |
+ const std::string& interface_name, |
+ mojo::ScopedMessagePipeHandle interface_pipe) override; |
+ bool OnServiceManagerConnectionLost() override; |
+ |
+ private: |
+ void OnVideoCaptureServiceRequest(mojom::ServiceRequest request); |
+ void SetShutdownDelayInSeconds(float seconds); |
+ void MaybeRequestQuitDelayed(); |
+ void MaybeRequestQuit(); |
+ |
+ float shutdown_delay_in_seconds_; |
+ service_manager::BinderRegistry registry_; |
+ std::unique_ptr<service_manager::ServiceContextRefFactory> ref_factory_; |
+ base::WeakPtrFactory<ServiceManagerServiceImpl> weak_factory_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(ServiceManagerServiceImpl); |
+}; |
+ |
+} // namespace video_capture |
+ |
+#endif // SERVICES_VIDEO_CAPTURE_SERVICE_MANAGER_SERVICE_IMPL_H_ |