aboutsummaryrefslogtreecommitdiff
path: root/gdb/python
diff options
context:
space:
mode:
authorTom Tromey <tromey@adacore.com>2023-05-16 07:14:22 -0600
committerTom Tromey <tromey@adacore.com>2023-06-12 12:09:45 -0600
commitc2a0d767db1637d1651b80bc885903cacd637107 (patch)
tree104aa04f29cf1d5239dd7adaeb1e18003bbf4ae9 /gdb/python
parented80156930339ee8e68a5341ec3d7f06fab6d02c (diff)
downloadgdb-c2a0d767db1637d1651b80bc885903cacd637107.zip
gdb-c2a0d767db1637d1651b80bc885903cacd637107.tar.gz
gdb-c2a0d767db1637d1651b80bc885903cacd637107.tar.bz2
Implement DAP setExpression request
This implements the DAP setExpression request.
Diffstat (limited to 'gdb/python')
-rw-r--r--gdb/python/lib/gdb/dap/evaluate.py24
1 files changed, 23 insertions, 1 deletions
diff --git a/gdb/python/lib/gdb/dap/evaluate.py b/gdb/python/lib/gdb/dap/evaluate.py
index 4fc0f31..1db6962 100644
--- a/gdb/python/lib/gdb/dap/evaluate.py
+++ b/gdb/python/lib/gdb/dap/evaluate.py
@@ -20,7 +20,7 @@ import gdb.printing
from typing import Optional
from .frames import frame_for_id
-from .server import request
+from .server import capability, request
from .startup import send_gdb_with_response, in_gdb_thread
from .varref import find_variable, VariableReference
@@ -43,6 +43,20 @@ def _evaluate(expr, frame_id):
return ref.to_object()
+# Helper function to perform an assignment.
+@in_gdb_thread
+def _set_expression(expression, value, frame_id):
+ global_context = True
+ if frame_id is not None:
+ frame = frame_for_id(frame_id)
+ frame.select()
+ global_context = False
+ lhs = gdb.parse_and_eval(expression, global_context=global_context)
+ rhs = gdb.parse_and_eval(value, global_context=global_context)
+ lhs.assign(rhs)
+ return EvaluateResult(lhs).to_object()
+
+
# Helper function to evaluate a gdb command in a certain frame.
@in_gdb_thread
def _repl(command, frame_id):
@@ -89,3 +103,11 @@ def variables(*, variablesReference: int, start: int = 0, count: int = 0, **args
lambda: _variables(variablesReference, start, count)
)
return {"variables": result}
+
+
+@capability("supportsSetExpression")
+@request("setExpression")
+def set_expression(
+ *, expression: str, value: str, frameId: Optional[int] = None, **args
+):
+ return send_gdb_with_response(lambda: _set_expression(expression, value, frameId))