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

Unified Diff: services/video_capture/device_factory_media_to_mojo_adapter.h

Issue 2824883005: [Mojo Video Capture] Stop service when last client disconnects. (Closed)
Patch Set: Incorporate suggestions from PatchSet #4 Created 3 years, 8 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
« no previous file with comments | « services/video_capture/BUILD.gn ('k') | services/video_capture/device_factory_media_to_mojo_adapter.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: services/video_capture/device_factory_media_to_mojo_adapter.h
diff --git a/services/video_capture/device_factory_media_to_mojo_adapter.h b/services/video_capture/device_factory_media_to_mojo_adapter.h
index 6c10ff70dfd4359be006234ae1f5406d1b39a182..e3ae55eaf4df7177320729fa9012ac9d1c97e2f8 100644
--- a/services/video_capture/device_factory_media_to_mojo_adapter.h
+++ b/services/video_capture/device_factory_media_to_mojo_adapter.h
@@ -10,6 +10,7 @@
#include "media/capture/video/video_capture_device_client.h"
#include "media/capture/video/video_capture_system.h"
#include "mojo/public/cpp/bindings/binding.h"
+#include "services/service_manager/public/cpp/service_context_ref.h"
#include "services/video_capture/public/interfaces/device_factory.mojom.h"
namespace video_capture {
@@ -23,12 +24,13 @@ class DeviceMediaToMojoAdapter;
class DeviceFactoryMediaToMojoAdapter : public mojom::DeviceFactory {
public:
DeviceFactoryMediaToMojoAdapter(
+ std::unique_ptr<service_manager::ServiceContextRef> service_ref,
std::unique_ptr<media::VideoCaptureSystem> capture_system,
const media::VideoCaptureJpegDecoderFactoryCB&
jpeg_decoder_factory_callback);
~DeviceFactoryMediaToMojoAdapter() override;
- // mojom::DeviceFactory:
+ // mojom::DeviceFactory implementation.
void GetDeviceInfos(const GetDeviceInfosCallback& callback) override;
void CreateDevice(const std::string& device_id,
mojom::DeviceRequest device_request,
@@ -48,11 +50,20 @@ class DeviceFactoryMediaToMojoAdapter : public mojom::DeviceFactory {
std::unique_ptr<mojo::Binding<mojom::Device>> binding;
};
+ void CreateAndAddNewDevice(const std::string& device_id,
+ mojom::DeviceRequest device_request,
+ const CreateDeviceCallback& callback);
void OnClientConnectionErrorOrClose(const std::string& device_id);
+ const std::unique_ptr<service_manager::ServiceContextRef> service_ref_;
const std::unique_ptr<media::VideoCaptureSystem> capture_system_;
const media::VideoCaptureJpegDecoderFactoryCB jpeg_decoder_factory_callback_;
std::map<std::string, ActiveDeviceEntry> active_devices_by_id_;
+ bool has_called_get_device_infos_;
+
+ base::WeakPtrFactory<DeviceFactoryMediaToMojoAdapter> weak_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(DeviceFactoryMediaToMojoAdapter);
};
} // namespace video_capture
« no previous file with comments | « services/video_capture/BUILD.gn ('k') | services/video_capture/device_factory_media_to_mojo_adapter.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698