diff options
author | emaste <emaste@FreeBSD.org> | 2013-11-06 16:48:53 +0000 |
---|---|---|
committer | emaste <emaste@FreeBSD.org> | 2013-11-06 16:48:53 +0000 |
commit | c727fe695d28799acb499e9961f11ec07d4f9fe2 (patch) | |
tree | 56d79f94966870db1cecd65a7264510a25fd1cba /source/Interpreter/OptionValueFileSpec.cpp | |
parent | 2e8c9206a971efee1b77ad2ae852265d6f4ecaa0 (diff) | |
download | FreeBSD-src-c727fe695d28799acb499e9961f11ec07d4f9fe2.zip FreeBSD-src-c727fe695d28799acb499e9961f11ec07d4f9fe2.tar.gz |
Import lldb as of SVN r194122
Sponsored by: DARPA, AFRL
Diffstat (limited to 'source/Interpreter/OptionValueFileSpec.cpp')
-rw-r--r-- | source/Interpreter/OptionValueFileSpec.cpp | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/source/Interpreter/OptionValueFileSpec.cpp b/source/Interpreter/OptionValueFileSpec.cpp index e56b48b..3d2a7ff 100644 --- a/source/Interpreter/OptionValueFileSpec.cpp +++ b/source/Interpreter/OptionValueFileSpec.cpp @@ -84,17 +84,21 @@ OptionValueFileSpec::SetValueFromCString (const char *value_cstr, case eVarSetOperationAssign: if (value_cstr && value_cstr[0]) { - Args args(value_cstr); - if (args.GetArgumentCount() == 1) - { - const char *path = args.GetArgumentAtIndex(0); - m_value_was_set = true; - m_current_value.SetFile(path, true); - } - else - { - error.SetErrorString("please supply a single path argument for this file or quote the path if it contains spaces"); - } + // The setting value may have whitespace, double-quotes, or single-quotes around the file + // path to indicate that internal spaces are not word breaks. Strip off any ws & quotes + // from the start and end of the file path - we aren't doing any word // breaking here so + // the quoting is unnecessary. NB this will cause a problem if someone tries to specify + // a file path that legitimately begins or ends with a " or ' character, or whitespace. + std::string filepath(value_cstr); + auto prefix_chars_to_trim = filepath.find_first_not_of ("\"' \t"); + if (prefix_chars_to_trim != std::string::npos && prefix_chars_to_trim > 0) + filepath.erase(0, prefix_chars_to_trim); + auto suffix_chars_to_trim = filepath.find_last_not_of ("\"' \t"); + if (suffix_chars_to_trim != std::string::npos && suffix_chars_to_trim < filepath.size()) + filepath.erase (suffix_chars_to_trim + 1); + + m_value_was_set = true; + m_current_value.SetFile(filepath.c_str(), true); } else { |