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

Side by Side Diff: content/browser/loader/url_loader_factory_impl.cc

Issue 1970693002: Use mojo for Chrome Loading, Part 1 (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 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
OLDNEW
(Empty)
1 // Copyright 2016 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 "content/browser/loader/url_loader_factory_impl.h"
6
7 #include <memory>
8
9 #include "base/memory/ptr_util.h"
10 #include "base/memory/weak_ptr.h"
11 #include "content/browser/loader/resource_dispatcher_host_impl.h"
12 #include "content/browser/loader/resource_message_filter.h"
13 #include "content/common/resource_messages.h"
14 #include "content/common/resource_request.h"
15 #include "content/common/url_loader.mojom.h"
16
17 namespace content {
18
19 namespace {
20
21 // This class is an implementation of mojom::URLLoader which is a resource
22 // loader interface with Mojo.
23 class URLLoaderImpl final : public mojom::URLLoader {
24 public:
25 // Creates a URLLoader. This function returns nothing and registers the
26 // created instance to the ResourceDispatcherHostImpl instead.
27 static void Create(scoped_refptr<ResourceMessageFilter> filter,
28 mojom::URLLoaderRequest request) {
29 int child_id = filter->child_id();
30 ResourceDispatcherHostImpl::Get()->AddUninitiatedURLLoader(
mmenke 2016/05/25 16:17:20 "Uninitiated" seems like a more ambiguous term for
yhirano 2016/05/26 15:42:44 Done.
31 child_id,
32 base::WrapUnique(new URLLoaderImpl(filter.get(), std::move(request))));
mmenke 2016/05/25 16:17:20 This ownership model seems really weird and non-ob
yhirano 2016/05/26 15:42:44 URLLoaderImpl uses mojo::Binding[1]. mojo::Binding
33 }
34
35 ~URLLoaderImpl() override {}
36
37 void Load(int32_t request_id,
38 const ResourceRequest& request,
39 mojom::URLLoaderClientPtr client) override {
40 DCHECK_CURRENTLY_ON(BrowserThread::IO);
41
42 ResourceMessageFilter* filter = resource_message_filter_.get();
43 if (!filter) {
44 // TODO(yhirano): Cancel the request.
45 return;
46 }
47
48 std::unique_ptr<mojom::URLLoader> that =
49 ResourceDispatcherHostImpl::Get()->TakeUninitiatedURLLoader(this);
50 DCHECK(that);
51
52 // TODO(yhirano): Provide the right routing ID.
53 const int routing_id = 0;
54 ResourceDispatcherHostImpl* rdh = ResourceDispatcherHostImpl::Get();
55 rdh->OnRequestResourceWithMojo(routing_id, request_id, request,
56 std::move(that), std::move(client), filter);
57 }
58 void FollowRedirect() override {}
59 void Cancel() override {}
60
61 private:
62 URLLoaderImpl(ResourceMessageFilter* filter,
63 mojo::InterfaceRequest<mojom::URLLoader> request)
64 : resource_message_filter_(filter->GetWeakPtr()),
65 binding_(this, std::move(request)) {}
66
67 base::WeakPtr<ResourceMessageFilter> resource_message_filter_;
68 mojo::Binding<mojom::URLLoader> binding_;
69 };
70
71 } // namespace
72
73 URLLoaderFactoryImpl::URLLoaderFactoryImpl(
74 scoped_refptr<ResourceMessageFilter> resource_message_filter,
75 mojo::InterfaceRequest<mojom::URLLoaderFactory> request)
76 : resource_message_filter_(resource_message_filter),
77 binding_(this, std::move(request)) {}
78
79 URLLoaderFactoryImpl::~URLLoaderFactoryImpl() {
80 DCHECK_CURRENTLY_ON(BrowserThread::UI);
81 }
82
83 void URLLoaderFactoryImpl::CreateURLLoader(mojom::URLLoaderRequest request) {
84 BrowserThread::PostTask(
85 BrowserThread::IO, FROM_HERE,
86 base::Bind(&URLLoaderImpl::Create, resource_message_filter_,
87 base::Passed(std::move(request))));
88 }
89
90 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698