| // 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_ |