Index: net/dns/host_resolver_impl.h |
diff --git a/net/dns/host_resolver_impl.h b/net/dns/host_resolver_impl.h |
index 9ab01ca03ea1a6d3ea4a828249d546537a127f4f..d67b553b2aabcac1f52571ba32cfac0545e098b8 100644 |
--- a/net/dns/host_resolver_impl.h |
+++ b/net/dns/host_resolver_impl.h |
@@ -16,6 +16,7 @@ |
#include "base/strings/string_piece.h" |
#include "base/threading/non_thread_safe.h" |
#include "base/time/time.h" |
+#include "base/timer/timer.h" |
#include "net/base/net_export.h" |
#include "net/base/network_change_notifier.h" |
#include "net/dns/host_cache.h" |
@@ -156,6 +157,10 @@ class NET_EXPORT HostResolverImpl |
HostCache::EntryStaleness* stale_info, |
const BoundNetLog& source_net_log); |
+ void InitializePersistence( |
+ const PersistCallback& persist_callback, |
+ std::unique_ptr<const base::Value> old_data) override; |
+ |
void set_proc_params_for_test(const ProcTaskParams& proc_params) { |
proc_params_ = proc_params; |
} |
@@ -297,6 +302,12 @@ class NET_EXPORT HostResolverImpl |
// and resulted in |net_error|. |
void OnDnsTaskResolve(int net_error); |
+ void SchedulePersist(); |
+ void DoPersist(); |
+ |
+ void ApplyPersistentData(std::unique_ptr<const base::Value>); |
+ std::unique_ptr<const base::Value> GetPersistentData(); |
+ |
// Allows the tests to catch slots leaking out of the dispatcher. One |
// HostResolverImpl::Job could occupy multiple PrioritizedDispatcher job |
// slots. |
@@ -353,6 +364,10 @@ class NET_EXPORT HostResolverImpl |
// tasks, but can be overridden for tests. |
scoped_refptr<base::TaskRunner> worker_task_runner_; |
+ bool persist_initialized_; |
+ PersistCallback persist_callback_; |
+ base::OneShotTimer persist_timer_; |
+ |
base::WeakPtrFactory<HostResolverImpl> weak_ptr_factory_; |
base::WeakPtrFactory<HostResolverImpl> probe_weak_ptr_factory_; |