forked from OSchip/llvm-project
144 lines
4.2 KiB
C++
144 lines
4.2 KiB
C++
//===-- OptionValueString.cpp ---------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/Interpreter/OptionValueString.h"
|
|
|
|
#include "lldb/Host/OptionParser.h"
|
|
#include "lldb/Utility/Args.h"
|
|
#include "lldb/Utility/Stream.h"
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
void OptionValueString::DumpValue(const ExecutionContext *exe_ctx, Stream &strm,
|
|
uint32_t dump_mask) {
|
|
if (dump_mask & eDumpOptionType)
|
|
strm.Printf("(%s)", GetTypeAsCString());
|
|
if (dump_mask & eDumpOptionValue) {
|
|
if (dump_mask & eDumpOptionType)
|
|
strm.PutCString(" = ");
|
|
if (!m_current_value.empty() || m_value_was_set) {
|
|
if (m_options.Test(eOptionEncodeCharacterEscapeSequences)) {
|
|
std::string expanded_escape_value;
|
|
Args::ExpandEscapedCharacters(m_current_value.c_str(),
|
|
expanded_escape_value);
|
|
if (dump_mask & eDumpOptionRaw)
|
|
strm.Printf("%s", expanded_escape_value.c_str());
|
|
else
|
|
strm.Printf("\"%s\"", expanded_escape_value.c_str());
|
|
} else {
|
|
if (dump_mask & eDumpOptionRaw)
|
|
strm.Printf("%s", m_current_value.c_str());
|
|
else
|
|
strm.Printf("\"%s\"", m_current_value.c_str());
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
Status OptionValueString::SetValueFromString(llvm::StringRef value,
|
|
VarSetOperationType op) {
|
|
Status error;
|
|
|
|
std::string value_str = value.str();
|
|
value = value.trim();
|
|
if (value.size() > 0) {
|
|
switch (value.front()) {
|
|
case '"':
|
|
case '\'': {
|
|
if (value.size() <= 1 || value.back() != value.front()) {
|
|
error.SetErrorString("mismatched quotes");
|
|
return error;
|
|
}
|
|
value = value.drop_front().drop_back();
|
|
} break;
|
|
}
|
|
value_str = value.str();
|
|
}
|
|
|
|
switch (op) {
|
|
case eVarSetOperationInvalid:
|
|
case eVarSetOperationInsertBefore:
|
|
case eVarSetOperationInsertAfter:
|
|
case eVarSetOperationRemove:
|
|
if (m_validator) {
|
|
error = m_validator(value_str.c_str(), m_validator_baton);
|
|
if (error.Fail())
|
|
return error;
|
|
}
|
|
error = OptionValue::SetValueFromString(value, op);
|
|
break;
|
|
|
|
case eVarSetOperationAppend: {
|
|
std::string new_value(m_current_value);
|
|
if (value.size() > 0) {
|
|
if (m_options.Test(eOptionEncodeCharacterEscapeSequences)) {
|
|
std::string str;
|
|
Args::EncodeEscapeSequences(value_str.c_str(), str);
|
|
new_value.append(str);
|
|
} else
|
|
new_value.append(std::string(value));
|
|
}
|
|
if (m_validator) {
|
|
error = m_validator(new_value.c_str(), m_validator_baton);
|
|
if (error.Fail())
|
|
return error;
|
|
}
|
|
m_current_value.assign(new_value);
|
|
NotifyValueChanged();
|
|
} break;
|
|
|
|
case eVarSetOperationClear:
|
|
Clear();
|
|
NotifyValueChanged();
|
|
break;
|
|
|
|
case eVarSetOperationReplace:
|
|
case eVarSetOperationAssign:
|
|
if (m_validator) {
|
|
error = m_validator(value_str.c_str(), m_validator_baton);
|
|
if (error.Fail())
|
|
return error;
|
|
}
|
|
m_value_was_set = true;
|
|
if (m_options.Test(eOptionEncodeCharacterEscapeSequences)) {
|
|
Args::EncodeEscapeSequences(value_str.c_str(), m_current_value);
|
|
} else {
|
|
SetCurrentValue(value_str);
|
|
}
|
|
NotifyValueChanged();
|
|
break;
|
|
}
|
|
return error;
|
|
}
|
|
|
|
Status OptionValueString::SetCurrentValue(llvm::StringRef value) {
|
|
if (m_validator) {
|
|
Status error(m_validator(value.str().c_str(), m_validator_baton));
|
|
if (error.Fail())
|
|
return error;
|
|
}
|
|
m_current_value.assign(std::string(value));
|
|
return Status();
|
|
}
|
|
|
|
Status OptionValueString::AppendToCurrentValue(const char *value) {
|
|
if (value && value[0]) {
|
|
if (m_validator) {
|
|
std::string new_value(m_current_value);
|
|
new_value.append(value);
|
|
Status error(m_validator(value, m_validator_baton));
|
|
if (error.Fail())
|
|
return error;
|
|
m_current_value.assign(new_value);
|
|
} else
|
|
m_current_value.append(value);
|
|
}
|
|
return Status();
|
|
}
|