diff options
author | thestig@chromium.org <thestig@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-09 20:37:56 +0000 |
---|---|---|
committer | thestig@chromium.org <thestig@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-09 20:37:56 +0000 |
commit | 8f681e432845de60b648960e4d1cec404a844581 (patch) | |
tree | 8cb6f2a9aaf2b463476a241f9e7c8ec9cdc59646 /base | |
parent | 59a3b8cd0edc83cf7e0590df7665867c79694f98 (diff) | |
download | chromium_src-8f681e432845de60b648960e4d1cec404a844581.zip chromium_src-8f681e432845de60b648960e4d1cec404a844581.tar.gz chromium_src-8f681e432845de60b648960e4d1cec404a844581.tar.bz2 |
Add a FilePath version of the CommandLine constructor. Mark the wstring version as deprecated.
BUG=none
TEST=none
Review URL: http://codereview.chromium.org/271031
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@28590 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base')
-rw-r--r-- | base/command_line.cc | 17 | ||||
-rw-r--r-- | base/command_line.h | 5 |
2 files changed, 20 insertions, 2 deletions
diff --git a/base/command_line.cc b/base/command_line.cc index 04c1ece..0104f3b 100644 --- a/base/command_line.cc +++ b/base/command_line.cc @@ -14,6 +14,7 @@ #include <algorithm> +#include "base/file_path.h" #include "base/logging.h" #include "base/singleton.h" #include "base/string_piece.h" @@ -92,6 +93,15 @@ void CommandLine::ParseFromString(const std::wstring& command_line) { if (args) LocalFree(args); } + +CommandLine::CommandLine(const FilePath& program) { + if (!program.empty()) { + program_ = program.value(); + command_line_string_ = L'"' + program.value() + L'"'; + } +} + +// Deprecated version CommandLine::CommandLine(const std::wstring& program) { if (!program.empty()) { program_ = program; @@ -134,6 +144,11 @@ void CommandLine::InitFromArgv() { } } +CommandLine::CommandLine(const FilePath& program) { + argv_.push_back(program.value()); +} + +// Deprecated version CommandLine::CommandLine(const std::wstring& program) { argv_.push_back(base::SysWideToNativeMB(program)); } @@ -275,7 +290,7 @@ std::vector<std::wstring> CommandLine::GetLooseValues() const { return values; } std::wstring CommandLine::program() const { - DCHECK(argv_.size() > 0); + DCHECK_GT(argv_.size(), 0U); return base::SysNativeMBToWide(argv_[0]); } #endif diff --git a/base/command_line.h b/base/command_line.h index 78f3862..c6aae86 100644 --- a/base/command_line.h +++ b/base/command_line.h @@ -26,6 +26,7 @@ #include "base/basictypes.h" #include "base/logging.h" +class FilePath; class InProcessBrowserTest; class CommandLine { @@ -42,7 +43,9 @@ class CommandLine { // Construct a new, empty command line. // |program| is the name of the program to run (aka argv[0]). - // TODO(port): should be a FilePath. + explicit CommandLine(const FilePath& program); + + // Deprecated in favor of FilePath version. explicit CommandLine(const std::wstring& program); // Uninit and free the current process's command line. |