Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "base/command_line.h" | 5 #include "base/command_line.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <ostream> | 8 #include <ostream> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| (...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 86 switch_value); | 86 switch_value); |
| 87 #elif defined(OS_POSIX) | 87 #elif defined(OS_POSIX) |
| 88 command_line->AppendSwitchNative(switch_string, switch_value); | 88 command_line->AppendSwitchNative(switch_string, switch_value); |
| 89 #endif | 89 #endif |
| 90 } else { | 90 } else { |
| 91 command_line->AppendArgNative(arg); | 91 command_line->AppendArgNative(arg); |
| 92 } | 92 } |
| 93 } | 93 } |
| 94 } | 94 } |
| 95 | 95 |
| 96 bool ContainsUpperASCII(const char* string) { | |
| 97 for (; *string; ++string) { | |
| 98 if (*string >= 'A' && *string <= 'Z') | |
| 99 return true; | |
| 100 } | |
| 101 return false; | |
| 102 } | |
| 103 | |
| 96 // Lowercase switches for backwards compatiblity *on Windows*. | 104 // Lowercase switches for backwards compatiblity *on Windows*. |
| 97 #if defined(OS_WIN) | 105 #if defined(OS_WIN) |
| 98 std::string LowerASCIIOnWindows(const std::string& string) { | 106 std::string LowerASCIIOnWindows(const std::string& string) { |
| 99 return StringToLowerASCII(string); | 107 return StringToLowerASCII(string); |
| 100 } | 108 } |
| 101 #elif defined(OS_POSIX) | 109 #elif defined(OS_POSIX) |
| 102 const std::string& LowerASCIIOnWindows(const std::string& string) { | 110 const std::string& LowerASCIIOnWindows(const std::string& string) { |
| 103 return string; | 111 return string; |
| 104 } | 112 } |
| 105 #endif | 113 #endif |
| (...skipping 149 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 255 } | 263 } |
| 256 | 264 |
| 257 FilePath CommandLine::GetProgram() const { | 265 FilePath CommandLine::GetProgram() const { |
| 258 return FilePath(argv_[0]); | 266 return FilePath(argv_[0]); |
| 259 } | 267 } |
| 260 | 268 |
| 261 void CommandLine::SetProgram(const FilePath& program) { | 269 void CommandLine::SetProgram(const FilePath& program) { |
| 262 TrimWhitespace(program.value(), TRIM_ALL, &argv_[0]); | 270 TrimWhitespace(program.value(), TRIM_ALL, &argv_[0]); |
| 263 } | 271 } |
| 264 | 272 |
| 265 bool CommandLine::HasSwitch(const std::string& switch_string) const { | 273 bool CommandLine::HasSwitch(const std::string& switch_string) const { |
|
tapted
2015/04/02 01:46:14
How many times is the std::string version called n
jackhou1
2015/04/02 04:51:51
Agreed. 1% of calls.
| |
| 266 return switches_.find(LowerASCIIOnWindows(switch_string)) != switches_.end(); | 274 #if defined(OS_WIN) |
| 275 if (ContainsUpperASCII(switch_string.c_str())) | |
| 276 return switches_.find(LowerASCIIOnWindows(switch_string)) != | |
| 277 switches_.end(); | |
| 278 #endif | |
| 279 | |
| 280 return switches_.find(switch_string) != switches_.end(); | |
| 267 } | 281 } |
| 268 | 282 |
| 269 bool CommandLine::HasSwitch(const char string_constant[]) const { | 283 bool CommandLine::HasSwitch(const char string_constant[]) const { |
| 270 return HasSwitch(std::string(string_constant)); | 284 DCHECK(!ContainsUpperASCII(string_constant)); |
|
tapted
2015/04/02 01:46:14
I think we can avoid the extra function with somet
jackhou1
2015/04/02 04:51:51
Done.
| |
| 285 return switches_.find(std::string(string_constant)) != switches_.end(); | |
|
tapted
2015/04/02 01:46:15
is the std::string(..) still needed?
jackhou1
2015/04/02 04:51:51
Nope, but the one in the DEBUG_EQ is.
| |
| 271 } | 286 } |
| 272 | 287 |
| 273 std::string CommandLine::GetSwitchValueASCII( | 288 std::string CommandLine::GetSwitchValueASCII( |
| 274 const std::string& switch_string) const { | 289 const std::string& switch_string) const { |
| 275 StringType value = GetSwitchValueNative(switch_string); | 290 StringType value = GetSwitchValueNative(switch_string); |
| 276 if (!IsStringASCII(value)) { | 291 if (!IsStringASCII(value)) { |
| 277 DLOG(WARNING) << "Value of switch (" << switch_string << ") must be ASCII."; | 292 DLOG(WARNING) << "Value of switch (" << switch_string << ") must be ASCII."; |
| 278 return std::string(); | 293 return std::string(); |
| 279 } | 294 } |
| 280 #if defined(OS_WIN) | 295 #if defined(OS_WIN) |
| 281 return UTF16ToASCII(value); | 296 return UTF16ToASCII(value); |
| 282 #else | 297 #else |
| 283 return value; | 298 return value; |
| 284 #endif | 299 #endif |
| 285 } | 300 } |
| 286 | 301 |
| 287 FilePath CommandLine::GetSwitchValuePath( | 302 FilePath CommandLine::GetSwitchValuePath( |
| 288 const std::string& switch_string) const { | 303 const std::string& switch_string) const { |
| 289 return FilePath(GetSwitchValueNative(switch_string)); | 304 return FilePath(GetSwitchValueNative(switch_string)); |
| 290 } | 305 } |
| 291 | 306 |
| 292 CommandLine::StringType CommandLine::GetSwitchValueNative( | 307 CommandLine::StringType CommandLine::GetSwitchValueNative( |
| 293 const std::string& switch_string) const { | 308 const std::string& switch_string) const { |
| 294 SwitchMap::const_iterator result = | 309 #if defined(OS_WIN) |
|
tapted
2015/04/02 01:46:14
I think we should defer this until there's a char[
jackhou1
2015/04/02 04:51:51
This method is about 9% of lookups during startup,
| |
| 295 switches_.find(LowerASCIIOnWindows(switch_string)); | 310 if (ContainsUpperASCII(switch_string.c_str())) { |
| 311 SwitchMap::const_iterator result = | |
| 312 switches_.find(LowerASCIIOnWindows(switch_string)); | |
| 313 return result == switches_.end() ? StringType() : result->second; | |
| 314 } | |
| 315 #endif | |
| 316 | |
| 317 SwitchMap::const_iterator result = switches_.find(switch_string); | |
| 296 return result == switches_.end() ? StringType() : result->second; | 318 return result == switches_.end() ? StringType() : result->second; |
| 297 } | 319 } |
| 298 | 320 |
| 299 void CommandLine::AppendSwitch(const std::string& switch_string) { | 321 void CommandLine::AppendSwitch(const std::string& switch_string) { |
| 300 AppendSwitchNative(switch_string, StringType()); | 322 AppendSwitchNative(switch_string, StringType()); |
| 301 } | 323 } |
| 302 | 324 |
| 303 void CommandLine::AppendSwitchPath(const std::string& switch_string, | 325 void CommandLine::AppendSwitchPath(const std::string& switch_string, |
| 304 const FilePath& path) { | 326 const FilePath& path) { |
| 305 AppendSwitchNative(switch_string, path.value()); | 327 AppendSwitchNative(switch_string, path.value()); |
| (...skipping 140 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 446 #if defined(OS_WIN) | 468 #if defined(OS_WIN) |
| 447 arg = QuoteForCommandLineToArgvW(arg, quote_placeholders); | 469 arg = QuoteForCommandLineToArgvW(arg, quote_placeholders); |
| 448 #endif | 470 #endif |
| 449 params.append(arg); | 471 params.append(arg); |
| 450 } | 472 } |
| 451 } | 473 } |
| 452 return params; | 474 return params; |
| 453 } | 475 } |
| 454 | 476 |
| 455 } // namespace base | 477 } // namespace base |
| OLD | NEW |