gdb/MAINTAINERS: add Luis Machado as global maintainer
[binutils-gdb.git] / gdb / go-valprint.c
index 1933e98ed29e3daca53082e9722ee44b4a865eed..05788af15a6f004225a0106a94ffd4f0a9b74eaf 100644 (file)
@@ -1,6 +1,6 @@
 /* Support for printing Go values for GDB, the GNU debugger.
 
-   Copyright (C) 2012-2020 Free Software Foundation, Inc.
+   Copyright (C) 2012-2023 Free Software Foundation, Inc.
 
    This file is part of GDB.
 
@@ -43,16 +43,16 @@ print_go_string (struct type *type,
                 struct value *val,
                 const struct value_print_options *options)
 {
-  struct gdbarch *gdbarch = get_type_arch (type);
-  struct type *elt_ptr_type = TYPE_FIELD_TYPE (type, 0);
-  struct type *elt_type = TYPE_TARGET_TYPE (elt_ptr_type);
+  struct gdbarch *gdbarch = type->arch ();
+  struct type *elt_ptr_type = type->field (0).type ();
+  struct type *elt_type = elt_ptr_type->target_type ();
   LONGEST length;
   /* TODO(dje): The encapsulation of what a pointer is belongs in value.c.
      I.e. If there's going to be unpack_pointer, there should be
      unpack_value_field_as_pointer.  Do this until we can get
      unpack_value_field_as_pointer.  */
   LONGEST addr;
-  const gdb_byte *valaddr = value_contents_for_printing (val);
+  const gdb_byte *valaddr = val->contents_for_printing ().data ();
 
 
   if (! unpack_value_field_as_long (type, valaddr, embedded_offset, 0,
@@ -66,15 +66,15 @@ print_go_string (struct type *type,
   /* TODO(dje): Print address of struct or actual string?  */
   if (options->addressprint)
     {
-      fputs_filtered (paddress (gdbarch, addr), stream);
-      fputs_filtered (" ", stream);
+      gdb_puts (paddress (gdbarch, addr), stream);
+      gdb_puts (" ", stream);
     }
 
   if (length < 0)
     {
-      printf_filtered (_("<invalid length: %ps>"),
-                      styled_string (metadata_style.style (),
-                                     plongest (addr)));
+      gdb_printf (_("<invalid length: %ps>"),
+                 styled_string (metadata_style.style (),
+                                plongest (addr)));
       return;
     }
 
@@ -87,10 +87,11 @@ print_go_string (struct type *type,
 /* See go-lang.h.  */
 
 void
-go_value_print_inner (struct value *val, struct ui_file *stream,
-                     int recurse, const struct value_print_options *options)
+go_language::value_print_inner (struct value *val, struct ui_file *stream,
+                               int recurse,
+                               const struct value_print_options *options) const
 {
-  struct type *type = check_typedef (value_type (val));
+  struct type *type = check_typedef (val->type ());
 
   switch (type->code ())
     {
@@ -103,8 +104,8 @@ go_value_print_inner (struct value *val, struct ui_file *stream,
            case GO_TYPE_STRING:
              if (! options->raw)
                {
-                 print_go_string (type, value_embedded_offset (val),
-                                  value_address (val),
+                 print_go_string (type, val->embedded_offset (),
+                                  val->address (),
                                   stream, recurse, val, options);
                  return;
                }