OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/runner/context.h" | 5 #include "mojo/runner/context.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
126 // 'parameters' key on the intent, which we specify during 'am shell start' | 126 // 'parameters' key on the intent, which we specify during 'am shell start' |
127 // via --esa, however that expects comma-separated values and says: | 127 // via --esa, however that expects comma-separated values and says: |
128 // am shell --help: | 128 // am shell --help: |
129 // [--esa <EXTRA_KEY> <EXTRA_STRING_VALUE>[,<EXTRA_STRING_VALUE...]] | 129 // [--esa <EXTRA_KEY> <EXTRA_STRING_VALUE>[,<EXTRA_STRING_VALUE...]] |
130 // (to embed a comma into a string escape it using "\,") | 130 // (to embed a comma into a string escape it using "\,") |
131 // Whatever takes 'parameters' and constructs a CommandLine is failing to | 131 // Whatever takes 'parameters' and constructs a CommandLine is failing to |
132 // un-escape the commas, we need to move this fix to that file. | 132 // un-escape the commas, we need to move this fix to that file. |
133 base::ReplaceSubstringsAfterOffset(&handlers_spec, 0, "\\,", ","); | 133 base::ReplaceSubstringsAfterOffset(&handlers_spec, 0, "\\,", ","); |
134 #endif | 134 #endif |
135 | 135 |
136 std::vector<std::string> parts; | 136 std::vector<std::string> parts = base::SplitString( |
137 base::SplitString(handlers_spec, ',', &parts); | 137 handlers_spec, ",", base::TRIM_WHITESPACE, base::SPLIT_WANT_ALL); |
138 if (parts.size() % 2 != 0) { | 138 if (parts.size() % 2 != 0) { |
139 LOG(ERROR) << "Invalid value for switch " << switches::kContentHandlers | 139 LOG(ERROR) << "Invalid value for switch " << switches::kContentHandlers |
140 << ": must be a comma-separated list of mimetype/url pairs." | 140 << ": must be a comma-separated list of mimetype/url pairs." |
141 << handlers_spec; | 141 << handlers_spec; |
142 return; | 142 return; |
143 } | 143 } |
144 | 144 |
145 for (size_t i = 0; i < parts.size(); i += 2) { | 145 for (size_t i = 0; i < parts.size(); i += 2) { |
146 GURL url(parts[i + 1]); | 146 GURL url(parts[i + 1]); |
147 if (!url.is_valid()) { | 147 if (!url.is_valid()) { |
148 LOG(ERROR) << "Invalid value for switch " << switches::kContentHandlers | 148 LOG(ERROR) << "Invalid value for switch " << switches::kContentHandlers |
149 << ": '" << parts[i + 1] << "' is not a valid URL."; | 149 << ": '" << parts[i + 1] << "' is not a valid URL."; |
150 return; | 150 return; |
151 } | 151 } |
152 // TODO(eseidel): We should also validate that the mimetype is valid | 152 // TODO(eseidel): We should also validate that the mimetype is valid |
153 // net/base/mime_util.h could do this, but we don't want to depend on net. | 153 // net/base/mime_util.h could do this, but we don't want to depend on net. |
154 manager->RegisterContentHandler(parts[i], url); | 154 manager->RegisterContentHandler(parts[i], url); |
155 } | 155 } |
156 } | 156 } |
157 | 157 |
158 void InitNativeOptions(shell::ApplicationManager* manager, | 158 void InitNativeOptions(shell::ApplicationManager* manager, |
159 const base::CommandLine& command_line) { | 159 const base::CommandLine& command_line) { |
160 std::vector<std::string> force_in_process_url_list; | 160 std::vector<std::string> force_in_process_url_list = base::SplitString( |
161 base::SplitString(command_line.GetSwitchValueASCII(switches::kForceInProcess), | 161 command_line.GetSwitchValueASCII(switches::kForceInProcess), ",", |
162 ',', &force_in_process_url_list); | 162 base::TRIM_WHITESPACE, base::SPLIT_WANT_ALL); |
163 for (const auto& force_in_process_url : force_in_process_url_list) { | 163 for (const auto& force_in_process_url : force_in_process_url_list) { |
164 GURL gurl(force_in_process_url); | 164 GURL gurl(force_in_process_url); |
165 if (!gurl.is_valid()) { | 165 if (!gurl.is_valid()) { |
166 LOG(ERROR) << "Invalid value for switch " << switches::kForceInProcess | 166 LOG(ERROR) << "Invalid value for switch " << switches::kForceInProcess |
167 << ": '" << force_in_process_url << "'is not a valid URL."; | 167 << ": '" << force_in_process_url << "'is not a valid URL."; |
168 return; | 168 return; |
169 } | 169 } |
170 | 170 |
171 shell::NativeRunnerFactory::Options options; | 171 shell::NativeRunnerFactory::Options options; |
172 options.force_in_process = true; | 172 options.force_in_process = true; |
(...skipping 218 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
391 base::MessageLoop::current()->Quit(); | 391 base::MessageLoop::current()->Quit(); |
392 } else { | 392 } else { |
393 app_complete_callback_.Run(); | 393 app_complete_callback_.Run(); |
394 } | 394 } |
395 } | 395 } |
396 } | 396 } |
397 } | 397 } |
398 | 398 |
399 } // namespace runner | 399 } // namespace runner |
400 } // namespace mojo | 400 } // namespace mojo |
OLD | NEW |