OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 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 | 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 "mojo/services/catalog/catalog.h" | 5 #include "mojo/services/catalog/catalog.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/strings/string_split.h" | 8 #include "base/strings/string_split.h" |
9 #include "base/task_runner_util.h" | 9 #include "base/task_runner_util.h" |
| 10 #include "base/thread_task_runner_handle.h" |
10 #include "mojo/common/url_type_converters.h" | 11 #include "mojo/common/url_type_converters.h" |
11 #include "mojo/services/catalog/entry.h" | 12 #include "mojo/services/catalog/entry.h" |
12 #include "mojo/services/catalog/store.h" | 13 #include "mojo/services/catalog/store.h" |
13 #include "mojo/shell/public/cpp/names.h" | 14 #include "mojo/shell/public/cpp/names.h" |
14 #include "mojo/util/filename_util.h" | 15 #include "mojo/util/filename_util.h" |
15 #include "url/gurl.h" | 16 #include "url/gurl.h" |
16 #include "url/url_util.h" | 17 #include "url/url_util.h" |
17 | 18 |
18 namespace catalog { | 19 namespace catalog { |
19 | 20 |
20 //////////////////////////////////////////////////////////////////////////////// | 21 //////////////////////////////////////////////////////////////////////////////// |
21 // Catalog, public: | 22 // Catalog, public: |
22 | 23 |
23 Catalog::Catalog(base::TaskRunner* blocking_pool, scoped_ptr<Store> store) | 24 Catalog::Catalog(base::TaskRunner* blocking_pool, |
24 : store_(std::move(store)), | 25 scoped_ptr<Store> store, |
| 26 Delegate* delegate) |
| 27 : delegate_(delegate), |
| 28 store_(std::move(store)), |
25 weak_factory_(this) { | 29 weak_factory_(this) { |
26 PathService::Get(base::DIR_MODULE, &package_path_); | 30 PathService::Get(base::DIR_MODULE, &package_path_); |
27 reader_.reset(new Reader(package_path_, blocking_pool)); | 31 reader_.reset(new Reader(package_path_, blocking_pool)); |
28 DeserializeCatalog(); | 32 DeserializeCatalog(); |
29 } | 33 } |
30 | 34 |
31 Catalog::~Catalog() {} | 35 Catalog::~Catalog() {} |
32 | 36 |
33 void Catalog::BindResolver(mojom::ResolverRequest request) { | 37 void Catalog::BindResolver(mojom::ResolverRequest request) { |
34 resolver_bindings_.AddBinding(this, std::move(request)); | 38 resolver_bindings_.AddBinding(this, std::move(request)); |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
78 resolved_name = alias_iter->second.first; | 82 resolved_name = alias_iter->second.first; |
79 | 83 |
80 std::string qualifier = mojo::GetNamePath(resolved_name); | 84 std::string qualifier = mojo::GetNamePath(resolved_name); |
81 auto qualifier_iter = qualifiers_.find(resolved_name); | 85 auto qualifier_iter = qualifiers_.find(resolved_name); |
82 if (qualifier_iter != qualifiers_.end()) | 86 if (qualifier_iter != qualifiers_.end()) |
83 qualifier = qualifier_iter->second; | 87 qualifier = qualifier_iter->second; |
84 | 88 |
85 if (IsNameInCatalog(resolved_name)) { | 89 if (IsNameInCatalog(resolved_name)) { |
86 CompleteResolveMojoName(resolved_name, qualifier, callback); | 90 CompleteResolveMojoName(resolved_name, qualifier, callback); |
87 } else { | 91 } else { |
88 reader_->Read(resolved_name, | 92 std::string manifest_contents; |
89 base::Bind(&Catalog::OnReadEntry, weak_factory_.GetWeakPtr(), | 93 if (delegate_ && |
90 resolved_name, callback)); | 94 delegate_->GetApplicationManifest(resolved_name, &manifest_contents)) { |
| 95 // We don't invoke the callback synchronously in this case to avoid |
| 96 // surprising the caller with possible re-entry. |
| 97 scoped_ptr<Entry> entry = reader_->Parse(manifest_contents); |
| 98 base::ThreadTaskRunnerHandle::Get()->PostTask( |
| 99 FROM_HERE, |
| 100 base::Bind(&Catalog::OnReadEntry, weak_factory_.GetWeakPtr(), |
| 101 resolved_name, callback, base::Passed(&entry))); |
| 102 } else { |
| 103 reader_->Read( |
| 104 resolved_name, |
| 105 base::Bind(&Catalog::OnReadEntry, weak_factory_.GetWeakPtr(), |
| 106 resolved_name, callback)); |
| 107 } |
91 } | 108 } |
92 } | 109 } |
93 | 110 |
94 //////////////////////////////////////////////////////////////////////////////// | 111 //////////////////////////////////////////////////////////////////////////////// |
95 // Catalog, mojom::Catalog: | 112 // Catalog, mojom::Catalog: |
96 | 113 |
97 void Catalog::GetEntries(mojo::Array<mojo::String> names, | 114 void Catalog::GetEntries(mojo::Array<mojo::String> names, |
98 const GetEntriesCallback& callback) { | 115 const GetEntriesCallback& callback) { |
99 mojo::Map<mojo::String, mojom::CatalogEntryPtr> entries; | 116 mojo::Map<mojo::String, mojom::CatalogEntryPtr> entries; |
100 std::vector<mojo::String> names_vec = names.PassStorage(); | 117 std::vector<mojo::String> names_vec = names.PassStorage(); |
(...skipping 109 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
210 | 227 |
211 SerializeCatalog(); | 228 SerializeCatalog(); |
212 | 229 |
213 auto qualifier_iter = qualifiers_.find(name); | 230 auto qualifier_iter = qualifiers_.find(name); |
214 DCHECK(qualifier_iter != qualifiers_.end()); | 231 DCHECK(qualifier_iter != qualifiers_.end()); |
215 std::string qualifier = qualifier_iter->second; | 232 std::string qualifier = qualifier_iter->second; |
216 CompleteResolveMojoName(name, qualifier, callback); | 233 CompleteResolveMojoName(name, qualifier, callback); |
217 } | 234 } |
218 | 235 |
219 } // namespace catalog | 236 } // namespace catalog |
OLD | NEW |