summaryrefslogtreecommitdiffstats
path: root/lldb/source/Interpreter
diff options
context:
space:
mode:
authorJason Molenda <jmolenda@apple.com>2013-09-13 02:33:15 +0000
committerJason Molenda <jmolenda@apple.com>2013-09-13 02:33:15 +0000
commit5c98b1cf8da919511920638bdd6e67609e031dcb (patch)
tree12f4bb21d4f6f00a07d632c1143eed30b5a80fcf /lldb/source/Interpreter
parentcdec0a8ad2eeeb2f854240229203e788e7bc4e7f (diff)
downloadbcm5719-llvm-5c98b1cf8da919511920638bdd6e67609e031dcb.tar.gz
bcm5719-llvm-5c98b1cf8da919511920638bdd6e67609e031dcb.zip
Change OptionValueFileSpec::SetValueFromCString to strip off whitespace,
single-quote and double-quotemarks from around file paths specified to settings like target.expr-prefix or target.process.python-os-plugin-path. <rdar://problem/14970457> llvm-svn: 190654
Diffstat (limited to 'lldb/source/Interpreter')
-rw-r--r--lldb/source/Interpreter/OptionValueFileSpec.cpp15
1 files changed, 14 insertions, 1 deletions
diff --git a/lldb/source/Interpreter/OptionValueFileSpec.cpp b/lldb/source/Interpreter/OptionValueFileSpec.cpp
index e01b0b22577..3d2a7ff3307 100644
--- a/lldb/source/Interpreter/OptionValueFileSpec.cpp
+++ b/lldb/source/Interpreter/OptionValueFileSpec.cpp
@@ -84,8 +84,21 @@ OptionValueFileSpec::SetValueFromCString (const char *value_cstr,
case eVarSetOperationAssign:
if (value_cstr && value_cstr[0])
{
+ // 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(value_cstr, true);
+ m_current_value.SetFile(filepath.c_str(), true);
}
else
{
OpenPOWER on IntegriCloud