
This patch adds new SBDebugger::GetSetting() API which enables client to access settings as SBStructedData. Implementation wise, a new ToJSON() virtual function is added to OptionValue class so that each concrete child class can override and provides its own JSON representation. This patch aims to define the APIs and implement a common set of OptionValue child classes, leaving the remaining for future patches. This patch is used later by auto deduce source map from source line breakpoint feature for testing generated source map entries. Differential Revision: https://reviews.llvm.org/D133038
76 lines
2.6 KiB
C++
76 lines
2.6 KiB
C++
//===-- OptionValueLanguage.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/OptionValueLanguage.h"
|
|
|
|
#include "lldb/DataFormatters/FormatManager.h"
|
|
#include "lldb/Target/Language.h"
|
|
#include "lldb/Symbol/TypeSystem.h"
|
|
#include "lldb/Utility/Args.h"
|
|
#include "lldb/Utility/Stream.h"
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
void OptionValueLanguage::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 != eLanguageTypeUnknown)
|
|
strm.PutCString(Language::GetNameForLanguageType(m_current_value));
|
|
}
|
|
}
|
|
|
|
llvm::json::Value OptionValueLanguage::ToJSON(const ExecutionContext *exe_ctx) {
|
|
return Language::GetNameForLanguageType(m_current_value);
|
|
}
|
|
|
|
Status OptionValueLanguage::SetValueFromString(llvm::StringRef value,
|
|
VarSetOperationType op) {
|
|
Status error;
|
|
switch (op) {
|
|
case eVarSetOperationClear:
|
|
Clear();
|
|
break;
|
|
|
|
case eVarSetOperationReplace:
|
|
case eVarSetOperationAssign: {
|
|
ConstString lang_name(value.trim());
|
|
LanguageSet languages_for_types = Language::GetLanguagesSupportingTypeSystems();
|
|
LanguageType new_type =
|
|
Language::GetLanguageTypeFromString(lang_name.GetStringRef());
|
|
if (new_type && languages_for_types[new_type]) {
|
|
m_value_was_set = true;
|
|
m_current_value = new_type;
|
|
} else {
|
|
StreamString error_strm;
|
|
error_strm.Printf("invalid language type '%s', ", value.str().c_str());
|
|
error_strm.Printf("valid values are:\n");
|
|
for (int bit : languages_for_types.bitvector.set_bits()) {
|
|
auto language = (LanguageType)bit;
|
|
error_strm.Printf(" %s\n",
|
|
Language::GetNameForLanguageType(language));
|
|
}
|
|
error.SetErrorString(error_strm.GetString());
|
|
}
|
|
} break;
|
|
|
|
case eVarSetOperationInsertBefore:
|
|
case eVarSetOperationInsertAfter:
|
|
case eVarSetOperationRemove:
|
|
case eVarSetOperationAppend:
|
|
case eVarSetOperationInvalid:
|
|
error = OptionValue::SetValueFromString(value, op);
|
|
break;
|
|
}
|
|
return error;
|
|
}
|