OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gdb-7.1/] [gdb/] [m2-valprint.c] - Diff between revs 834 and 842

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 834 Rev 842
/* Support for printing Modula 2 values for GDB, the GNU debugger.
/* Support for printing Modula 2 values for GDB, the GNU debugger.
 
 
   Copyright (C) 1986, 1988, 1989, 1991, 1992, 1996, 1998, 2000, 2005, 2006,
   Copyright (C) 1986, 1988, 1989, 1991, 1992, 1996, 1998, 2000, 2005, 2006,
                 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
                 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
 
 
   This file is part of GDB.
   This file is part of GDB.
 
 
   This program is free software; you can redistribute it and/or modify
   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 3 of the License, or
   the Free Software Foundation; either version 3 of the License, or
   (at your option) any later version.
   (at your option) any later version.
 
 
   This program is distributed in the hope that it will be useful,
   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.
   GNU General Public License for more details.
 
 
   You should have received a copy of the GNU General Public License
   You should have received a copy of the GNU General Public License
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
 
 
#include "defs.h"
#include "defs.h"
#include "symtab.h"
#include "symtab.h"
#include "gdbtypes.h"
#include "gdbtypes.h"
#include "expression.h"
#include "expression.h"
#include "value.h"
#include "value.h"
#include "valprint.h"
#include "valprint.h"
#include "language.h"
#include "language.h"
#include "typeprint.h"
#include "typeprint.h"
#include "c-lang.h"
#include "c-lang.h"
#include "m2-lang.h"
#include "m2-lang.h"
#include "target.h"
#include "target.h"
 
 
static int print_unpacked_pointer (struct type *type,
static int print_unpacked_pointer (struct type *type,
                                   CORE_ADDR address, CORE_ADDR addr,
                                   CORE_ADDR address, CORE_ADDR addr,
                                   const struct value_print_options *options,
                                   const struct value_print_options *options,
                                   struct ui_file *stream);
                                   struct ui_file *stream);
static void
static void
m2_print_array_contents (struct type *type, const gdb_byte *valaddr,
m2_print_array_contents (struct type *type, const gdb_byte *valaddr,
                         int embedded_offset, CORE_ADDR address,
                         int embedded_offset, CORE_ADDR address,
                         struct ui_file *stream, int recurse,
                         struct ui_file *stream, int recurse,
                         const struct value_print_options *options,
                         const struct value_print_options *options,
                         int len);
                         int len);
 
 
 
 
/* Print function pointer with inferior address ADDRESS onto stdio
/* Print function pointer with inferior address ADDRESS onto stdio
   stream STREAM.  */
   stream STREAM.  */
 
 
static void
static void
print_function_pointer_address (struct gdbarch *gdbarch, CORE_ADDR address,
print_function_pointer_address (struct gdbarch *gdbarch, CORE_ADDR address,
                                struct ui_file *stream, int addressprint)
                                struct ui_file *stream, int addressprint)
{
{
  CORE_ADDR func_addr = gdbarch_convert_from_func_ptr_addr (gdbarch, address,
  CORE_ADDR func_addr = gdbarch_convert_from_func_ptr_addr (gdbarch, address,
                                                            &current_target);
                                                            &current_target);
 
 
  /* If the function pointer is represented by a description, print the
  /* If the function pointer is represented by a description, print the
     address of the description.  */
     address of the description.  */
  if (addressprint && func_addr != address)
  if (addressprint && func_addr != address)
    {
    {
      fputs_filtered ("@", stream);
      fputs_filtered ("@", stream);
      fputs_filtered (paddress (gdbarch, address), stream);
      fputs_filtered (paddress (gdbarch, address), stream);
      fputs_filtered (": ", stream);
      fputs_filtered (": ", stream);
    }
    }
  print_address_demangle (gdbarch, func_addr, stream, demangle);
  print_address_demangle (gdbarch, func_addr, stream, demangle);
}
}
 
 
/* get_long_set_bounds - assigns the bounds of the long set to low and
/* get_long_set_bounds - assigns the bounds of the long set to low and
                         high.  */
                         high.  */
 
 
int
int
get_long_set_bounds (struct type *type, LONGEST *low, LONGEST *high)
get_long_set_bounds (struct type *type, LONGEST *low, LONGEST *high)
{
{
  int len, i;
  int len, i;
 
 
  if (TYPE_CODE (type) == TYPE_CODE_STRUCT)
  if (TYPE_CODE (type) == TYPE_CODE_STRUCT)
    {
    {
      len = TYPE_NFIELDS (type);
      len = TYPE_NFIELDS (type);
      i = TYPE_N_BASECLASSES (type);
      i = TYPE_N_BASECLASSES (type);
      if (len == 0)
      if (len == 0)
        return 0;
        return 0;
      *low = TYPE_LOW_BOUND (TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, i)));
      *low = TYPE_LOW_BOUND (TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, i)));
      *high = TYPE_HIGH_BOUND (TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type,
      *high = TYPE_HIGH_BOUND (TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type,
                                                                 len-1)));
                                                                 len-1)));
      return 1;
      return 1;
    }
    }
  error (_("expecting long_set"));
  error (_("expecting long_set"));
  return 0;
  return 0;
}
}
 
 
static void
static void
m2_print_long_set (struct type *type, const gdb_byte *valaddr,
m2_print_long_set (struct type *type, const gdb_byte *valaddr,
                   int embedded_offset, CORE_ADDR address,
                   int embedded_offset, CORE_ADDR address,
                   struct ui_file *stream)
                   struct ui_file *stream)
{
{
  int empty_set        = 1;
  int empty_set        = 1;
  int element_seen     = 0;
  int element_seen     = 0;
  LONGEST previous_low = 0;
  LONGEST previous_low = 0;
  LONGEST previous_high= 0;
  LONGEST previous_high= 0;
  LONGEST i, low_bound, high_bound;
  LONGEST i, low_bound, high_bound;
  LONGEST field_low, field_high;
  LONGEST field_low, field_high;
  struct type *range;
  struct type *range;
  int len, field;
  int len, field;
  struct type *target;
  struct type *target;
  int bitval;
  int bitval;
 
 
  CHECK_TYPEDEF (type);
  CHECK_TYPEDEF (type);
 
 
  fprintf_filtered (stream, "{");
  fprintf_filtered (stream, "{");
  len = TYPE_NFIELDS (type);
  len = TYPE_NFIELDS (type);
  if (get_long_set_bounds (type, &low_bound, &high_bound))
  if (get_long_set_bounds (type, &low_bound, &high_bound))
    {
    {
      field = TYPE_N_BASECLASSES (type);
      field = TYPE_N_BASECLASSES (type);
      range = TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, field));
      range = TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, field));
    }
    }
  else
  else
    {
    {
      fprintf_filtered (stream, " %s }", _("<unknown bounds of set>"));
      fprintf_filtered (stream, " %s }", _("<unknown bounds of set>"));
      return;
      return;
    }
    }
 
 
  target = TYPE_TARGET_TYPE (range);
  target = TYPE_TARGET_TYPE (range);
 
 
  if (get_discrete_bounds (range, &field_low, &field_high) >= 0)
  if (get_discrete_bounds (range, &field_low, &field_high) >= 0)
    {
    {
      for (i = low_bound; i <= high_bound; i++)
      for (i = low_bound; i <= high_bound; i++)
        {
        {
          bitval = value_bit_index (TYPE_FIELD_TYPE (type, field),
          bitval = value_bit_index (TYPE_FIELD_TYPE (type, field),
                                    (TYPE_FIELD_BITPOS (type, field) / 8) +
                                    (TYPE_FIELD_BITPOS (type, field) / 8) +
                                    valaddr + embedded_offset, i);
                                    valaddr + embedded_offset, i);
          if (bitval < 0)
          if (bitval < 0)
            error (_("bit test is out of range"));
            error (_("bit test is out of range"));
          else if (bitval > 0)
          else if (bitval > 0)
            {
            {
              previous_high = i;
              previous_high = i;
              if (! element_seen)
              if (! element_seen)
                {
                {
                  if (! empty_set)
                  if (! empty_set)
                    fprintf_filtered (stream, ", ");
                    fprintf_filtered (stream, ", ");
                  print_type_scalar (target, i, stream);
                  print_type_scalar (target, i, stream);
                  empty_set    = 0;
                  empty_set    = 0;
                  element_seen = 1;
                  element_seen = 1;
                  previous_low = i;
                  previous_low = i;
                }
                }
            }
            }
          else
          else
            {
            {
              /* bit is not set */
              /* bit is not set */
              if (element_seen)
              if (element_seen)
                {
                {
                  if (previous_low+1 < previous_high)
                  if (previous_low+1 < previous_high)
                    fprintf_filtered (stream, "..");
                    fprintf_filtered (stream, "..");
                  if (previous_low+1 < previous_high)
                  if (previous_low+1 < previous_high)
                    print_type_scalar (target, previous_high, stream);
                    print_type_scalar (target, previous_high, stream);
                  element_seen = 0;
                  element_seen = 0;
                }
                }
            }
            }
          if (i == field_high)
          if (i == field_high)
            {
            {
              field++;
              field++;
              if (field == len)
              if (field == len)
                break;
                break;
              range = TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, field));
              range = TYPE_INDEX_TYPE (TYPE_FIELD_TYPE (type, field));
              if (get_discrete_bounds (range, &field_low, &field_high) < 0)
              if (get_discrete_bounds (range, &field_low, &field_high) < 0)
                break;
                break;
              target = TYPE_TARGET_TYPE (range);
              target = TYPE_TARGET_TYPE (range);
            }
            }
        }
        }
      if (element_seen)
      if (element_seen)
        {
        {
          if (previous_low+1 < previous_high)
          if (previous_low+1 < previous_high)
            {
            {
              fprintf_filtered (stream, "..");
              fprintf_filtered (stream, "..");
              print_type_scalar (target, previous_high, stream);
              print_type_scalar (target, previous_high, stream);
            }
            }
          element_seen = 0;
          element_seen = 0;
        }
        }
      fprintf_filtered (stream, "}");
      fprintf_filtered (stream, "}");
    }
    }
}
}
 
 
static void
static void
m2_print_unbounded_array (struct type *type, const gdb_byte *valaddr,
m2_print_unbounded_array (struct type *type, const gdb_byte *valaddr,
                          int embedded_offset, CORE_ADDR address,
                          int embedded_offset, CORE_ADDR address,
                          struct ui_file *stream, int recurse,
                          struct ui_file *stream, int recurse,
                          const struct value_print_options *options)
                          const struct value_print_options *options)
{
{
  struct type *content_type;
  struct type *content_type;
  CORE_ADDR addr;
  CORE_ADDR addr;
  LONGEST len;
  LONGEST len;
  struct value *val;
  struct value *val;
 
 
  CHECK_TYPEDEF (type);
  CHECK_TYPEDEF (type);
  content_type = TYPE_TARGET_TYPE (TYPE_FIELD_TYPE (type, 0));
  content_type = TYPE_TARGET_TYPE (TYPE_FIELD_TYPE (type, 0));
 
 
  addr = unpack_pointer (TYPE_FIELD_TYPE (type, 0),
  addr = unpack_pointer (TYPE_FIELD_TYPE (type, 0),
                         (TYPE_FIELD_BITPOS (type, 0) / 8) +
                         (TYPE_FIELD_BITPOS (type, 0) / 8) +
                         valaddr + embedded_offset);
                         valaddr + embedded_offset);
 
 
  val = value_at_lazy (TYPE_TARGET_TYPE (TYPE_FIELD_TYPE (type, 0)),
  val = value_at_lazy (TYPE_TARGET_TYPE (TYPE_FIELD_TYPE (type, 0)),
                       addr);
                       addr);
  len = unpack_field_as_long (type, valaddr + embedded_offset, 1);
  len = unpack_field_as_long (type, valaddr + embedded_offset, 1);
 
 
  fprintf_filtered (stream, "{");
  fprintf_filtered (stream, "{");
  m2_print_array_contents (value_type (val), value_contents(val),
  m2_print_array_contents (value_type (val), value_contents(val),
                           value_embedded_offset (val), addr, stream,
                           value_embedded_offset (val), addr, stream,
                           recurse, options, len);
                           recurse, options, len);
  fprintf_filtered (stream, ", HIGH = %d}", (int) len);
  fprintf_filtered (stream, ", HIGH = %d}", (int) len);
}
}
 
 
static int
static int
print_unpacked_pointer (struct type *type,
print_unpacked_pointer (struct type *type,
                        CORE_ADDR address, CORE_ADDR addr,
                        CORE_ADDR address, CORE_ADDR addr,
                        const struct value_print_options *options,
                        const struct value_print_options *options,
                        struct ui_file *stream)
                        struct ui_file *stream)
{
{
  struct gdbarch *gdbarch = get_type_arch (type);
  struct gdbarch *gdbarch = get_type_arch (type);
  struct type *elttype = check_typedef (TYPE_TARGET_TYPE (type));
  struct type *elttype = check_typedef (TYPE_TARGET_TYPE (type));
 
 
  if (TYPE_CODE (elttype) == TYPE_CODE_FUNC)
  if (TYPE_CODE (elttype) == TYPE_CODE_FUNC)
    {
    {
      /* Try to print what function it points to.  */
      /* Try to print what function it points to.  */
      print_function_pointer_address (gdbarch, addr, stream,
      print_function_pointer_address (gdbarch, addr, stream,
                                      options->addressprint);
                                      options->addressprint);
      /* Return value is irrelevant except for string pointers.  */
      /* Return value is irrelevant except for string pointers.  */
      return 0;
      return 0;
    }
    }
 
 
  if (options->addressprint && options->format != 's')
  if (options->addressprint && options->format != 's')
    fputs_filtered (paddress (gdbarch, address), stream);
    fputs_filtered (paddress (gdbarch, address), stream);
 
 
  /* For a pointer to char or unsigned char, also print the string
  /* For a pointer to char or unsigned char, also print the string
     pointed to, unless pointer is null.  */
     pointed to, unless pointer is null.  */
 
 
  if (TYPE_LENGTH (elttype) == 1
  if (TYPE_LENGTH (elttype) == 1
      && TYPE_CODE (elttype) == TYPE_CODE_INT
      && TYPE_CODE (elttype) == TYPE_CODE_INT
      && (options->format == 0 || options->format == 's')
      && (options->format == 0 || options->format == 's')
      && addr != 0)
      && addr != 0)
    return val_print_string (TYPE_TARGET_TYPE (type), addr, -1,
    return val_print_string (TYPE_TARGET_TYPE (type), addr, -1,
                             stream, options);
                             stream, options);
 
 
  return 0;
  return 0;
}
}
 
 
static void
static void
print_variable_at_address (struct type *type,
print_variable_at_address (struct type *type,
                           const gdb_byte *valaddr,
                           const gdb_byte *valaddr,
                           struct ui_file *stream,
                           struct ui_file *stream,
                           int recurse,
                           int recurse,
                           const struct value_print_options *options)
                           const struct value_print_options *options)
{
{
  struct gdbarch *gdbarch = get_type_arch (type);
  struct gdbarch *gdbarch = get_type_arch (type);
  CORE_ADDR addr = unpack_pointer (type, valaddr);
  CORE_ADDR addr = unpack_pointer (type, valaddr);
  struct type *elttype = check_typedef (TYPE_TARGET_TYPE (type));
  struct type *elttype = check_typedef (TYPE_TARGET_TYPE (type));
 
 
  fprintf_filtered (stream, "[");
  fprintf_filtered (stream, "[");
  fputs_filtered (paddress (gdbarch, addr), stream);
  fputs_filtered (paddress (gdbarch, addr), stream);
  fprintf_filtered (stream, "] : ");
  fprintf_filtered (stream, "] : ");
 
 
  if (TYPE_CODE (elttype) != TYPE_CODE_UNDEF)
  if (TYPE_CODE (elttype) != TYPE_CODE_UNDEF)
    {
    {
      struct value *deref_val =
      struct value *deref_val =
        value_at (TYPE_TARGET_TYPE (type), unpack_pointer (type, valaddr));
        value_at (TYPE_TARGET_TYPE (type), unpack_pointer (type, valaddr));
      common_val_print (deref_val, stream, recurse, options, current_language);
      common_val_print (deref_val, stream, recurse, options, current_language);
    }
    }
  else
  else
    fputs_filtered ("???", stream);
    fputs_filtered ("???", stream);
}
}
 
 
 
 
/* m2_print_array_contents - prints out the contents of an
/* m2_print_array_contents - prints out the contents of an
                             array up to a max_print values.
                             array up to a max_print values.
                             It prints arrays of char as a string
                             It prints arrays of char as a string
                             and all other data types as comma
                             and all other data types as comma
                             separated values.  */
                             separated values.  */
 
 
static void
static void
m2_print_array_contents (struct type *type, const gdb_byte *valaddr,
m2_print_array_contents (struct type *type, const gdb_byte *valaddr,
                         int embedded_offset, CORE_ADDR address,
                         int embedded_offset, CORE_ADDR address,
                         struct ui_file *stream, int recurse,
                         struct ui_file *stream, int recurse,
                         const struct value_print_options *options,
                         const struct value_print_options *options,
                         int len)
                         int len)
{
{
  int eltlen;
  int eltlen;
  CHECK_TYPEDEF (type);
  CHECK_TYPEDEF (type);
 
 
  if (TYPE_LENGTH (type) > 0)
  if (TYPE_LENGTH (type) > 0)
    {
    {
      eltlen = TYPE_LENGTH (type);
      eltlen = TYPE_LENGTH (type);
      if (options->prettyprint_arrays)
      if (options->prettyprint_arrays)
        print_spaces_filtered (2 + 2 * recurse, stream);
        print_spaces_filtered (2 + 2 * recurse, stream);
      /* For an array of chars, print with string syntax.  */
      /* For an array of chars, print with string syntax.  */
      if (eltlen == 1 &&
      if (eltlen == 1 &&
          ((TYPE_CODE (type) == TYPE_CODE_INT)
          ((TYPE_CODE (type) == TYPE_CODE_INT)
           || ((current_language->la_language == language_m2)
           || ((current_language->la_language == language_m2)
               && (TYPE_CODE (type) == TYPE_CODE_CHAR)))
               && (TYPE_CODE (type) == TYPE_CODE_CHAR)))
          && (options->format == 0 || options->format == 's'))
          && (options->format == 0 || options->format == 's'))
        val_print_string (type, address, len+1, stream, options);
        val_print_string (type, address, len+1, stream, options);
      else
      else
        {
        {
          fprintf_filtered (stream, "{");
          fprintf_filtered (stream, "{");
          val_print_array_elements (type, valaddr + embedded_offset,
          val_print_array_elements (type, valaddr + embedded_offset,
                                    address, stream, recurse, options, 0);
                                    address, stream, recurse, options, 0);
          fprintf_filtered (stream, "}");
          fprintf_filtered (stream, "}");
        }
        }
    }
    }
}
}
 
 
 
 
/* Print data of type TYPE located at VALADDR (within GDB), which came from
/* Print data of type TYPE located at VALADDR (within GDB), which came from
   the inferior at address ADDRESS, onto stdio stream STREAM according to
   the inferior at address ADDRESS, onto stdio stream STREAM according to
   OPTIONS.  The data at VALADDR is in target byte order.
   OPTIONS.  The data at VALADDR is in target byte order.
 
 
   If the data are a string pointer, returns the number of string characters
   If the data are a string pointer, returns the number of string characters
   printed.  */
   printed.  */
 
 
int
int
m2_val_print (struct type *type, const gdb_byte *valaddr, int embedded_offset,
m2_val_print (struct type *type, const gdb_byte *valaddr, int embedded_offset,
              CORE_ADDR address, struct ui_file *stream, int recurse,
              CORE_ADDR address, struct ui_file *stream, int recurse,
              const struct value_print_options *options)
              const struct value_print_options *options)
{
{
  struct gdbarch *gdbarch = get_type_arch (type);
  struct gdbarch *gdbarch = get_type_arch (type);
  unsigned int i = 0;    /* Number of characters printed */
  unsigned int i = 0;    /* Number of characters printed */
  unsigned len;
  unsigned len;
  struct type *elttype;
  struct type *elttype;
  unsigned eltlen;
  unsigned eltlen;
  int length_pos, length_size, string_pos;
  int length_pos, length_size, string_pos;
  int char_size;
  int char_size;
  LONGEST val;
  LONGEST val;
  CORE_ADDR addr;
  CORE_ADDR addr;
 
 
  CHECK_TYPEDEF (type);
  CHECK_TYPEDEF (type);
  switch (TYPE_CODE (type))
  switch (TYPE_CODE (type))
    {
    {
    case TYPE_CODE_ARRAY:
    case TYPE_CODE_ARRAY:
      if (TYPE_LENGTH (type) > 0 && TYPE_LENGTH (TYPE_TARGET_TYPE (type)) > 0)
      if (TYPE_LENGTH (type) > 0 && TYPE_LENGTH (TYPE_TARGET_TYPE (type)) > 0)
        {
        {
          elttype = check_typedef (TYPE_TARGET_TYPE (type));
          elttype = check_typedef (TYPE_TARGET_TYPE (type));
          eltlen = TYPE_LENGTH (elttype);
          eltlen = TYPE_LENGTH (elttype);
          len = TYPE_LENGTH (type) / eltlen;
          len = TYPE_LENGTH (type) / eltlen;
          if (options->prettyprint_arrays)
          if (options->prettyprint_arrays)
            print_spaces_filtered (2 + 2 * recurse, stream);
            print_spaces_filtered (2 + 2 * recurse, stream);
          /* For an array of chars, print with string syntax.  */
          /* For an array of chars, print with string syntax.  */
          if (eltlen == 1 &&
          if (eltlen == 1 &&
              ((TYPE_CODE (elttype) == TYPE_CODE_INT)
              ((TYPE_CODE (elttype) == TYPE_CODE_INT)
               || ((current_language->la_language == language_m2)
               || ((current_language->la_language == language_m2)
                   && (TYPE_CODE (elttype) == TYPE_CODE_CHAR)))
                   && (TYPE_CODE (elttype) == TYPE_CODE_CHAR)))
              && (options->format == 0 || options->format == 's'))
              && (options->format == 0 || options->format == 's'))
            {
            {
              /* If requested, look for the first null char and only print
              /* If requested, look for the first null char and only print
                 elements up to it.  */
                 elements up to it.  */
              if (options->stop_print_at_null)
              if (options->stop_print_at_null)
                {
                {
                  unsigned int temp_len;
                  unsigned int temp_len;
 
 
                  /* Look for a NULL char. */
                  /* Look for a NULL char. */
                  for (temp_len = 0;
                  for (temp_len = 0;
                       (valaddr + embedded_offset)[temp_len]
                       (valaddr + embedded_offset)[temp_len]
                         && temp_len < len && temp_len < options->print_max;
                         && temp_len < len && temp_len < options->print_max;
                       temp_len++);
                       temp_len++);
                  len = temp_len;
                  len = temp_len;
                }
                }
 
 
              LA_PRINT_STRING (stream, TYPE_TARGET_TYPE (type),
              LA_PRINT_STRING (stream, TYPE_TARGET_TYPE (type),
                               valaddr + embedded_offset, len, NULL,
                               valaddr + embedded_offset, len, NULL,
                               0, options);
                               0, options);
              i = len;
              i = len;
            }
            }
          else
          else
            {
            {
              fprintf_filtered (stream, "{");
              fprintf_filtered (stream, "{");
              val_print_array_elements (type, valaddr + embedded_offset,
              val_print_array_elements (type, valaddr + embedded_offset,
                                        address, stream, recurse, options, 0);
                                        address, stream, recurse, options, 0);
              fprintf_filtered (stream, "}");
              fprintf_filtered (stream, "}");
            }
            }
          break;
          break;
        }
        }
      /* Array of unspecified length: treat like pointer to first elt.  */
      /* Array of unspecified length: treat like pointer to first elt.  */
      print_unpacked_pointer (type, address, address, options, stream);
      print_unpacked_pointer (type, address, address, options, stream);
      break;
      break;
 
 
    case TYPE_CODE_PTR:
    case TYPE_CODE_PTR:
      if (TYPE_CONST (type))
      if (TYPE_CONST (type))
        print_variable_at_address (type, valaddr + embedded_offset,
        print_variable_at_address (type, valaddr + embedded_offset,
                                   stream, recurse, options);
                                   stream, recurse, options);
      else if (options->format && options->format != 's')
      else if (options->format && options->format != 's')
        print_scalar_formatted (valaddr + embedded_offset, type,
        print_scalar_formatted (valaddr + embedded_offset, type,
                                options, 0, stream);
                                options, 0, stream);
      else
      else
        {
        {
          addr = unpack_pointer (type, valaddr + embedded_offset);
          addr = unpack_pointer (type, valaddr + embedded_offset);
          print_unpacked_pointer (type, addr, address, options, stream);
          print_unpacked_pointer (type, addr, address, options, stream);
        }
        }
      break;
      break;
 
 
    case TYPE_CODE_REF:
    case TYPE_CODE_REF:
      elttype = check_typedef (TYPE_TARGET_TYPE (type));
      elttype = check_typedef (TYPE_TARGET_TYPE (type));
      if (options->addressprint)
      if (options->addressprint)
        {
        {
          CORE_ADDR addr
          CORE_ADDR addr
            = extract_typed_address (valaddr + embedded_offset, type);
            = extract_typed_address (valaddr + embedded_offset, type);
          fprintf_filtered (stream, "@");
          fprintf_filtered (stream, "@");
          fputs_filtered (paddress (gdbarch, addr), stream);
          fputs_filtered (paddress (gdbarch, addr), stream);
          if (options->deref_ref)
          if (options->deref_ref)
            fputs_filtered (": ", stream);
            fputs_filtered (": ", stream);
        }
        }
      /* De-reference the reference.  */
      /* De-reference the reference.  */
      if (options->deref_ref)
      if (options->deref_ref)
        {
        {
          if (TYPE_CODE (elttype) != TYPE_CODE_UNDEF)
          if (TYPE_CODE (elttype) != TYPE_CODE_UNDEF)
            {
            {
              struct value *deref_val =
              struct value *deref_val =
                value_at
                value_at
                (TYPE_TARGET_TYPE (type),
                (TYPE_TARGET_TYPE (type),
                 unpack_pointer (type, valaddr + embedded_offset));
                 unpack_pointer (type, valaddr + embedded_offset));
              common_val_print (deref_val, stream, recurse, options,
              common_val_print (deref_val, stream, recurse, options,
                                current_language);
                                current_language);
            }
            }
          else
          else
            fputs_filtered ("???", stream);
            fputs_filtered ("???", stream);
        }
        }
      break;
      break;
 
 
    case TYPE_CODE_UNION:
    case TYPE_CODE_UNION:
      if (recurse && !options->unionprint)
      if (recurse && !options->unionprint)
        {
        {
          fprintf_filtered (stream, "{...}");
          fprintf_filtered (stream, "{...}");
          break;
          break;
        }
        }
      /* Fall through.  */
      /* Fall through.  */
    case TYPE_CODE_STRUCT:
    case TYPE_CODE_STRUCT:
      if (m2_is_long_set (type))
      if (m2_is_long_set (type))
        m2_print_long_set (type, valaddr, embedded_offset, address,
        m2_print_long_set (type, valaddr, embedded_offset, address,
                           stream);
                           stream);
      else if (m2_is_unbounded_array (type))
      else if (m2_is_unbounded_array (type))
        m2_print_unbounded_array (type, valaddr, embedded_offset,
        m2_print_unbounded_array (type, valaddr, embedded_offset,
                                  address, stream, recurse, options);
                                  address, stream, recurse, options);
      else
      else
        cp_print_value_fields (type, type, valaddr, embedded_offset,
        cp_print_value_fields (type, type, valaddr, embedded_offset,
                               address, stream, recurse, options, NULL, 0);
                               address, stream, recurse, options, NULL, 0);
      break;
      break;
 
 
    case TYPE_CODE_ENUM:
    case TYPE_CODE_ENUM:
      if (options->format)
      if (options->format)
        {
        {
          print_scalar_formatted (valaddr + embedded_offset, type,
          print_scalar_formatted (valaddr + embedded_offset, type,
                                  options, 0, stream);
                                  options, 0, stream);
          break;
          break;
        }
        }
      len = TYPE_NFIELDS (type);
      len = TYPE_NFIELDS (type);
      val = unpack_long (type, valaddr + embedded_offset);
      val = unpack_long (type, valaddr + embedded_offset);
      for (i = 0; i < len; i++)
      for (i = 0; i < len; i++)
        {
        {
          QUIT;
          QUIT;
          if (val == TYPE_FIELD_BITPOS (type, i))
          if (val == TYPE_FIELD_BITPOS (type, i))
            {
            {
              break;
              break;
            }
            }
        }
        }
      if (i < len)
      if (i < len)
        {
        {
          fputs_filtered (TYPE_FIELD_NAME (type, i), stream);
          fputs_filtered (TYPE_FIELD_NAME (type, i), stream);
        }
        }
      else
      else
        {
        {
          print_longest (stream, 'd', 0, val);
          print_longest (stream, 'd', 0, val);
        }
        }
      break;
      break;
 
 
    case TYPE_CODE_FUNC:
    case TYPE_CODE_FUNC:
      if (options->format)
      if (options->format)
        {
        {
          print_scalar_formatted (valaddr + embedded_offset, type,
          print_scalar_formatted (valaddr + embedded_offset, type,
                                  options, 0, stream);
                                  options, 0, stream);
          break;
          break;
        }
        }
      /* FIXME, we should consider, at least for ANSI C language, eliminating
      /* FIXME, we should consider, at least for ANSI C language, eliminating
         the distinction made between FUNCs and POINTERs to FUNCs.  */
         the distinction made between FUNCs and POINTERs to FUNCs.  */
      fprintf_filtered (stream, "{");
      fprintf_filtered (stream, "{");
      type_print (type, "", stream, -1);
      type_print (type, "", stream, -1);
      fprintf_filtered (stream, "} ");
      fprintf_filtered (stream, "} ");
      /* Try to print what function it points to, and its address.  */
      /* Try to print what function it points to, and its address.  */
      print_address_demangle (gdbarch, address, stream, demangle);
      print_address_demangle (gdbarch, address, stream, demangle);
      break;
      break;
 
 
    case TYPE_CODE_BOOL:
    case TYPE_CODE_BOOL:
      if (options->format || options->output_format)
      if (options->format || options->output_format)
        {
        {
          struct value_print_options opts = *options;
          struct value_print_options opts = *options;
          opts.format = (options->format ? options->format
          opts.format = (options->format ? options->format
                         : options->output_format);
                         : options->output_format);
          print_scalar_formatted (valaddr + embedded_offset, type,
          print_scalar_formatted (valaddr + embedded_offset, type,
                                  &opts, 0, stream);
                                  &opts, 0, stream);
        }
        }
      else
      else
        {
        {
          val = unpack_long (type, valaddr + embedded_offset);
          val = unpack_long (type, valaddr + embedded_offset);
          if (val == 0)
          if (val == 0)
            fputs_filtered ("FALSE", stream);
            fputs_filtered ("FALSE", stream);
          else if (val == 1)
          else if (val == 1)
            fputs_filtered ("TRUE", stream);
            fputs_filtered ("TRUE", stream);
          else
          else
            fprintf_filtered (stream, "%ld)", (long int) val);
            fprintf_filtered (stream, "%ld)", (long int) val);
        }
        }
      break;
      break;
 
 
    case TYPE_CODE_RANGE:
    case TYPE_CODE_RANGE:
      if (TYPE_LENGTH (type) == TYPE_LENGTH (TYPE_TARGET_TYPE (type)))
      if (TYPE_LENGTH (type) == TYPE_LENGTH (TYPE_TARGET_TYPE (type)))
        {
        {
          m2_val_print (TYPE_TARGET_TYPE (type), valaddr, embedded_offset,
          m2_val_print (TYPE_TARGET_TYPE (type), valaddr, embedded_offset,
                        address, stream, recurse, options);
                        address, stream, recurse, options);
          break;
          break;
        }
        }
      /* FIXME: create_range_type does not set the unsigned bit in a
      /* FIXME: create_range_type does not set the unsigned bit in a
         range type (I think it probably should copy it from the target
         range type (I think it probably should copy it from the target
         type), so we won't print values which are too large to
         type), so we won't print values which are too large to
         fit in a signed integer correctly.  */
         fit in a signed integer correctly.  */
      /* FIXME: Doesn't handle ranges of enums correctly.  (Can't just
      /* FIXME: Doesn't handle ranges of enums correctly.  (Can't just
         print with the target type, though, because the size of our type
         print with the target type, though, because the size of our type
         and the target type might differ).  */
         and the target type might differ).  */
      /* FALLTHROUGH */
      /* FALLTHROUGH */
 
 
    case TYPE_CODE_INT:
    case TYPE_CODE_INT:
      if (options->format || options->output_format)
      if (options->format || options->output_format)
        {
        {
          struct value_print_options opts = *options;
          struct value_print_options opts = *options;
          opts.format = (options->format ? options->format
          opts.format = (options->format ? options->format
                         : options->output_format);
                         : options->output_format);
          print_scalar_formatted (valaddr + embedded_offset, type,
          print_scalar_formatted (valaddr + embedded_offset, type,
                                  &opts, 0, stream);
                                  &opts, 0, stream);
        }
        }
      else
      else
        val_print_type_code_int (type, valaddr + embedded_offset, stream);
        val_print_type_code_int (type, valaddr + embedded_offset, stream);
      break;
      break;
 
 
    case TYPE_CODE_CHAR:
    case TYPE_CODE_CHAR:
      if (options->format || options->output_format)
      if (options->format || options->output_format)
        {
        {
          struct value_print_options opts = *options;
          struct value_print_options opts = *options;
          opts.format = (options->format ? options->format
          opts.format = (options->format ? options->format
                         : options->output_format);
                         : options->output_format);
          print_scalar_formatted (valaddr + embedded_offset, type,
          print_scalar_formatted (valaddr + embedded_offset, type,
                                  &opts, 0, stream);
                                  &opts, 0, stream);
        }
        }
      else
      else
        {
        {
          val = unpack_long (type, valaddr + embedded_offset);
          val = unpack_long (type, valaddr + embedded_offset);
          if (TYPE_UNSIGNED (type))
          if (TYPE_UNSIGNED (type))
            fprintf_filtered (stream, "%u", (unsigned int) val);
            fprintf_filtered (stream, "%u", (unsigned int) val);
          else
          else
            fprintf_filtered (stream, "%d", (int) val);
            fprintf_filtered (stream, "%d", (int) val);
          fputs_filtered (" ", stream);
          fputs_filtered (" ", stream);
          LA_PRINT_CHAR ((unsigned char) val, type, stream);
          LA_PRINT_CHAR ((unsigned char) val, type, stream);
        }
        }
      break;
      break;
 
 
    case TYPE_CODE_FLT:
    case TYPE_CODE_FLT:
      if (options->format)
      if (options->format)
        print_scalar_formatted (valaddr + embedded_offset, type,
        print_scalar_formatted (valaddr + embedded_offset, type,
                                options, 0, stream);
                                options, 0, stream);
      else
      else
        print_floating (valaddr + embedded_offset, type, stream);
        print_floating (valaddr + embedded_offset, type, stream);
      break;
      break;
 
 
    case TYPE_CODE_METHOD:
    case TYPE_CODE_METHOD:
      break;
      break;
 
 
    case TYPE_CODE_BITSTRING:
    case TYPE_CODE_BITSTRING:
    case TYPE_CODE_SET:
    case TYPE_CODE_SET:
      elttype = TYPE_INDEX_TYPE (type);
      elttype = TYPE_INDEX_TYPE (type);
      CHECK_TYPEDEF (elttype);
      CHECK_TYPEDEF (elttype);
      if (TYPE_STUB (elttype))
      if (TYPE_STUB (elttype))
        {
        {
          fprintf_filtered (stream, _("<incomplete type>"));
          fprintf_filtered (stream, _("<incomplete type>"));
          gdb_flush (stream);
          gdb_flush (stream);
          break;
          break;
        }
        }
      else
      else
        {
        {
          struct type *range = elttype;
          struct type *range = elttype;
          LONGEST low_bound, high_bound;
          LONGEST low_bound, high_bound;
          int i;
          int i;
          int is_bitstring = TYPE_CODE (type) == TYPE_CODE_BITSTRING;
          int is_bitstring = TYPE_CODE (type) == TYPE_CODE_BITSTRING;
          int need_comma = 0;
          int need_comma = 0;
 
 
          if (is_bitstring)
          if (is_bitstring)
            fputs_filtered ("B'", stream);
            fputs_filtered ("B'", stream);
          else
          else
            fputs_filtered ("{", stream);
            fputs_filtered ("{", stream);
 
 
          i = get_discrete_bounds (range, &low_bound, &high_bound);
          i = get_discrete_bounds (range, &low_bound, &high_bound);
        maybe_bad_bstring:
        maybe_bad_bstring:
          if (i < 0)
          if (i < 0)
            {
            {
              fputs_filtered (_("<error value>"), stream);
              fputs_filtered (_("<error value>"), stream);
              goto done;
              goto done;
            }
            }
 
 
          for (i = low_bound; i <= high_bound; i++)
          for (i = low_bound; i <= high_bound; i++)
            {
            {
              int element = value_bit_index (type, valaddr + embedded_offset,
              int element = value_bit_index (type, valaddr + embedded_offset,
                                             i);
                                             i);
              if (element < 0)
              if (element < 0)
                {
                {
                  i = element;
                  i = element;
                  goto maybe_bad_bstring;
                  goto maybe_bad_bstring;
                }
                }
              if (is_bitstring)
              if (is_bitstring)
                fprintf_filtered (stream, "%d", element);
                fprintf_filtered (stream, "%d", element);
              else if (element)
              else if (element)
                {
                {
                  if (need_comma)
                  if (need_comma)
                    fputs_filtered (", ", stream);
                    fputs_filtered (", ", stream);
                  print_type_scalar (range, i, stream);
                  print_type_scalar (range, i, stream);
                  need_comma = 1;
                  need_comma = 1;
 
 
                  if (i + 1 <= high_bound
                  if (i + 1 <= high_bound
                      && value_bit_index (type, valaddr + embedded_offset,
                      && value_bit_index (type, valaddr + embedded_offset,
                                          ++i))
                                          ++i))
                    {
                    {
                      int j = i;
                      int j = i;
                      fputs_filtered ("..", stream);
                      fputs_filtered ("..", stream);
                      while (i + 1 <= high_bound
                      while (i + 1 <= high_bound
                             && value_bit_index (type,
                             && value_bit_index (type,
                                                 valaddr + embedded_offset,
                                                 valaddr + embedded_offset,
                                                 ++i))
                                                 ++i))
                        j = i;
                        j = i;
                      print_type_scalar (range, j, stream);
                      print_type_scalar (range, j, stream);
                    }
                    }
                }
                }
            }
            }
        done:
        done:
          if (is_bitstring)
          if (is_bitstring)
            fputs_filtered ("'", stream);
            fputs_filtered ("'", stream);
          else
          else
            fputs_filtered ("}", stream);
            fputs_filtered ("}", stream);
        }
        }
      break;
      break;
 
 
    case TYPE_CODE_VOID:
    case TYPE_CODE_VOID:
      fprintf_filtered (stream, "void");
      fprintf_filtered (stream, "void");
      break;
      break;
 
 
    case TYPE_CODE_ERROR:
    case TYPE_CODE_ERROR:
      fprintf_filtered (stream, _("<error type>"));
      fprintf_filtered (stream, _("<error type>"));
      break;
      break;
 
 
    case TYPE_CODE_UNDEF:
    case TYPE_CODE_UNDEF:
      /* This happens (without TYPE_FLAG_STUB set) on systems which don't use
      /* This happens (without TYPE_FLAG_STUB set) on systems which don't use
         dbx xrefs (NO_DBX_XREFS in gcc) if a file has a "struct foo *bar"
         dbx xrefs (NO_DBX_XREFS in gcc) if a file has a "struct foo *bar"
         and no complete type for struct foo in that file.  */
         and no complete type for struct foo in that file.  */
      fprintf_filtered (stream, _("<incomplete type>"));
      fprintf_filtered (stream, _("<incomplete type>"));
      break;
      break;
 
 
    default:
    default:
      error (_("Invalid m2 type code %d in symbol table."), TYPE_CODE (type));
      error (_("Invalid m2 type code %d in symbol table."), TYPE_CODE (type));
    }
    }
  gdb_flush (stream);
  gdb_flush (stream);
  return (0);
  return (0);
}
}
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.