2018-08-17 01:59:38 +08:00
|
|
|
//===-- JSONUtils.h ---------------------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLDBVSCODE_JSONUTILS_H_
|
|
|
|
#define LLDBVSCODE_JSONUTILS_H_
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "llvm/ADT/StringRef.h"
|
|
|
|
#include "llvm/Support/JSON.h"
|
|
|
|
#include "VSCodeForward.h"
|
|
|
|
|
|
|
|
namespace lldb_vscode {
|
|
|
|
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
/// Extract simple values as a string.
|
|
|
|
///
|
|
|
|
/// @param[in] value
|
|
|
|
/// A JSON value to extract the string from.
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A llvm::StringRef that contains the string value, or an empty
|
|
|
|
/// string if \a value isn't a string.
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
llvm::StringRef GetAsString(const llvm::json::Value &value);
|
|
|
|
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
/// Extract the string value for the specified key from the
|
|
|
|
/// specified object.
|
|
|
|
///
|
|
|
|
/// @param[in] obj
|
|
|
|
/// A JSON object that we will attempt to extract the value from
|
|
|
|
///
|
|
|
|
/// @param[in] key
|
|
|
|
/// The key to use when extracting the value
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A llvm::StringRef that contains the string value for the
|
|
|
|
/// specified \a key, or an empty string if there is no key that
|
|
|
|
/// matches or if the value is not a string.
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
llvm::StringRef GetString(const llvm::json::Object &obj, llvm::StringRef key);
|
|
|
|
llvm::StringRef GetString(const llvm::json::Object *obj, llvm::StringRef key);
|
|
|
|
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
/// Extract the unsigned integer value for the specified key from
|
|
|
|
/// the specified object.
|
|
|
|
///
|
|
|
|
/// @param[in] obj
|
|
|
|
/// A JSON object that we will attempt to extract the value from
|
|
|
|
///
|
|
|
|
/// @param[in] key
|
|
|
|
/// The key to use when extracting the value
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// The unsigned integer value for the specified \a key, or
|
|
|
|
/// \a fail_value if there is no key that matches or if the
|
|
|
|
/// value is not an integer.
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
uint64_t GetUnsigned(const llvm::json::Object &obj, llvm::StringRef key,
|
|
|
|
uint64_t fail_value);
|
|
|
|
uint64_t GetUnsigned(const llvm::json::Object *obj, llvm::StringRef key,
|
|
|
|
uint64_t fail_value);
|
|
|
|
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
/// Extract the boolean value for the specified key from the
|
|
|
|
/// specified object.
|
|
|
|
///
|
|
|
|
/// @param[in] obj
|
|
|
|
/// A JSON object that we will attempt to extract the value from
|
|
|
|
///
|
|
|
|
/// @param[in] key
|
|
|
|
/// The key to use when extracting the value
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// The boolean value for the specified \a key, or \a fail_value
|
|
|
|
/// if there is no key that matches or if the value is not a
|
|
|
|
/// boolean value of an integer.
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
bool GetBoolean(const llvm::json::Object &obj, llvm::StringRef key,
|
|
|
|
bool fail_value);
|
|
|
|
bool GetBoolean(const llvm::json::Object *obj, llvm::StringRef key,
|
|
|
|
bool fail_value);
|
|
|
|
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
/// Extract the signed integer for the specified key from the
|
|
|
|
/// specified object.
|
|
|
|
///
|
|
|
|
/// @param[in] obj
|
|
|
|
/// A JSON object that we will attempt to extract the value from
|
|
|
|
///
|
|
|
|
/// @param[in] key
|
|
|
|
/// The key to use when extracting the value
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// The signed integer value for the specified \a key, or
|
|
|
|
/// \a fail_value if there is no key that matches or if the
|
|
|
|
/// value is not an integer.
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
int64_t GetSigned(const llvm::json::Object &obj, llvm::StringRef key,
|
|
|
|
int64_t fail_value);
|
|
|
|
int64_t GetSigned(const llvm::json::Object *obj, llvm::StringRef key,
|
|
|
|
int64_t fail_value);
|
|
|
|
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
/// Check if the specified key exists in the specified object.
|
|
|
|
///
|
|
|
|
/// @param[in] obj
|
|
|
|
/// A JSON object that we will attempt to extract the value from
|
|
|
|
///
|
|
|
|
/// @param[in] key
|
|
|
|
/// The key to check for
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// \b True if the key exists in the \a obj, \b False otherwise.
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
bool ObjectContainsKey(const llvm::json::Object &obj, llvm::StringRef key);
|
|
|
|
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
/// Extract an array of strings for the specified key from an object.
|
|
|
|
///
|
|
|
|
/// String values in the array will be extracted without any quotes
|
|
|
|
/// around them. Numbers and Booleans will be converted into
|
|
|
|
/// strings. Any NULL, array or objects values in the array will be
|
|
|
|
/// ignored.
|
|
|
|
///
|
|
|
|
/// @param[in] obj
|
|
|
|
/// A JSON object that we will attempt to extract the array from
|
|
|
|
///
|
|
|
|
/// @param[in] key
|
|
|
|
/// The key to use when extracting the value
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// An array of string values for the specified \a key, or
|
|
|
|
/// \a fail_value if there is no key that matches or if the
|
|
|
|
/// value is not an array or all items in the array are not
|
|
|
|
/// strings, numbers or booleans.
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
std::vector<std::string> GetStrings(const llvm::json::Object *obj,
|
|
|
|
llvm::StringRef key);
|
|
|
|
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
/// Fill a response object given the request object.
|
|
|
|
///
|
|
|
|
/// The \a response object will get its "type" set to "response",
|
|
|
|
/// the "seq" set to zero, "response_seq" set to the "seq" value from
|
|
|
|
/// \a request, "command" set to the "command" from \a request,
|
|
|
|
/// and "success" set to true.
|
|
|
|
///
|
|
|
|
/// @param[in] request
|
|
|
|
/// The request object received from a call to VSCode::ReadJSON().
|
|
|
|
///
|
|
|
|
/// @param[in,out] response
|
|
|
|
/// An empty llvm::json::Object object that will be filled
|
|
|
|
/// in as noted in description.
|
|
|
|
//------------------------------------------------------------------
|
|
|
|
void FillResponse(const llvm::json::Object &request,
|
|
|
|
llvm::json::Object &response);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Emplace the string value from an SBValue into the supplied object
|
|
|
|
/// using \a key as the key that will contain the value.
|
|
|
|
///
|
|
|
|
/// The value is what we will display in VS Code. Some SBValue objects
|
|
|
|
/// can have a value and/or a summary. If a value has both, we
|
|
|
|
/// combine the value and the summary into one string. If we only have a
|
|
|
|
/// value or summary, then that is considered the value. If there is
|
|
|
|
/// no value and no summary then the value is the type name followed by
|
|
|
|
/// the address of the type if it has an address.
|
|
|
|
///
|
|
|
|
///
|
|
|
|
/// @param[in] v
|
|
|
|
/// A lldb::SBValue object to extract the string value from
|
|
|
|
///
|
|
|
|
///
|
|
|
|
/// @param[in] object
|
|
|
|
/// The object to place the value object into
|
|
|
|
///
|
|
|
|
///
|
|
|
|
/// @param[in] key
|
|
|
|
/// The key name to use when inserting the value object we create
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void SetValueForKey(lldb::SBValue &v, llvm::json::Object &object,
|
|
|
|
llvm::StringRef key);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Converts \a bp to a JSON value and appends all locations to the
|
|
|
|
/// \a breakpoints array.
|
|
|
|
///
|
|
|
|
/// @param[in] bp
|
|
|
|
/// A LLDB breakpoint object which will get all locations extracted
|
|
|
|
/// and converted into a JSON objects in the \a breakpoints array
|
|
|
|
///
|
|
|
|
/// @param[in] breakpoints
|
|
|
|
/// A JSON array that will get a llvm::json::Value for \a bp
|
|
|
|
/// appended to it.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
void AppendBreakpoint(lldb::SBBreakpoint &bp, llvm::json::Array &breakpoints);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Converts breakpoint location to a Visual Studio Code "Breakpoint"
|
|
|
|
/// JSON object and appends it to the \a breakpoints array.
|
|
|
|
///
|
|
|
|
/// @param[in] bp_loc
|
|
|
|
/// A LLDB breakpoint location object to convert into a JSON value
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "Breakpoint" JSON object with that follows the formal JSON
|
|
|
|
/// definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
llvm::json::Value CreateBreakpoint(lldb::SBBreakpointLocation &bp_loc);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Create a "Event" JSON object using \a event_name as the event name
|
|
|
|
///
|
|
|
|
/// @param[in] event_name
|
|
|
|
/// The string value to use for the "event" key in the JSON object.
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "Event" JSON object with that follows the formal JSON
|
|
|
|
/// definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
2018-08-17 02:24:59 +08:00
|
|
|
llvm::json::Object CreateEventObject(const llvm::StringRef event_name);
|
2018-08-17 01:59:38 +08:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Create a "ExceptionBreakpointsFilter" JSON object as described in
|
|
|
|
/// the Visual Studio Code debug adaptor definition.
|
|
|
|
///
|
|
|
|
/// @param[in] bp
|
|
|
|
/// The exception breakppoint object to use
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "ExceptionBreakpointsFilter" JSON object with that follows
|
|
|
|
/// the formal JSON definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
llvm::json::Value
|
|
|
|
CreateExceptionBreakpointFilter(const ExceptionBreakpoint &bp);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Create a "Scope" JSON object as described in the Visual Studio Code
|
|
|
|
/// debug adaptor definition.
|
|
|
|
///
|
|
|
|
/// @param[in] name
|
|
|
|
/// The value to place into the "name" key
|
|
|
|
//
|
|
|
|
/// @param[in] variablesReference
|
|
|
|
/// The value to place into the "variablesReference" key
|
|
|
|
//
|
|
|
|
/// @param[in] namedVariables
|
|
|
|
/// The value to place into the "namedVariables" key
|
|
|
|
//
|
|
|
|
/// @param[in] expensive
|
|
|
|
/// The value to place into the "expensive" key
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "Scope" JSON object with that follows the formal JSON
|
|
|
|
/// definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
llvm::json::Value CreateScope(const llvm::StringRef name,
|
|
|
|
int64_t variablesReference,
|
|
|
|
int64_t namedVariables, bool expensive);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Create a "Source" JSON object as described in the Visual Studio Code
|
|
|
|
/// debug adaptor definition.
|
|
|
|
///
|
|
|
|
/// @param[in] line_entry
|
|
|
|
/// The LLDB line table to use when populating out the "Source"
|
|
|
|
/// object
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "Source" JSON object with that follows the formal JSON
|
|
|
|
/// definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
llvm::json::Value CreateSource(lldb::SBLineEntry &line_entry);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Create a "Source" object for a given frame.
|
|
|
|
///
|
|
|
|
/// When there is no source file information for a stack frame, we will
|
|
|
|
/// create disassembly for a function and store a permanent
|
|
|
|
/// "sourceReference" that contains the textual disassembly for a
|
|
|
|
/// function along with address to line information. The "Source" object
|
|
|
|
/// that is created will contain a "sourceReference" that the VSCode
|
|
|
|
/// protocol can later fetch as text in order to display disassembly.
|
|
|
|
/// The PC will be extracted from the frame and the disassembly line
|
|
|
|
/// within the source referred to by "sourceReference" will be filled
|
|
|
|
/// in.
|
|
|
|
///
|
|
|
|
/// @param[in] frame
|
|
|
|
/// The LLDB stack frame to use when populating out the "Source"
|
|
|
|
/// object.
|
|
|
|
///
|
|
|
|
/// @param[out] disasm_line
|
|
|
|
/// The line within the "sourceReference" file that the PC from
|
|
|
|
/// \a frame matches.
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "Source" JSON object with that follows the formal JSON
|
|
|
|
/// definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
llvm::json::Value CreateSource(lldb::SBFrame &frame, int64_t &disasm_line);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Create a "StackFrame" object for a LLDB frame object.
|
|
|
|
///
|
|
|
|
/// This function will fill in the following keys in the returned
|
|
|
|
/// object:
|
|
|
|
/// "id" - the stack frame ID as an integer
|
|
|
|
/// "name" - the function name as a string
|
|
|
|
/// "source" - source file information as a "Source" VSCode object
|
|
|
|
/// "line" - the source file line number as an integer
|
|
|
|
/// "column" - the source file column number as an integer
|
|
|
|
///
|
|
|
|
/// @param[in] frame
|
|
|
|
/// The LLDB stack frame to use when populating out the "StackFrame"
|
|
|
|
/// object.
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "StackFrame" JSON object with that follows the formal JSON
|
|
|
|
/// definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
llvm::json::Value CreateStackFrame(lldb::SBFrame &frame);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Create a "Thread" object for a LLDB thread object.
|
|
|
|
///
|
|
|
|
/// This function will fill in the following keys in the returned
|
|
|
|
/// object:
|
|
|
|
/// "id" - the thread ID as an integer
|
|
|
|
/// "name" - the thread name as a string which combines the LLDB
|
|
|
|
/// thread index ID along with the string name of the thread
|
|
|
|
/// from the OS if it has a name.
|
|
|
|
///
|
|
|
|
/// @param[in] thread
|
|
|
|
/// The LLDB thread to use when populating out the "Thread"
|
|
|
|
/// object.
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "Thread" JSON object with that follows the formal JSON
|
|
|
|
/// definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
llvm::json::Value CreateThread(lldb::SBThread &thread);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Create a "StoppedEvent" object for a LLDB thread object.
|
|
|
|
///
|
|
|
|
/// This function will fill in the following keys in the returned
|
|
|
|
/// object's "body" object:
|
|
|
|
/// "reason" - With a valid stop reason enumeration string value
|
|
|
|
/// that Microsoft specifies
|
|
|
|
/// "threadId" - The thread ID as an integer
|
|
|
|
/// "description" - a stop description (like "breakpoint 12.3") as a
|
|
|
|
/// string
|
|
|
|
/// "preserveFocusHint" - a boolean value that states if this thread
|
|
|
|
/// should keep the focus in the GUI.
|
|
|
|
/// "allThreadsStopped" - set to True to indicate that all threads
|
|
|
|
/// stop when any thread stops.
|
|
|
|
///
|
|
|
|
/// @param[in] thread
|
|
|
|
/// The LLDB thread to use when populating out the "StoppedEvent"
|
|
|
|
/// object.
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "StoppedEvent" JSON object with that follows the formal JSON
|
|
|
|
/// definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
llvm::json::Value CreateThreadStopped(lldb::SBThread &thread, uint32_t stop_id);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
/// Create a "Variable" object for a LLDB thread object.
|
|
|
|
///
|
|
|
|
/// This function will fill in the following keys in the returned
|
|
|
|
/// object:
|
|
|
|
/// "name" - the name of the variable
|
|
|
|
/// "value" - the value of the variable as a string
|
|
|
|
/// "type" - the typename of the varaible as a string
|
|
|
|
/// "id" - a unique identifier for a value in case there are multiple
|
|
|
|
/// variables with the same name. Other parts of the VSCode
|
|
|
|
/// protocol refer to values by name so this can help
|
|
|
|
/// disambiguate such cases if a IDE passes this "id" value
|
|
|
|
/// back down.
|
|
|
|
/// "variablesReference" - Zero if the variable has no children,
|
|
|
|
/// non-zero integer otherwise which can be used to expand
|
|
|
|
/// the variable.
|
|
|
|
/// "evaluateName" - The name of the variable to use in expressions
|
|
|
|
/// as a string.
|
|
|
|
///
|
|
|
|
/// @param[in] v
|
|
|
|
/// The LLDB value to use when populating out the "Variable"
|
|
|
|
/// object.
|
|
|
|
///
|
|
|
|
/// @param[in] variablesReference
|
|
|
|
/// The variable reference. Zero if this value isn't structured
|
|
|
|
/// and has no children, non-zero if it does have children and
|
|
|
|
/// might be asked to expand itself.
|
|
|
|
///
|
|
|
|
/// @param[in] varID
|
|
|
|
/// A unique variable indentifier to help in properly identifying
|
|
|
|
/// variables with the same name. This is an extension to the
|
|
|
|
/// VS protocol.
|
|
|
|
///
|
|
|
|
/// @param[in] format_hex
|
|
|
|
/// It set to true the variable will be formatted as hex in
|
|
|
|
/// the "value" key value pair for the value of the variable.
|
|
|
|
///
|
|
|
|
/// @return
|
|
|
|
/// A "Variable" JSON object with that follows the formal JSON
|
|
|
|
/// definition outlined by Microsoft.
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
llvm::json::Value CreateVariable(lldb::SBValue v, int64_t variablesReference,
|
|
|
|
int64_t varID, bool format_hex);
|
|
|
|
|
|
|
|
} // namespace lldb_vscode
|
|
|
|
|
|
|
|
#endif
|