summaryrefslogtreecommitdiffstats
path: root/base
diff options
context:
space:
mode:
authorevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-12 22:50:39 +0000
committerevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-12 22:50:39 +0000
commit0189bbd4cc569eaec4c6664109659c32fed8e4b7 (patch)
treef792f823d15a1e806d1b25d0f6d318622db6daf4 /base
parent079487b08bf7867eb7c078b59dec61f142a42df2 (diff)
downloadchromium_src-0189bbd4cc569eaec4c6664109659c32fed8e4b7.zip
chromium_src-0189bbd4cc569eaec4c6664109659c32fed8e4b7.tar.gz
chromium_src-0189bbd4cc569eaec4c6664109659c32fed8e4b7.tar.bz2
CommandLine: rejigger how initialization works.
I'm attempting to clean up CommandLine. This change rearranges how initialization is done. I am trying to eliminate redundant functions; more will come in subsequent changes. Review URL: http://codereview.chromium.org/273018 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@28752 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base')
-rw-r--r--base/command_line.cc24
-rw-r--r--base/command_line.h32
2 files changed, 26 insertions, 30 deletions
diff --git a/base/command_line.cc b/base/command_line.cc
index ac8402cb..84fa415 100644
--- a/base/command_line.cc
+++ b/base/command_line.cc
@@ -109,17 +109,14 @@ CommandLine::CommandLine(const std::wstring& program) {
}
}
#elif defined(OS_POSIX)
-CommandLine::CommandLine(int argc, const char* const* argv) {
+void CommandLine::InitFromArgv(int argc, const char* const* argv) {
for (int i = 0; i < argc; ++i)
argv_.push_back(argv[i]);
- InitFromArgv();
-}
-CommandLine::CommandLine(const std::vector<std::string>& argv) {
- argv_ = argv;
- InitFromArgv();
+ InitFromArgv(argv_);
}
-void CommandLine::InitFromArgv() {
+void CommandLine::InitFromArgv(const std::vector<std::string>& argv) {
+ argv_ = argv;
bool parse_switches = true;
for (size_t i = 1; i < argv_.size(); ++i) {
const std::string& arg = argv_[i];
@@ -192,22 +189,11 @@ bool CommandLine::IsSwitch(const StringType& parameter_string,
// static
void CommandLine::Init(int argc, const char* const* argv) {
-#if defined(OS_WIN)
current_process_commandline_ = new CommandLine;
- current_process_commandline_->ParseFromString(::GetCommandLineW());
-#elif defined(OS_POSIX)
- current_process_commandline_ = new CommandLine(argc, argv);
-#endif
-}
-
-// static
-void CommandLine::Init(const std::vector<std::string>& argv) {
- DCHECK(current_process_commandline_ == NULL);
#if defined(OS_WIN)
- current_process_commandline_ = new CommandLine;
current_process_commandline_->ParseFromString(::GetCommandLineW());
#elif defined(OS_POSIX)
- current_process_commandline_ = new CommandLine(argv);
+ current_process_commandline_->InitFromArgv(argc, argv);
#endif
}
diff --git a/base/command_line.h b/base/command_line.h
index 3eb3dbb..6b7d1f4 100644
--- a/base/command_line.h
+++ b/base/command_line.h
@@ -24,21 +24,28 @@
#include <vector>
#include "base/basictypes.h"
+#include "base/file_path.h"
#include "base/logging.h"
-class FilePath;
class InProcessBrowserTest;
class CommandLine {
public:
#if defined(OS_WIN)
- // Creates a parsed version of the given command-line string.
+ // Initialize by parsing the given command-line string.
// The program name is assumed to be the first item in the string.
void ParseFromString(const std::wstring& command_line);
#elif defined(OS_POSIX)
- // Initialize from an argv vector (or directly from main()'s argv).
- CommandLine(int argc, const char* const* argv);
- explicit CommandLine(const std::vector<std::string>& argv);
+ // Initialize from an argv vector.
+ void InitFromArgv(int argc, const char* const* argv);
+ void InitFromArgv(const std::vector<std::string>& argv);
+
+ CommandLine(int argc, const char* const* argv) {
+ InitFromArgv(argc, argv);
+ }
+ explicit CommandLine(const std::vector<std::string>& argv) {
+ InitFromArgv(argv);
+ }
#endif
// Construct a new, empty command line.
@@ -53,7 +60,6 @@ class CommandLine {
// directly) because we don't trust the CRT's parsing of the command
// line, but it still must be called to set up the command line.
static void Init(int argc, const char* const* argv);
- static void Init(const std::vector<std::string>& argv);
#if defined(OS_LINUX) || defined(OS_FREEBSD)
// Sets the current process' arguments that show in "ps" etc. to those
@@ -76,8 +82,9 @@ class CommandLine {
static void Terminate() { Reset(); }
// Get the singleton CommandLine representing the current process's
- // command line.
- static const CommandLine* ForCurrentProcess() {
+ // command line. Note: returned value is mutable, but not thread safe;
+ // only mutate if you know what you're doing!
+ static CommandLine* ForCurrentProcess() {
DCHECK(current_process_commandline_);
return current_process_commandline_;
}
@@ -111,6 +118,12 @@ class CommandLine {
#endif
// Returns the program part of the command line string (the first item).
+ FilePath GetProgram() const {
+ return FilePath::FromWStringHack(program());
+ }
+
+ // Returns the program part of the command line string (the first item).
+ // Deprecated version of the above.
std::wstring program() const;
// Return a copy of the string prefixed with a switch prefix.
@@ -178,9 +191,6 @@ class CommandLine {
// The type of native command line arguments.
typedef std::string StringType;
-
- // Shared by the two POSIX constructor forms. Initalize from argv_.
- void InitFromArgv();
#endif
// Returns true and fills in |switch_string| and |switch_value|