diff options
| author | Ed Maste <emaste@FreeBSD.org> | 2013-11-06 16:48:53 +0000 | 
|---|---|---|
| committer | Ed Maste <emaste@FreeBSD.org> | 2013-11-06 16:48:53 +0000 | 
| commit | f21a844f60ae6c74fcf1fddca32461acce3c1ee0 (patch) | |
| tree | 56d79f94966870db1cecd65a7264510a25fd1cba /source/Interpreter/OptionValueFileSpec.cpp | |
| parent | 37d22554be9f5a677dad2a95b7ef22fe59c66a8a (diff) | |
Notes
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 e56b48b5579d..3d2a7ff3307a 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          {  | 
