diff options
author | emaste <emaste@FreeBSD.org> | 2015-07-04 01:02:43 +0000 |
---|---|---|
committer | emaste <emaste@FreeBSD.org> | 2015-07-04 01:02:43 +0000 |
commit | cea4c167517a0678c7dbf92a0324088dcbac1035 (patch) | |
tree | 02de7f7c9d5a08ae1c4d3b4c98a565ff96cd52e6 /contrib/llvm/tools/lldb/source/Interpreter/OptionValueFileSpec.cpp | |
parent | 1756896fd2b99ede7ebeb8019d4004bdfeed3bbe (diff) | |
parent | 8037fa4ee916fa20b3c63cbf531f4ee7e1c76138 (diff) | |
download | FreeBSD-src-cea4c167517a0678c7dbf92a0324088dcbac1035.zip FreeBSD-src-cea4c167517a0678c7dbf92a0324088dcbac1035.tar.gz |
Update LLDB snapshot to upstream r241361
Notable upstream commits (upstream revision in parens):
- Add a JSON producer to LLDB (228636)
- Don't crash on bad DWARF expression (228729)
- Add support of DWARFv3 DW_OP_form_tls_address (231342)
- Assembly profiler for MIPS64 (232619)
- Handle FreeBSD/arm64 core files (233273)
- Read/Write register for MIPS64 (233685)
- Rework LLDB system initialization (233758)
- SysV ABI for aarch64 (236098)
- MIPS software single stepping (236696)
- FreeBSD/arm live debugging support (237303)
- Assembly profiler for mips32 (237420)
- Parse function name from DWARF DW_AT_abstract_origin (238307)
- Improve LLDB prompt handling (238313)
- Add real time signals support to FreeBSDSignals (238316)
- Fix race in IOHandlerProcessSTDIO (238423)
- MIPS64 Branch instruction emulation for SW single stepping (238820)
- Improve OSType initialization in elf object file's arch_spec (239148)
- Emulation of MIPS64 floating-point branch instructions (239996)
- ABI Plugin for MIPS32 (239997)
- ABI Plugin for MIPS64 (240123)
- MIPS32 branch emulation and single stepping (240373)
- Improve instruction emulation based stack unwinding on ARM (240533)
- Add branch emulation to aarch64 instruction emulator (240769)
Diffstat (limited to 'contrib/llvm/tools/lldb/source/Interpreter/OptionValueFileSpec.cpp')
-rw-r--r-- | contrib/llvm/tools/lldb/source/Interpreter/OptionValueFileSpec.cpp | 46 |
1 files changed, 25 insertions, 21 deletions
diff --git a/contrib/llvm/tools/lldb/source/Interpreter/OptionValueFileSpec.cpp b/contrib/llvm/tools/lldb/source/Interpreter/OptionValueFileSpec.cpp index 3f46698..3a282f1 100644 --- a/contrib/llvm/tools/lldb/source/Interpreter/OptionValueFileSpec.cpp +++ b/contrib/llvm/tools/lldb/source/Interpreter/OptionValueFileSpec.cpp @@ -7,8 +7,6 @@ // //===----------------------------------------------------------------------===// -#include "lldb/lldb-python.h" - #include "lldb/Interpreter/OptionValueFileSpec.h" // C Includes @@ -24,31 +22,39 @@ using namespace lldb; using namespace lldb_private; -OptionValueFileSpec::OptionValueFileSpec () : +OptionValueFileSpec::OptionValueFileSpec (bool resolve) : OptionValue(), m_current_value (), m_default_value (), m_data_sp(), - m_completion_mask (CommandCompletions::eDiskFileCompletion) + m_data_mod_time (), + m_completion_mask (CommandCompletions::eDiskFileCompletion), + m_resolve (resolve) { } -OptionValueFileSpec::OptionValueFileSpec (const FileSpec &value) : +OptionValueFileSpec::OptionValueFileSpec (const FileSpec &value, + bool resolve) : OptionValue(), m_current_value (value), m_default_value (value), m_data_sp(), - m_completion_mask (CommandCompletions::eDiskFileCompletion) + m_data_mod_time (), + m_completion_mask (CommandCompletions::eDiskFileCompletion), + m_resolve (resolve) { } OptionValueFileSpec::OptionValueFileSpec (const FileSpec ¤t_value, - const FileSpec &default_value) : + const FileSpec &default_value, + bool resolve) : OptionValue(), m_current_value (current_value), m_default_value (default_value), m_data_sp(), - m_completion_mask (CommandCompletions::eDiskFileCompletion) + m_data_mod_time (), + m_completion_mask (CommandCompletions::eDiskFileCompletion), + m_resolve (resolve) { } @@ -70,7 +76,7 @@ OptionValueFileSpec::DumpValue (const ExecutionContext *exe_ctx, Stream &strm, u } Error -OptionValueFileSpec::SetValueFromCString (const char *value_cstr, +OptionValueFileSpec::SetValueFromString (llvm::StringRef value, VarSetOperationType op) { Error error; @@ -83,24 +89,18 @@ OptionValueFileSpec::SetValueFromCString (const char *value_cstr, case eVarSetOperationReplace: case eVarSetOperationAssign: - if (value_cstr && value_cstr[0]) + if (value.size() > 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); - + value = value.trim("\"' \t"); m_value_was_set = true; - m_current_value.SetFile(filepath.c_str(), true); + m_current_value.SetFile(value.str().c_str(), m_resolve); m_data_sp.reset(); + m_data_mod_time.Clear(); NotifyValueChanged(); } else @@ -114,7 +114,7 @@ OptionValueFileSpec::SetValueFromCString (const char *value_cstr, case eVarSetOperationRemove: case eVarSetOperationAppend: case eVarSetOperationInvalid: - error = OptionValue::SetValueFromCString (value_cstr, op); + error = OptionValue::SetValueFromString (value, op); break; } return error; @@ -153,12 +153,16 @@ OptionValueFileSpec::AutoComplete (CommandInterpreter &interpreter, const lldb::DataBufferSP & OptionValueFileSpec::GetFileContents(bool null_terminate) { - if (!m_data_sp && m_current_value) + if (m_current_value) { + const TimeValue file_mod_time = m_current_value.GetModificationTime(); + if (m_data_sp && m_data_mod_time == file_mod_time) + return m_data_sp; if (null_terminate) m_data_sp = m_current_value.ReadFileContentsAsCString(); else m_data_sp = m_current_value.ReadFileContents(); + m_data_mod_time = file_mod_time; } return m_data_sp; } |