| // Copyright (c) 2017 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. | 
 |  | 
 | #ifndef NET_DISK_CACHE_BACKEND_CLEANUP_TRACKER_H_ | 
 | #define NET_DISK_CACHE_BACKEND_CLEANUP_TRACKER_H_ | 
 |  | 
 | #include <utility> | 
 | #include <vector> | 
 |  | 
 | #include "base/callback.h" | 
 | #include "base/files/file_path.h" | 
 | #include "base/memory/ref_counted.h" | 
 | #include "base/sequence_checker.h" | 
 | #include "net/base/net_export.h" | 
 |  | 
 | namespace base { | 
 | class SequencedTaskRunner; | 
 | }  // namespace base | 
 |  | 
 | namespace disk_cache { | 
 |  | 
 | // Internal helper used to sequence cleanup and reuse of cache directories. | 
 | // One of these is created before each backend, and is kept alive till both | 
 | // the backend is destroyed and all of its work is done by its refcount, | 
 | // which keeps track of outstanding work. That refcount is expected to only be | 
 | // updated from the I/O thread or its equivalent. | 
 | class NET_EXPORT_PRIVATE BackendCleanupTracker | 
 |     : public base::RefCounted<BackendCleanupTracker> { | 
 |  public: | 
 |   // Either returns a fresh cleanup tracker for |path| if none exists, or | 
 |   // will eventually post |retry_closure| to the calling thread, | 
 |   // and return null. | 
 |   static scoped_refptr<BackendCleanupTracker> TryCreate( | 
 |       const base::FilePath& path, | 
 |       base::OnceClosure retry_closure); | 
 |  | 
 |   // Register a callback to be posted after all the work of associated | 
 |   // context is complete (which will result in destruction of this context). | 
 |   // Should only be called by owner, on its I/O-thread-like execution context, | 
 |   // and will in turn eventually post |cb| there. | 
 |   void AddPostCleanupCallback(base::OnceClosure cb); | 
 |  | 
 |  private: | 
 |   friend class base::RefCounted<BackendCleanupTracker>; | 
 |   explicit BackendCleanupTracker(const base::FilePath& path); | 
 |   ~BackendCleanupTracker(); | 
 |  | 
 |   void AddPostCleanupCallbackImpl(base::OnceClosure cb); | 
 |  | 
 |   base::FilePath path_; | 
 |  | 
 |   // Since it's possible that a different thread may want to create a | 
 |   // cache for a reused path, we keep track of runners contexts of | 
 |   // post-cleanup callbacks. | 
 |   std::vector< | 
 |       std::pair<scoped_refptr<base::SequencedTaskRunner>, base::OnceClosure>> | 
 |       post_cleanup_cbs_; | 
 |  | 
 |   // We expect only TryMakeContext to be multithreaded, everything | 
 |   // else should be sequenced. | 
 |   SEQUENCE_CHECKER(seq_checker_); | 
 |  | 
 |   DISALLOW_COPY_AND_ASSIGN(BackendCleanupTracker); | 
 | }; | 
 |  | 
 | }  // namespace disk_cache | 
 |  | 
 | #endif  // NET_DISK_CACHE_BACKEND_CLEANUP_TRACKER_H_ |