Index: content/browser/background_sync/background_sync_context_impl.h |
diff --git a/content/browser/background_sync/background_sync_context_impl.h b/content/browser/background_sync/background_sync_context_impl.h |
index 861b6d2a3fdff982d94bb572d404cd6794eabfcc..52dfdc9691c6ac92be1d9b2c6c90e482a6449719 100644 |
--- a/content/browser/background_sync/background_sync_context_impl.h |
+++ b/content/browser/background_sync/background_sync_context_impl.h |
@@ -5,14 +5,18 @@ |
#ifndef CONTENT_BROWSER_BACKGROUND_SYNC_BACKGROUND_SYNC_CONTEXT_IMPL_H_ |
#define CONTENT_BROWSER_BACKGROUND_SYNC_BACKGROUND_SYNC_CONTEXT_IMPL_H_ |
+#include <set> |
+ |
#include "base/memory/ref_counted.h" |
#include "base/memory/scoped_ptr.h" |
+#include "content/common/background_sync_service.mojom.h" |
#include "content/common/content_export.h" |
#include "content/public/browser/background_sync_context.h" |
namespace content { |
class BackgroundSyncManager; |
+class BackgroundSyncServiceImpl; |
class ServiceWorkerContextWrapper; |
// Implements the BackgroundSyncContext. One instance of this exists per |
@@ -26,9 +30,19 @@ class CONTENT_EXPORT BackgroundSyncContextImpl : public BackgroundSyncContext { |
// Init and Shutdown are for use on the UI thread when the |
// StoragePartition is being setup and torn down. |
void Init(const scoped_refptr<ServiceWorkerContextWrapper>& context); |
+ |
+ // Shutdown must be called before deleting this. Call on the UI thread. |
void Shutdown(); |
- // Only callable on the IO thread. |
+ // Create a BackgroundSyncServiceImpl that is owned by this. Call on the UI |
+ // thread. |
+ void CreateService(mojo::InterfaceRequest<BackgroundSyncService> request); |
+ |
+ // Called by BackgroundSyncServciceImpl objects so that they can |
+ // be deleted. Call on the IO thread. |
+ void ServiceHadConnectionError(BackgroundSyncServiceImpl* service); |
+ |
+ // Call on the IO thread. |
BackgroundSyncManager* background_sync_manager() const override; |
protected: |
@@ -38,11 +52,19 @@ class CONTENT_EXPORT BackgroundSyncContextImpl : public BackgroundSyncContext { |
void CreateBackgroundSyncManager( |
const scoped_refptr<ServiceWorkerContextWrapper>& context); |
+ void CreateServiceOnIOThread( |
+ mojo::InterfaceRequest<BackgroundSyncService> request); |
+ |
void ShutdownOnIO(); |
// Only accessed on the IO thread. |
scoped_ptr<BackgroundSyncManager> background_sync_manager_; |
+ // The services are owned by this. They're either deleted |
+ // during ShutdownOnIO or when the channel is closed via |
+ // ServiceHadConnectionError. Only accessed on the IO thread. |
+ std::set<BackgroundSyncServiceImpl*> services_; |
+ |
DISALLOW_COPY_AND_ASSIGN(BackgroundSyncContextImpl); |
}; |