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

Side by Side Diff: components/cronet/android/url_request_context_adapter.h

Issue 617393005: Make URLRequestContextAdapter initialization asynchronous (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Removed mStarted Created 6 years, 2 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 unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef COMPONENTS_CRONET_ANDROID_URL_REQUEST_CONTEXT_ADAPTER_H_ 5 #ifndef COMPONENTS_CRONET_ANDROID_URL_REQUEST_CONTEXT_ADAPTER_H_
6 #define COMPONENTS_CRONET_ANDROID_URL_REQUEST_CONTEXT_ADAPTER_H_ 6 #define COMPONENTS_CRONET_ANDROID_URL_REQUEST_CONTEXT_ADAPTER_H_
7 7
8 #include <queue>
8 #include <string> 9 #include <string>
9 10
11 #include "base/callback.h"
10 #include "base/compiler_specific.h" 12 #include "base/compiler_specific.h"
11 #include "base/macros.h" 13 #include "base/macros.h"
12 #include "base/memory/ref_counted.h" 14 #include "base/memory/ref_counted.h"
13 #include "base/memory/scoped_ptr.h" 15 #include "base/memory/scoped_ptr.h"
14 #include "base/threading/thread.h" 16 #include "base/threading/thread.h"
15 #include "net/base/net_log.h" 17 #include "net/base/net_log.h"
16 #include "net/base/network_change_notifier.h" 18 #include "net/base/network_change_notifier.h"
17 #include "net/url_request/url_request_context.h" 19 #include "net/url_request/url_request_context.h"
18 #include "net/url_request/url_request_context_getter.h" 20 #include "net/url_request/url_request_context_getter.h"
19 21
20 namespace net { 22 namespace net {
21 class NetLogLogger; 23 class NetLogLogger;
22 } // namespace net 24 } // namespace net
23 25
24 namespace cronet { 26 namespace cronet {
25 27
26 struct URLRequestContextConfig; 28 struct URLRequestContextConfig;
29 typedef base::Callback<void()> RunAfterContextInitTask;
27 30
28 // Implementation of the Chromium NetLog observer interface. 31 // Implementation of the Chromium NetLog observer interface.
29 class NetLogObserver : public net::NetLog::ThreadSafeObserver { 32 class NetLogObserver : public net::NetLog::ThreadSafeObserver {
30 public: 33 public:
31 explicit NetLogObserver() {} 34 explicit NetLogObserver() {}
32 35
33 virtual ~NetLogObserver() {} 36 virtual ~NetLogObserver() {}
34 37
35 virtual void OnAddEntry(const net::NetLog::Entry& entry) OVERRIDE; 38 virtual void OnAddEntry(const net::NetLog::Entry& entry) OVERRIDE;
36 39
(...skipping 12 matching lines...) Expand all
49 protected: 52 protected:
50 friend class base::RefCountedThreadSafe<URLRequestContextAdapterDelegate>; 53 friend class base::RefCountedThreadSafe<URLRequestContextAdapterDelegate>;
51 54
52 virtual ~URLRequestContextAdapterDelegate() {} 55 virtual ~URLRequestContextAdapterDelegate() {}
53 }; 56 };
54 57
55 URLRequestContextAdapter(URLRequestContextAdapterDelegate* delegate, 58 URLRequestContextAdapter(URLRequestContextAdapterDelegate* delegate,
56 std::string user_agent); 59 std::string user_agent);
57 void Initialize(scoped_ptr<URLRequestContextConfig> config); 60 void Initialize(scoped_ptr<URLRequestContextConfig> config);
58 61
62 // Runs a task that might depend on context being initialized.
63 void RunTask(const RunAfterContextInitTask& callback);
mmenke 2014/10/02 22:11:52 Maybe RunTaskAfterContextInit? It's a bit unwield
xunjieli 2014/10/03 14:32:55 Done.
64 void RunTaskOnNetworkThread(const RunAfterContextInitTask& callback);
65
59 const std::string& GetUserAgent(const GURL& url) const; 66 const std::string& GetUserAgent(const GURL& url) const;
60 67
61 // net::URLRequestContextGetter implementation: 68 // net::URLRequestContextGetter implementation:
62 virtual net::URLRequestContext* GetURLRequestContext() OVERRIDE; 69 virtual net::URLRequestContext* GetURLRequestContext() OVERRIDE;
63 virtual scoped_refptr<base::SingleThreadTaskRunner> GetNetworkTaskRunner() 70 virtual scoped_refptr<base::SingleThreadTaskRunner> GetNetworkTaskRunner()
64 const OVERRIDE; 71 const OVERRIDE;
65 72
66 void StartNetLogToFile(const std::string& file_name); 73 void StartNetLogToFile(const std::string& file_name);
67 void StopNetLog(); 74 void StopNetLog();
68 75
69 private: 76 private:
70 scoped_refptr<URLRequestContextAdapterDelegate> delegate_; 77 scoped_refptr<URLRequestContextAdapterDelegate> delegate_;
71 scoped_ptr<net::URLRequestContext> context_; 78 scoped_ptr<net::URLRequestContext> context_;
72 std::string user_agent_; 79 std::string user_agent_;
73 base::Thread* network_thread_; 80 base::Thread* network_thread_;
74 scoped_ptr<net::NetworkChangeNotifier> network_change_notifier_; 81 scoped_ptr<net::NetworkChangeNotifier> network_change_notifier_;
75 scoped_ptr<NetLogObserver> net_log_observer_; 82 scoped_ptr<NetLogObserver> net_log_observer_;
76 scoped_ptr<net::NetLogLogger> net_log_logger_; 83 scoped_ptr<net::NetLogLogger> net_log_logger_;
77 84
85 // A queue of tasks that need to be run after context has been initialized.
86 std::queue<RunAfterContextInitTask> tasks_waiting_for_context_;
87 bool is_context_initialized_;
88
78 virtual ~URLRequestContextAdapter(); 89 virtual ~URLRequestContextAdapter();
79 90
80 // Initializes |context_| on the Network thread. 91 // Initializes |context_| on the Network thread.
81 void InitializeURLRequestContext(scoped_ptr<URLRequestContextConfig> config); 92 void InitializeURLRequestContext(scoped_ptr<URLRequestContextConfig> config);
82 93
83 DISALLOW_COPY_AND_ASSIGN(URLRequestContextAdapter); 94 DISALLOW_COPY_AND_ASSIGN(URLRequestContextAdapter);
84 }; 95 };
85 96
86 } // namespace cronet 97 } // namespace cronet
87 98
88 #endif // COMPONENTS_CRONET_ANDROID_URL_REQUEST_CONTEXT_ADAPTER_H_ 99 #endif // COMPONENTS_CRONET_ANDROID_URL_REQUEST_CONTEXT_ADAPTER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698