summaryrefslogtreecommitdiffstats
path: root/lldb/tools/lldb-vscode/JSONUtils.h
diff options
context:
space:
mode:
Diffstat (limited to 'lldb/tools/lldb-vscode/JSONUtils.h')
-rw-r--r--lldb/tools/lldb-vscode/JSONUtils.h421
1 files changed, 421 insertions, 0 deletions
diff --git a/lldb/tools/lldb-vscode/JSONUtils.h b/lldb/tools/lldb-vscode/JSONUtils.h
new file mode 100644
index 00000000000..c5d9ec17105
--- /dev/null
+++ b/lldb/tools/lldb-vscode/JSONUtils.h
@@ -0,0 +1,421 @@
+//===-- 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.
+//----------------------------------------------------------------------
+llvm::json::Object CreateEvent(const llvm::StringRef event_name);
+
+//----------------------------------------------------------------------
+/// 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
OpenPOWER on IntegriCloud