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

Side by Side Diff: chrome/browser/extensions/api/dns/dns_api.cc

Issue 10309002: Reimplements net::AddressList without struct addrinfo. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: get_canonical_name -> canonical_name. iterator to indexing Created 8 years, 7 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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 #include "chrome/browser/extensions/api/dns/dns_api.h" 5 #include "chrome/browser/extensions/api/dns/dns_api.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/values.h" 8 #include "base/values.h"
9 #include "chrome/browser/browser_process.h" 9 #include "chrome/browser/browser_process.h"
10 #include "chrome/browser/io_thread.h" 10 #include "chrome/browser/io_thread.h"
11 #include "chrome/common/extensions/api/experimental.dns.h" 11 #include "chrome/common/extensions/api/experimental.dns.h"
12 #include "content/public/browser/browser_thread.h" 12 #include "content/public/browser/browser_thread.h"
13 #include "net/base/host_port_pair.h" 13 #include "net/base/host_port_pair.h"
14 #include "net/base/net_errors.h" 14 #include "net/base/net_errors.h"
15 #include "net/base/net_util.h"
16 15
17 using content::BrowserThread; 16 using content::BrowserThread;
18 using extensions::api::experimental_dns::ResolveCallbackResolveInfo; 17 using extensions::api::experimental_dns::ResolveCallbackResolveInfo;
19 18
20 namespace Resolve = extensions::api::experimental_dns::Resolve; 19 namespace Resolve = extensions::api::experimental_dns::Resolve;
21 20
22 namespace extensions { 21 namespace extensions {
23 22
24 namespace { 23 namespace {
25 24
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
89 void DnsResolveFunction::RespondOnUIThread() { 88 void DnsResolveFunction::RespondOnUIThread() {
90 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 89 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
91 SendResponse(response_); 90 SendResponse(response_);
92 } 91 }
93 92
94 void DnsResolveFunction::OnLookupFinished(int resolve_result) { 93 void DnsResolveFunction::OnLookupFinished(int resolve_result) {
95 scoped_ptr<ResolveCallbackResolveInfo> resolve_info( 94 scoped_ptr<ResolveCallbackResolveInfo> resolve_info(
96 new ResolveCallbackResolveInfo()); 95 new ResolveCallbackResolveInfo());
97 resolve_info->result_code = resolve_result; 96 resolve_info->result_code = resolve_result;
98 if (resolve_result == net::OK) { 97 if (resolve_result == net::OK) {
99 const struct addrinfo* head = addresses_->head(); 98 DCHECK(!addresses_->empty());
100 DCHECK(head);
101 resolve_info->address.reset( 99 resolve_info->address.reset(
102 new std::string(net::NetAddressToString(head))); 100 new std::string(addresses_->front().ToStringWithoutPort()));
103 } 101 }
104 result_.reset(Resolve::Result::Create(*resolve_info)); 102 result_.reset(Resolve::Result::Create(*resolve_info));
105 response_ = true; 103 response_ = true;
106 104
107 bool post_task_result = BrowserThread::PostTask( 105 bool post_task_result = BrowserThread::PostTask(
108 BrowserThread::UI, FROM_HERE, 106 BrowserThread::UI, FROM_HERE,
109 base::Bind(&DnsResolveFunction::RespondOnUIThread, this)); 107 base::Bind(&DnsResolveFunction::RespondOnUIThread, this));
110 DCHECK(post_task_result); 108 DCHECK(post_task_result);
111 109
112 Release(); // Added in WorkOnIOThread(). 110 Release(); // Added in WorkOnIOThread().
113 } 111 }
114 112
115 } // namespace extensions 113 } // namespace extensions
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/web_socket_proxy.cc ('k') | chrome/browser/extensions/api/socket/socket.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698