Guile: add value-{rvalue-,}reference-value
authorGeorge Barrett <bob@bob131.so>
Wed, 28 Apr 2021 17:32:47 +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
Value.reference_value() or Value.rvalue_reference_value(). This commit
adds a procedure with equivalent semantics to the Guile API.

gdb/ChangeLog:

* NEWS (Guile API): Note the addition of new procedures.
* guile/scm-value.c (gdbscm_reference_value): Add helper function
for reference value creation.
(gdbscm_value_reference_value): Add implementation of
value-reference-value procedure.
(gdbscm_value_rvalue_reference_value): Add implementation of
value-rvalue-reference-value procedure.
(value_functions): Add value-reference-value procedure.  Add
value-rvalue-reference-value procedure.

gdb/doc/ChangeLog:

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

gdb/testsuite/ChangeLog:

* gdb.guile/scm-value.exp (test_value_in_inferior): Add test for
value-reference-value.  Add test for value-rvalue-reference-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 26751d318b2ccaa415e900412e68dfc4d0aab71b..f29f60a7d62b9c713b85e6bceca0c0b1cec96911 100644 (file)
@@ -1,3 +1,15 @@
+2021-05-12  George Barrett  <bob@bob131.so>
+
+       * NEWS (Guile API): Note the addition of new procedures.
+       * guile/scm-value.c (gdbscm_reference_value): Add helper function
+       for reference value creation.
+       (gdbscm_value_reference_value): Add implementation of
+       value-reference-value procedure.
+       (gdbscm_value_rvalue_reference_value): Add implementation of
+       value-rvalue-reference-value procedure.
+       (value_functions): Add value-reference-value procedure.  Add
+       value-rvalue-reference-value procedure.
+
 2021-05-12  George Barrett  <bob@bob131.so>
 
        * guile/scm-type.c (type_integer_constants): Add binding for
index 250f79153ca6ba55b66657f6d83fb468f9e0f424..f7844e5d9e344cda0ed7ae908b55866778219656 100644 (file)
--- a/gdb/NEWS
+++ b/gdb/NEWS
@@ -207,6 +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.
+
 *** Changes in GDB 10
 
 * There are new feature names for ARC targets: "org.gnu.gdb.arc.core"
index 0546f650b328684bf458600c37511e516de4530e..029e2404470b945060b8573e0499579369745862 100644 (file)
@@ -1,3 +1,9 @@
+2021-05-12  George Barrett  <bob@bob131.so>
+
+       * guile.texi (Values From Inferior In Guile): Add documentation
+       for value-reference-value.  Add documentation for
+       value-rvalue-reference-value.
+
 2021-05-12  George Barrett  <bob@bob131.so>
 
        * guile.texi (Types In Guile): Add documentation for
index c3e134b5ffe649fbb726492a45566243647a003a..cca3a943c61ab7a936e4725ded04a9820de3297c 100644 (file)
@@ -801,6 +801,16 @@ The @code{<gdb:value>} object @code{scm-val} is identical to that
 corresponding to @code{val}.
 @end deffn
 
+@deffn {Scheme Procedure} value-reference-value value
+Return a new @code{<gdb:value>} object which is a reference to the value
+encapsulated by @code{<gdb:value>} object @var{value}.
+@end deffn
+
+@deffn {Scheme Procedure} value-rvalue-reference-value value
+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-field value field-name
 Return field @var{field-name} from @code{<gdb:value>} object @var{value}.
 @end deffn
index f50e8b5b46c597bb6533c2a5b51dc8cbebe7d4a3..a07bc7d2e6129223f1bfb4c7310e6fe6f60513d5 100644 (file)
@@ -488,6 +488,38 @@ gdbscm_value_referenced_value (SCM self)
     });
 }
 
+static SCM
+gdbscm_reference_value (SCM self, enum type_code refcode)
+{
+  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 = value_ref (value, refcode);
+      return vlscm_scm_from_value (res_val);
+    });
+}
+
+/* (value-reference-value <gdb:value>) -> <gdb:value> */
+
+static SCM
+gdbscm_value_reference_value (SCM self)
+{
+  return gdbscm_reference_value (self, TYPE_CODE_REF);
+}
+
+/* (value-rvalue-reference-value <gdb:value>) -> <gdb:value> */
+
+static SCM
+gdbscm_value_rvalue_reference_value (SCM self)
+{
+  return gdbscm_reference_value (self, TYPE_CODE_RVALUE_REF);
+}
+
 /* (value-type <gdb:value>) -> <gdb:type> */
 
 static SCM
@@ -1352,6 +1384,16 @@ For example, for a value which is a reference to an 'int' pointer ('int *'),\n\
 value-dereference will result in a value of type 'int' while\n\
 value-referenced-value will result in a value of type 'int *'." },
 
+  { "value-reference-value", 1, 0, 0,
+    as_a_scm_t_subr (gdbscm_value_reference_value),
+    "\
+Return a <gdb:value> object which is a reference to the given value." },
+
+  { "value-rvalue-reference-value", 1, 0, 0,
+    as_a_scm_t_subr (gdbscm_value_rvalue_reference_value),
+    "\
+Return a <gdb:value> object which is an rvalue reference to 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 a1cd48578df8b1e22bb09cb6b1f2ea0e7fe30331..691e83cdc94fa938c299c80df67d7d95ea53ccf8 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-reference-value.  Add test for value-rvalue-reference-value.
+
 2021-05-11  Tom de Vries  <tdevries@suse.de>
 
        * gdb.base/watch_thread_num.exp: Fix "set debug infrun 1" FAILs.
index 191af1d71a677f432e5be22c757b9c896aad8d3c..b3f785c9ecf5789eb7f2ad7d0c92723eaf27e647 100644 (file)
@@ -173,6 +173,16 @@ proc test_value_in_inferior {} {
        "get string beyond null"
     gdb_test "gu (print nullst)" \
        "= divide\\\\000et"
+
+    gdb_scm_test_silent_cmd "gu (define argv-ref (value-reference-value argv))" \
+       "test value-reference-value"
+    gdb_test "gu (equal? argv (value-referenced-value argv-ref))" "#t"
+    gdb_test "gu (eqv? (type-code (value-type argv-ref)) TYPE_CODE_REF)" "#t"
+
+    gdb_scm_test_silent_cmd "gu (define argv-rref (value-rvalue-reference-value argv))" \
+       "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"
 }
 
 proc test_strings {} {