]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
Guile: add value-const-value
authorGeorge Barrett <bob@bob131.so>
Wed, 28 Apr 2021 17:32:56 +0000 (03:32 +1000)
committerAndrew Burgess <andrew.burgess@embecosm.com>
Wed, 12 May 2021 11:35:36 +0000 (12:35 +0100)
The Guile API doesn't currently have an equivalent to the Python API's
gdb.Value.const_value(). This commit adds a procedure with equivalent
semantics to the Guile API.

gdb/ChangeLog:

* NEWS (Guile API): Note the addition of the new procedure.
* guile/scm-value.c (gdbscm_value_const_value): Add
implementation of value-const-value procedure.
(value_functions): Add value-const-value procedure.

gdb/doc/ChangeLog:

* guile.texi (Values From Inferior In Guile): Add documentation
for value-const-value.

gdb/testsuite/ChangeLog:

* gdb.guile/scm-value.exp (test_value_in_inferior): Add test for
value-const-value.

gdb/ChangeLog
gdb/NEWS
gdb/doc/ChangeLog
gdb/doc/guile.texi
gdb/guile/scm-value.c
gdb/testsuite/ChangeLog
gdb/testsuite/gdb.guile/scm-value.exp

index f29f60a7d62b9c713b85e6bceca0c0b1cec96911..8ef5eb6c833b73e6618891e8a4acb2127a7c56fd 100644 (file)
@@ -1,3 +1,10 @@
+2021-05-12  George Barrett  <bob@bob131.so>
+
+       * NEWS (Guile API): Note the addition of the new procedure.
+       * guile/scm-value.c (gdbscm_value_const_value): Add
+       implementation of value-const-value procedure.
+       (value_functions): Add value-const-value procedure.
+
 2021-05-12  George Barrett  <bob@bob131.so>
 
        * NEWS (Guile API): Note the addition of new procedures.
index f7844e5d9e344cda0ed7ae908b55866778219656..6e147cb031826336da6451f614833f39b4e68613 100644 (file)
--- a/gdb/NEWS
+++ b/gdb/NEWS
@@ -207,8 +207,9 @@ QMemTags
      value-referenced-value procedure now handles rvalue reference
      values.
 
-  ** New procedures for obtaining reference values:
-     value-reference-value and value-rvalue-reference-value.
+  ** New procedures for obtaining value variants:
+     value-reference-value, value-rvalue-reference-value and
+     value-const-value.
 
 *** Changes in GDB 10
 
index 029e2404470b945060b8573e0499579369745862..290ad485521a09142e46e8a8c83a8d5b830efe2c 100644 (file)
@@ -1,3 +1,8 @@
+2021-05-12  George Barrett  <bob@bob131.so>
+
+       * guile.texi (Values From Inferior In Guile): Add documentation
+       for value-const-value.
+
 2021-05-12  George Barrett  <bob@bob131.so>
 
        * guile.texi (Values From Inferior In Guile): Add documentation
index cca3a943c61ab7a936e4725ded04a9820de3297c..c7e43c8d63a9f80b5d467c7de36474faf4237d7c 100644 (file)
@@ -811,6 +811,11 @@ Return a new @code{<gdb:value>} object which is an rvalue reference to
 the value encapsulated by @code{<gdb:value>} object @var{value}.
 @end deffn
 
+@deffn {Scheme Procedure} value-const-value value
+Return a new @code{<gdb:value>} object which is a @samp{const} version
+of @code{<gdb:value>} object @var{value}.
+@end deffn
+
 @deffn {Scheme Procedure} value-field value field-name
 Return field @var{field-name} from @code{<gdb:value>} object @var{value}.
 @end deffn
index a07bc7d2e6129223f1bfb4c7310e6fe6f60513d5..24bb55479570fa0ed86369f1c53ad8d467fcbe72 100644 (file)
@@ -520,6 +520,24 @@ gdbscm_value_rvalue_reference_value (SCM self)
   return gdbscm_reference_value (self, TYPE_CODE_RVALUE_REF);
 }
 
+/* (value-const-value <gdb:value>) -> <gdb:value> */
+
+static SCM
+gdbscm_value_const_value (SCM self)
+{
+  value_smob *v_smob
+    = vlscm_get_value_smob_arg_unsafe (self, SCM_ARG1, FUNC_NAME);
+  struct value *value = v_smob->value;
+
+  return gdbscm_wrap ([=]
+    {
+      scoped_value_mark free_values;
+
+      struct value *res_val = make_cv_value (1, 0, value);
+      return vlscm_scm_from_value (res_val);
+    });
+}
+
 /* (value-type <gdb:value>) -> <gdb:type> */
 
 static SCM
@@ -1394,6 +1412,11 @@ Return a <gdb:value> object which is a reference to the given value." },
     "\
 Return a <gdb:value> object which is an rvalue reference to the given value." },
 
+  { "value-const-value", 1, 0, 0,
+    as_a_scm_t_subr (gdbscm_value_const_value),
+    "\
+Return a <gdb:value> object which is a 'const' version of the given value." },
+
   { "value-field", 2, 0, 0, as_a_scm_t_subr (gdbscm_value_field),
     "\
 Return the specified field of the value.\n\
index 691e83cdc94fa938c299c80df67d7d95ea53ccf8..e0f64965d9421ce0b4d0fa35b5ca4d79f977158e 100644 (file)
@@ -1,3 +1,8 @@
+2021-05-12  George Barrett  <bob@bob131.so>
+
+       * gdb.guile/scm-value.exp (test_value_in_inferior): Add test for
+       value-const-value.
+
 2021-05-12  George Barrett  <bob@bob131.so>
 
        * gdb.guile/scm-value.exp (test_value_in_inferior): Add test for
index b3f785c9ecf5789eb7f2ad7d0c92723eaf27e647..982b9bf17b95da1c4a0e6a8ec621b04a2aa95286 100644 (file)
@@ -183,6 +183,9 @@ proc test_value_in_inferior {} {
        "test value-rvalue-reference-value"
     gdb_test "gu (equal? argv (value-referenced-value argv-rref))" "#t"
     gdb_test "gu (eqv? (type-code (value-type argv-rref)) TYPE_CODE_RVALUE_REF)" "#t"
+
+    gdb_test "gu (equal? (value-type (value-const-value argv)) (type-const (value-type argv)))" \
+       "#t"
 }
 
 proc test_strings {} {