22#include "llvm/ADT/StringRef.h"
23#include "llvm/Support/FormatAdapters.h"
33 const std::string &
message, uint32_t loc,
35 : ErrorInfo(make_error_code(std::errc::invalid_argument)) {
37 FileSpec{}, 1,
static_cast<uint16_t
>(loc + 1),
38 err_len,
false,
true};
46 auto msg = llvm::formatv(
"<user expression>:1:{0}: {1}\n 1 | {2}\n |",
48 std::string rendered_str;
49 llvm::raw_string_ostream rendered_os(rendered_str);
50 rendered_os << msg.str();
51 rendered_os << llvm::indent(loc + 1) <<
"^";
54 rendered_os << std::string(err_len - 1,
'~');
59 m_detail.rendered = std::move(rendered_str);
62llvm::Expected<lldb::TypeSystemSP>
65 ctx->GetSymbolContext(lldb::eSymbolContextCompUnit);
68 symbol_context = ctx->GetSymbolContext(lldb::eSymbolContextModule);
69 return symbol_context.
module_sp->GetTypeSystemForLanguage(language);
76 llvm::StringRef name_ref(name);
78 if (name_ref.starts_with(
"::"))
79 name_ref = name_ref.drop_front(2);
81 std::vector<CompilerType> result_type_list;
83 if (!name_ref.empty() && target_sp) {
86 TypeQueryOptions::e_find_one};
88 images.
FindTypes(
nullptr, query, results);
91 result_type_list.push_back(type_sp->GetFullCompilerType());
94 if (!result_type_list.empty()) {
105 std::shared_ptr<StackFrame> frame_sp,
108 llvm::Error
error = llvm::Error::success();
109 DILParser parser(dil_input_expr, lexer, frame_sp, use_dynamic,
error, mode);
112 assert(node_up &&
"ASTNodeUP must not contain a nullptr");
121 std::shared_ptr<StackFrame> frame_sp,
150 assert(lhs &&
"ASTNodeUP must not contain a nullptr");
156 assert(rhs &&
"ASTNodeUP must not contain a nullptr");
157 lhs = std::make_unique<BinaryOpNode>(
159 std::move(lhs), std::move(rhs));
178 BailOut(
"binary multiplication (*) is allowed only in DIL full mode",
180 return std::make_unique<ErrorNode>();
184 assert(rhs &&
"ASTNodeUP must not contain a nullptr");
185 lhs = std::make_unique<BinaryOpNode>(
187 std::move(lhs), std::move(rhs));
211 uint32_t save_token_idx =
m_dil_lexer.GetCurrentTokenIdx();
223 if (!type_id.value().IsValid())
224 return std::make_unique<ErrorNode>();
229 assert(rhs &&
"ASTNodeUP must not contain a nullptr");
230 return std::make_unique<CastNode>(loc, type_id.value(), std::move(rhs),
260 assert(rhs &&
"ASTNodeUP must not contain a nullptr");
275 llvm_unreachable(
"invalid token kind");
292 assert(lhs &&
"ASTNodeUP must not contain a nullptr");
300 assert(index &&
"ASTNodeUP must not contain a nullptr");
304 assert(last_index &&
"ASTNodeUP must not contain a nullptr");
305 lhs = std::make_unique<BitFieldExtractionNode>(
306 loc, std::move(lhs), std::move(index), std::move(last_index));
308 BailOut(
"use of '-' for bitfield range is deprecated; use ':' instead",
310 return std::make_unique<ErrorNode>();
312 lhs = std::make_unique<ArraySubscriptNode>(loc, std::move(lhs),
324 lhs = std::make_unique<MemberOfNode>(
330 llvm_unreachable(
"invalid token");
356 if (!identifier.empty())
357 return std::make_unique<IdentifierNode>(loc, identifier);
370 return std::make_unique<ErrorNode>();
394 (
m_dil_lexer.LookAhead(1).GetSpelling() ==
"anonymous") &&
396 (
m_dil_lexer.LookAhead(2).GetSpelling() ==
"namespace") &&
404 BailOut(
"Expected an identifier or anonymous namespace, but not found.",
410 return "(anonymous namespace)::" + identifier2;
450 if (maybe_builtin_type) {
451 type = *maybe_builtin_type;
455 std::string type_name;
458 if (type_name.empty())
480 std::vector<Token> ptr_operators;
483 ptr_operators.push_back(std::move(tok));
502 std::string type_name =
"";
503 uint32_t save_token_idx =
m_dil_lexer.GetCurrentTokenIdx();
504 bool first_word =
true;
506 if (
CurToken().GetSpelling() ==
"const" ||
507 CurToken().GetSpelling() ==
"volatile")
510 type_name.push_back(
' ');
513 type_name.append(
CurToken().GetSpelling());
517 if (type_name.size() > 0) {
520 for (
auto type_system_sp : target_sp->GetScratchTypeSystems())
521 if (
auto compiler_type =
522 type_system_sp->GetBuiltinTypeByName(const_type_name))
523 return compiler_type;
540 type_name = *err_or_string;
556 bool global_scope =
false;
567 if (!type_name_or_err)
568 return type_name_or_err;
569 std::string type_name = *type_name_or_err;
574 if (!type_name.empty())
576 return llvm::formatv(
"{0}{1}{2}", global_scope ?
"::" :
"",
577 nested_name_specifier, type_name);
627 bool global_scope =
false;
638 if (!nested_name_specifier.empty()) {
642 return llvm::formatv(
"{0}{1}{2}", global_scope ?
"::" :
"",
643 nested_name_specifier, unqualified_id);
655 return llvm::formatv(
"{0}{1}", global_scope ?
"::" :
"", identifier);
679 const std::vector<Token> &ptr_operators) {
681 for (
Token tk : ptr_operators) {
682 uint32_t loc = tk.GetLocation();
686 BailOut(llvm::formatv(
"'type name' declared as a pointer to a "
687 "reference of type {0}",
689 loc,
CurToken().GetSpelling().length());
699 BailOut(
"type name declared as a reference to a reference", loc,
722 return std::make_unique<BooleanLiteralNode>(loc, literal_value);
751 BailOut(llvm::formatv(
"Failed to parse token as numeric-constant: {0}",
754 return numeric_constant;
757 return numeric_constant;
763 llvm::StringRef spelling_ref = spelling;
765 auto radix = llvm::getAutoSenseRadix(spelling_ref);
767 bool is_unsigned =
false;
768 if (spelling_ref.consume_back_insensitive(
"u"))
770 if (spelling_ref.consume_back_insensitive(
"ll"))
772 else if (spelling_ref.consume_back_insensitive(
"l"))
775 if (!is_unsigned && spelling_ref.consume_back_insensitive(
"u"))
778 llvm::APInt raw_value;
779 if (!spelling_ref.getAsInteger(radix, raw_value))
780 return std::make_unique<IntegerLiteralNode>(token.
GetLocation(), raw_value,
781 radix, is_unsigned, type);
782 return std::make_unique<ErrorNode>();
788 llvm::StringRef spelling_ref = spelling;
790 llvm::APFloat raw_float(llvm::APFloat::IEEEdouble());
791 if (spelling_ref.consume_back_insensitive(
"f"))
792 raw_float = llvm::APFloat(llvm::APFloat::IEEEsingle());
794 auto StatusOrErr = raw_float.convertFromString(
795 spelling_ref, llvm::APFloat::rmNearestTiesToEven);
796 if (!errorToBool(StatusOrErr.takeError()))
797 return std::make_unique<FloatLiteralNode>(token.
GetLocation(), raw_float);
798 return std::make_unique<ErrorNode>();
809 if (!
CurToken().IsOneOf(kinds_vec)) {
810 BailOut(llvm::formatv(
"expected any of ({0}), got: {1}",
811 llvm::iterator_range(kinds_vec),
CurToken()),
static llvm::raw_ostream & error(Stream &strm)
uint32_t GetKind(uint32_t data)
Return the type kind encoded in the given data.
lldb::LanguageType GetLanguage()
Generic representation of a type in a programming language.
CompilerType GetPointerType() const
Return a new CompilerType that is a pointer to this type.
CompilerType GetLValueReferenceType() const
Return a new CompilerType that is a L value reference to this type if this type is valid and the type...
ConstString GetTypeName(bool BaseOnly=false) const
bool IsReferenceType(CompilerType *pointee_type=nullptr, bool *is_rvalue=nullptr) const
std::string TypeDescription()
A uniqued constant string class.
llvm::StringRef GetStringRef() const
Get the string value as a llvm::StringRef.
"lldb/Target/ExecutionContextScope.h" Inherit from this if your object can reconstruct its execution ...
virtual lldb::TargetSP CalculateTarget()=0
A collection class for Module objects.
void FindTypes(Module *search_first, const TypeQuery &query, lldb_private::TypeResults &results) const
Find types using a type-matching object that contains all search parameters.
Defines a symbol context baton that can be handed other debug core functions.
lldb::ModuleSP module_sp
The Module for a given query.
CompileUnit * comp_unit
The CompileUnit for a given query.
A class that contains all state required for type lookups.
This class tracks the state and results of a TypeQuery.
lldb::TypeSP GetFirstType() const
DILDiagnosticError(DiagnosticDetail detail)
std::string message() const override
DiagnosticDetail m_detail
Class for doing the simple lexing required by DIL.
ASTNodeUP ParseAdditiveExpression()
ASTNodeUP ParseUnaryExpression()
void ParseTypeSpecifierSeq(std::string &type_name)
ASTNodeUP ParseIntegerLiteral()
void Expect(Token::Kind kind)
std::optional< CompilerType > ParseTypeId()
void TentativeParsingRollback(uint32_t saved_idx)
ASTNodeUP ParseFloatingPointLiteral()
ASTNodeUP ParseExpression()
void ExpectOneOf(std::vector< Token::Kind > kinds_vec)
std::optional< std::string > ParseTypeSpecifier()
ASTNodeUP ParseNumericLiteral()
std::optional< CompilerType > ParseBuiltinType()
ASTNodeUP ParsePrimaryExpression()
std::shared_ptr< StackFrame > m_ctx_scope
void BailOut(const std::string &error, uint32_t loc, uint16_t err_len)
CompilerType ResolveTypeDeclarators(CompilerType type, const std::vector< Token > &ptr_operators)
ASTNodeUP ParsePostfixExpression()
std::string ParseIdExpression()
ASTNodeUP ParseMultiplicativeExpression()
lldb::DynamicValueType m_use_dynamic
std::string ParseUnqualifiedId()
DILParser(llvm::StringRef dil_input_expr, DILLexer lexer, std::shared_ptr< StackFrame > frame_sp, lldb::DynamicValueType use_dynamic, llvm::Error &error, lldb::DILMode mode)
static llvm::Expected< ASTNodeUP > Parse(llvm::StringRef dil_input_expr, DILLexer lexer, std::shared_ptr< StackFrame > frame_sp, lldb::DynamicValueType use_dynamic, lldb::DILMode mode)
ASTNodeUP ParseCastExpression()
ASTNodeUP ParseBooleanLiteral()
std::optional< std::string > ParseTypeName()
llvm::StringRef m_input_expr
std::string ParseNestedNameSpecifier()
Class defining the tokens generated by the DIL lexer and used by the DIL parser.
uint32_t GetLocation() const
std::string GetSpelling() const
@ eNone
Invalid promotion type (results in error).
static CompilerType ResolveTypeByName(const std::string &name, ExecutionContextScope &ctx_scope)
llvm::Expected< lldb::TypeSystemSP > GetTypeSystemFromCU(std::shared_ptr< StackFrame > ctx)
std::unique_ptr< ASTNode > ASTNodeUP
BinaryOpKind GetBinaryOpKindFromToken(Token::Kind token_kind)
Translates DIL tokens to BinaryOpKind.
lldb::ValueObjectSP LookupGlobalIdentifier(llvm::StringRef name_ref, std::shared_ptr< StackFrame > frame_sp, lldb::TargetSP target_sp, lldb::DynamicValueType use_dynamic)
Given the name of an identifier, check to see if it matches the name of a global variable.
lldb::ValueObjectSP LookupIdentifier(llvm::StringRef name_ref, std::shared_ptr< StackFrame > frame_sp, lldb::DynamicValueType use_dynamic)
Given the name of an identifier (variable name, member name, type name, etc.), find the ValueObject f...
LanguageType
Programming language type.
std::shared_ptr< lldb_private::Type > TypeSP
std::shared_ptr< lldb_private::Target > TargetSP
DILMode
Data Inspection Language (DIL) evaluation modes.
@ eDILModeFull
Allowed: everything supported by DIL.
A source location consisting of a file name and position.