diff options
author | Andrew Burgess <aburgess@redhat.com> | 2024-10-06 20:32:16 +0100 |
---|---|---|
committer | Andrew Burgess <aburgess@redhat.com> | 2024-10-21 10:36:32 +0100 |
commit | 9ee884981410d3d666e9b7b747b50908d891286b (patch) | |
tree | 7603bf825fababeb7f69157bd032d96e3643e98d | |
parent | ced885161b6e1dee89acc4bd3b68ba7a27815645 (diff) | |
download | binutils-9ee884981410d3d666e9b7b747b50908d891286b.zip binutils-9ee884981410d3d666e9b7b747b50908d891286b.tar.gz binutils-9ee884981410d3d666e9b7b747b50908d891286b.tar.bz2 |
gdb/guile: add get-basic-type
A question was asked on stackoverflow.com about the guile function
get-basic-type[1] which is mentioned in the docs along with an example
of its use.
The problem is, the function was apparently never actually added to
GDB. But it turns out that it's pretty easy to implement, so lets add
it now. Better late than never.
The implementation mirrors the Python get_basic_type function. I've
added a test which is a copy of the documentation example.
One issue is that the docs suggest that the type will be returned as
just "int", however, I'm not sure what this actually means. It makes
more sense that the function return a gdb:type object which would be
represented as "#<gdb:type int>", so I've updated the docs to show
this output.
[1] https://stackoverflow.com/questions/79058691/unbound-variable-get-basic-type-in-gdb-guile-session
Reviewed-By: Kevin Buettner <kevinb@redhat.com>
-rw-r--r-- | gdb/doc/guile.texi | 2 | ||||
-rw-r--r-- | gdb/guile/lib/gdb/types.scm | 19 | ||||
-rw-r--r-- | gdb/testsuite/gdb.guile/types-module.cc | 4 | ||||
-rw-r--r-- | gdb/testsuite/gdb.guile/types-module.exp | 5 |
4 files changed, 29 insertions, 1 deletions
diff --git a/gdb/doc/guile.texi b/gdb/doc/guile.texi index a66e8bf..bd1262e 100644 --- a/gdb/doc/guile.texi +++ b/gdb/doc/guile.texi @@ -3946,7 +3946,7 @@ Then in gdb: (gdb) guile (use-modules (gdb) (gdb types)) (gdb) guile (define foo-ref (parse-and-eval "foo_ref")) (gdb) guile (get-basic-type (value-type foo-ref)) -int +#<gdb:type int> @end smallexample @end deffn diff --git a/gdb/guile/lib/gdb/types.scm b/gdb/guile/lib/gdb/types.scm index 198de9d..7d8d3c6 100644 --- a/gdb/guile/lib/gdb/types.scm +++ b/gdb/guile/lib/gdb/types.scm @@ -55,6 +55,25 @@ (search-class type)) +(define-public (get-basic-type type) + "Return the \"basic\" type of a given type. + + Arguments: + type: The type to reduce to its basic type. + + Returns: + TYPE with const/volatile stripped away, and typedefs/references + converted to the underlying type." + + (while (or (= (type-code type) TYPE_CODE_REF) + (= (type-code type) TYPE_CODE_RVALUE_REF) + (= (type-code type) TYPE_CODE_TYPEDEF)) + (if (= (type-code type) TYPE_CODE_TYPEDEF) + (set! type (type-strip-typedefs type)) + (set! type (type-target type)))) + + (type-unqualified type)) + (define-public (make-enum-hashtable enum-type) "Return a hash table from a program's enum type. diff --git a/gdb/testsuite/gdb.guile/types-module.cc b/gdb/testsuite/gdb.guile/types-module.cc index 9b32f67..f3992c0 100644 --- a/gdb/testsuite/gdb.guile/types-module.cc +++ b/gdb/testsuite/gdb.guile/types-module.cc @@ -31,6 +31,10 @@ class derived : public base derived d; +typedef const int const_int; +const_int foo (3); +const_int &foo_ref (foo); + int main (void) { diff --git a/gdb/testsuite/gdb.guile/types-module.exp b/gdb/testsuite/gdb.guile/types-module.exp index d95ff21..ee55804 100644 --- a/gdb/testsuite/gdb.guile/types-module.exp +++ b/gdb/testsuite/gdb.guile/types-module.exp @@ -59,3 +59,8 @@ gdb_test "guile (define bad-enum-htab (make-enum-hashtable #f))" \ gdb_test "guile (define bad-enum-htab (make-enum-hashtable (lookup-type \"int\")))" \ "Wrong type argument in position 1 \\(expecting enum\\): #<gdb:type int>.*" \ "make-enum-hashtable from int" + +gdb_test_no_output "guile (define foo-ref (parse-and-eval \"foo_ref\"))" \ + "get foo-ref value" +gdb_test "guile (get-basic-type (value-type foo-ref))" "#<gdb:type int>" \ + "check get-basic-type" |