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

Side by Side Diff: chrome/browser/net/chrome_http_user_agent_settings.cc

Issue 10918279: Provide mutable members of UrlRequestContext via pure-virtual interface (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Address mmenke's comments Created 8 years, 1 month 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/net/chrome_http_user_agent_settings.h"
6
7 #include "chrome/browser/prefs/pref_service.h"
8 #include "chrome/common/pref_names.h"
9 #include "content/public/browser/browser_thread.h"
10 #include "content/public/common/content_client.h"
11 #include "net/http/http_util.h"
12
13 ChromeHttpUserAgentSettings::ChromeHttpUserAgentSettings(PrefService* prefs) {
14 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
15 pref_accept_language_.Init(prefs::kAcceptLanguages, prefs, NULL);
16 pref_accept_charset_.Init(prefs::kDefaultCharset, prefs, NULL);
17 last_pref_accept_language_ = *pref_accept_language_;
18 last_http_accept_language_ =
19 net::HttpUtil::GenerateAcceptLanguageHeader(last_pref_accept_language_);
20 last_pref_accept_charset_ = *pref_accept_charset_;
21 last_http_accept_charset_ =
22 net::HttpUtil::GenerateAcceptCharsetHeader(last_pref_accept_charset_);
23 pref_accept_language_.MoveToThread(content::BrowserThread::IO);
24 pref_accept_charset_.MoveToThread(content::BrowserThread::IO);
25 }
26
27 ChromeHttpUserAgentSettings::~ChromeHttpUserAgentSettings() {
28 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO));
29 }
30
31 void ChromeHttpUserAgentSettings::CleanupOnUIThread() {
32 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
erikwright (departed) 2012/10/26 21:10:46 Is there any kind of guarantee that GetAcceptLangu
pauljensen 2012/10/26 22:04:14 No.
33 pref_accept_language_.Destroy();
34 pref_accept_charset_.Destroy();
35 }
36
37 std::string ChromeHttpUserAgentSettings::GetAcceptLanguage() const {
38 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO));
39 std::string new_pref_accept_language = *pref_accept_language_;
40 if (new_pref_accept_language != last_pref_accept_language_) {
41 last_http_accept_language_ =
42 net::HttpUtil::GenerateAcceptLanguageHeader(new_pref_accept_language);
43 last_pref_accept_language_ = new_pref_accept_language;
44 }
45 return last_http_accept_language_;
46 }
47
48 std::string ChromeHttpUserAgentSettings::GetAcceptCharset() const {
49 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO));
50 std::string new_pref_accept_charset = *pref_accept_charset_;
51 if (new_pref_accept_charset != last_pref_accept_charset_) {
52 last_http_accept_charset_ =
53 net::HttpUtil::GenerateAcceptCharsetHeader(new_pref_accept_charset);
54 last_pref_accept_charset_ = new_pref_accept_charset;
55 }
56 return last_http_accept_charset_;
57 }
58
59 std::string ChromeHttpUserAgentSettings::GetUserAgent(const GURL& url) const {
60 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO));
61 return content::GetUserAgent(url);
62 }
63
OLDNEW
« no previous file with comments | « chrome/browser/net/chrome_http_user_agent_settings.h ('k') | chrome/browser/net/chrome_url_request_context.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698