OpenCores
URL https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk

Subversion Repositories openrisc_2011-10-31

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc1/] [gcc/] [cp/] [dump.c] - Diff between revs 283 and 338

Only display areas with differences | Details | Blame | View Log

Rev 283 Rev 338
/* Tree-dumping functionality for intermediate representation.
/* Tree-dumping functionality for intermediate representation.
   Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007, 2008
   Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007, 2008
   Free Software Foundation, Inc.
   Free Software Foundation, Inc.
   Written by Mark Mitchell <mark@codesourcery.com>
   Written by Mark Mitchell <mark@codesourcery.com>
 
 
This file is part of GCC.
This file is part of GCC.
 
 
GCC is free software; you can redistribute it and/or modify
GCC 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, or (at your option)
the Free Software Foundation; either version 3, or (at your option)
any later version.
any later version.
 
 
GCC is distributed in the hope that it will be useful,
GCC 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 GCC; see the file COPYING3.  If not see
along with GCC; see the file COPYING3.  If not see
<http://www.gnu.org/licenses/>.  */
<http://www.gnu.org/licenses/>.  */
 
 
#include "config.h"
#include "config.h"
#include "system.h"
#include "system.h"
#include "coretypes.h"
#include "coretypes.h"
#include "tm.h"
#include "tm.h"
#include "tree.h"
#include "tree.h"
#include "cp-tree.h"
#include "cp-tree.h"
#include "tree-dump.h"
#include "tree-dump.h"
 
 
static void dump_access (dump_info_p, tree);
static void dump_access (dump_info_p, tree);
 
 
static void dump_op (dump_info_p, tree);
static void dump_op (dump_info_p, tree);
 
 
/* Dump a representation of the accessibility information associated
/* Dump a representation of the accessibility information associated
   with T.  */
   with T.  */
 
 
static void
static void
dump_access (dump_info_p di, tree t)
dump_access (dump_info_p di, tree t)
{
{
  if (TREE_PROTECTED(t))
  if (TREE_PROTECTED(t))
    dump_string_field (di, "accs", "prot");
    dump_string_field (di, "accs", "prot");
  else if (TREE_PRIVATE(t))
  else if (TREE_PRIVATE(t))
    dump_string_field (di, "accs", "priv");
    dump_string_field (di, "accs", "priv");
  else
  else
    dump_string_field (di, "accs", "pub");
    dump_string_field (di, "accs", "pub");
}
}
 
 
/* Dump a representation of the specific operator for an overloaded
/* Dump a representation of the specific operator for an overloaded
   operator associated with node t.  */
   operator associated with node t.  */
 
 
static void
static void
dump_op (dump_info_p di, tree t)
dump_op (dump_info_p di, tree t)
{
{
  switch (DECL_OVERLOADED_OPERATOR_P (t)) {
  switch (DECL_OVERLOADED_OPERATOR_P (t)) {
    case NEW_EXPR:
    case NEW_EXPR:
      dump_string (di, "new");
      dump_string (di, "new");
      break;
      break;
    case VEC_NEW_EXPR:
    case VEC_NEW_EXPR:
      dump_string (di, "vecnew");
      dump_string (di, "vecnew");
      break;
      break;
    case DELETE_EXPR:
    case DELETE_EXPR:
      dump_string (di, "delete");
      dump_string (di, "delete");
      break;
      break;
    case VEC_DELETE_EXPR:
    case VEC_DELETE_EXPR:
      dump_string (di, "vecdelete");
      dump_string (di, "vecdelete");
      break;
      break;
    case UNARY_PLUS_EXPR:
    case UNARY_PLUS_EXPR:
      dump_string (di, "pos");
      dump_string (di, "pos");
      break;
      break;
    case NEGATE_EXPR:
    case NEGATE_EXPR:
      dump_string (di, "neg");
      dump_string (di, "neg");
      break;
      break;
    case ADDR_EXPR:
    case ADDR_EXPR:
      dump_string (di, "addr");
      dump_string (di, "addr");
      break;
      break;
    case INDIRECT_REF:
    case INDIRECT_REF:
      dump_string(di, "deref");
      dump_string(di, "deref");
      break;
      break;
    case BIT_NOT_EXPR:
    case BIT_NOT_EXPR:
      dump_string(di, "not");
      dump_string(di, "not");
      break;
      break;
    case TRUTH_NOT_EXPR:
    case TRUTH_NOT_EXPR:
      dump_string(di, "lnot");
      dump_string(di, "lnot");
      break;
      break;
    case PREINCREMENT_EXPR:
    case PREINCREMENT_EXPR:
      dump_string(di, "preinc");
      dump_string(di, "preinc");
      break;
      break;
    case PREDECREMENT_EXPR:
    case PREDECREMENT_EXPR:
      dump_string(di, "predec");
      dump_string(di, "predec");
      break;
      break;
    case PLUS_EXPR:
    case PLUS_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "plusassign");
        dump_string (di, "plusassign");
      else
      else
        dump_string(di, "plus");
        dump_string(di, "plus");
      break;
      break;
    case MINUS_EXPR:
    case MINUS_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "minusassign");
        dump_string (di, "minusassign");
      else
      else
        dump_string(di, "minus");
        dump_string(di, "minus");
      break;
      break;
    case MULT_EXPR:
    case MULT_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "multassign");
        dump_string (di, "multassign");
      else
      else
        dump_string (di, "mult");
        dump_string (di, "mult");
      break;
      break;
    case TRUNC_DIV_EXPR:
    case TRUNC_DIV_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "divassign");
        dump_string (di, "divassign");
      else
      else
        dump_string (di, "div");
        dump_string (di, "div");
      break;
      break;
    case TRUNC_MOD_EXPR:
    case TRUNC_MOD_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
         dump_string (di, "modassign");
         dump_string (di, "modassign");
      else
      else
        dump_string (di, "mod");
        dump_string (di, "mod");
      break;
      break;
    case BIT_AND_EXPR:
    case BIT_AND_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "andassign");
        dump_string (di, "andassign");
      else
      else
        dump_string (di, "and");
        dump_string (di, "and");
      break;
      break;
    case BIT_IOR_EXPR:
    case BIT_IOR_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "orassign");
        dump_string (di, "orassign");
      else
      else
        dump_string (di, "or");
        dump_string (di, "or");
      break;
      break;
    case BIT_XOR_EXPR:
    case BIT_XOR_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "xorassign");
        dump_string (di, "xorassign");
      else
      else
        dump_string (di, "xor");
        dump_string (di, "xor");
      break;
      break;
    case LSHIFT_EXPR:
    case LSHIFT_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "lshiftassign");
        dump_string (di, "lshiftassign");
      else
      else
        dump_string (di, "lshift");
        dump_string (di, "lshift");
      break;
      break;
    case RSHIFT_EXPR:
    case RSHIFT_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "rshiftassign");
        dump_string (di, "rshiftassign");
      else
      else
        dump_string (di, "rshift");
        dump_string (di, "rshift");
      break;
      break;
    case EQ_EXPR:
    case EQ_EXPR:
      dump_string (di, "eq");
      dump_string (di, "eq");
      break;
      break;
    case NE_EXPR:
    case NE_EXPR:
      dump_string (di, "ne");
      dump_string (di, "ne");
      break;
      break;
    case LT_EXPR:
    case LT_EXPR:
      dump_string (di, "lt");
      dump_string (di, "lt");
      break;
      break;
    case GT_EXPR:
    case GT_EXPR:
      dump_string (di, "gt");
      dump_string (di, "gt");
      break;
      break;
    case LE_EXPR:
    case LE_EXPR:
      dump_string (di, "le");
      dump_string (di, "le");
      break;
      break;
    case GE_EXPR:
    case GE_EXPR:
      dump_string (di, "ge");
      dump_string (di, "ge");
      break;
      break;
    case TRUTH_ANDIF_EXPR:
    case TRUTH_ANDIF_EXPR:
      dump_string (di, "land");
      dump_string (di, "land");
      break;
      break;
    case TRUTH_ORIF_EXPR:
    case TRUTH_ORIF_EXPR:
      dump_string (di, "lor");
      dump_string (di, "lor");
      break;
      break;
    case COMPOUND_EXPR:
    case COMPOUND_EXPR:
      dump_string (di, "compound");
      dump_string (di, "compound");
      break;
      break;
    case MEMBER_REF:
    case MEMBER_REF:
      dump_string (di, "memref");
      dump_string (di, "memref");
      break;
      break;
    case COMPONENT_REF:
    case COMPONENT_REF:
      dump_string (di, "ref");
      dump_string (di, "ref");
      break;
      break;
    case ARRAY_REF:
    case ARRAY_REF:
      dump_string (di, "subs");
      dump_string (di, "subs");
      break;
      break;
    case POSTINCREMENT_EXPR:
    case POSTINCREMENT_EXPR:
      dump_string (di, "postinc");
      dump_string (di, "postinc");
      break;
      break;
    case POSTDECREMENT_EXPR:
    case POSTDECREMENT_EXPR:
      dump_string (di, "postdec");
      dump_string (di, "postdec");
      break;
      break;
    case CALL_EXPR:
    case CALL_EXPR:
      dump_string (di, "call");
      dump_string (di, "call");
      break;
      break;
    case NOP_EXPR:
    case NOP_EXPR:
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
      if (DECL_ASSIGNMENT_OPERATOR_P (t))
        dump_string (di, "assign");
        dump_string (di, "assign");
      break;
      break;
    default:
    default:
      break;
      break;
  }
  }
}
}
 
 
bool
bool
cp_dump_tree (void* dump_info, tree t)
cp_dump_tree (void* dump_info, tree t)
{
{
  enum tree_code code;
  enum tree_code code;
  dump_info_p di = (dump_info_p) dump_info;
  dump_info_p di = (dump_info_p) dump_info;
 
 
  /* Figure out what kind of node this is.  */
  /* Figure out what kind of node this is.  */
  code = TREE_CODE (t);
  code = TREE_CODE (t);
 
 
  if (DECL_P (t))
  if (DECL_P (t))
    {
    {
      if (DECL_LANG_SPECIFIC (t) && DECL_LANGUAGE (t) != lang_cplusplus)
      if (DECL_LANG_SPECIFIC (t) && DECL_LANGUAGE (t) != lang_cplusplus)
        dump_string_field (di, "lang", language_to_string (DECL_LANGUAGE (t)));
        dump_string_field (di, "lang", language_to_string (DECL_LANGUAGE (t)));
    }
    }
 
 
  switch (code)
  switch (code)
    {
    {
    case IDENTIFIER_NODE:
    case IDENTIFIER_NODE:
      if (IDENTIFIER_OPNAME_P (t))
      if (IDENTIFIER_OPNAME_P (t))
        {
        {
          dump_string_field (di, "note", "operator");
          dump_string_field (di, "note", "operator");
          return true;
          return true;
        }
        }
      else if (IDENTIFIER_TYPENAME_P (t))
      else if (IDENTIFIER_TYPENAME_P (t))
        {
        {
          dump_child ("tynm", TREE_TYPE (t));
          dump_child ("tynm", TREE_TYPE (t));
          return true;
          return true;
        }
        }
      break;
      break;
 
 
    case OFFSET_TYPE:
    case OFFSET_TYPE:
      dump_string_field (di, "note", "ptrmem");
      dump_string_field (di, "note", "ptrmem");
      dump_child ("ptd", TYPE_PTRMEM_POINTED_TO_TYPE (t));
      dump_child ("ptd", TYPE_PTRMEM_POINTED_TO_TYPE (t));
      dump_child ("cls", TYPE_PTRMEM_CLASS_TYPE (t));
      dump_child ("cls", TYPE_PTRMEM_CLASS_TYPE (t));
      return true;
      return true;
 
 
    case RECORD_TYPE:
    case RECORD_TYPE:
      if (TYPE_PTRMEMFUNC_P (t))
      if (TYPE_PTRMEMFUNC_P (t))
        {
        {
          dump_string_field (di, "note", "ptrmem");
          dump_string_field (di, "note", "ptrmem");
          dump_child ("ptd", TYPE_PTRMEM_POINTED_TO_TYPE (t));
          dump_child ("ptd", TYPE_PTRMEM_POINTED_TO_TYPE (t));
          dump_child ("cls", TYPE_PTRMEM_CLASS_TYPE (t));
          dump_child ("cls", TYPE_PTRMEM_CLASS_TYPE (t));
          return true;
          return true;
        }
        }
      /* Fall through.  */
      /* Fall through.  */
 
 
    case UNION_TYPE:
    case UNION_TYPE:
      /* Is it a type used as a base? */
      /* Is it a type used as a base? */
      if (TYPE_CONTEXT (t) && TREE_CODE (TYPE_CONTEXT (t)) == TREE_CODE (t)
      if (TYPE_CONTEXT (t) && TREE_CODE (TYPE_CONTEXT (t)) == TREE_CODE (t)
          && CLASSTYPE_AS_BASE (TYPE_CONTEXT (t)) == t)
          && CLASSTYPE_AS_BASE (TYPE_CONTEXT (t)) == t)
        {
        {
          dump_child ("bfld", TYPE_CONTEXT (t));
          dump_child ("bfld", TYPE_CONTEXT (t));
          return true;
          return true;
        }
        }
 
 
      if (! MAYBE_CLASS_TYPE_P (t))
      if (! MAYBE_CLASS_TYPE_P (t))
        break;
        break;
 
 
      dump_child ("vfld", TYPE_VFIELD (t));
      dump_child ("vfld", TYPE_VFIELD (t));
      if (CLASSTYPE_TEMPLATE_SPECIALIZATION(t))
      if (CLASSTYPE_TEMPLATE_SPECIALIZATION(t))
        dump_string(di, "spec");
        dump_string(di, "spec");
 
 
      if (!dump_flag (di, TDF_SLIM, t) && TYPE_BINFO (t))
      if (!dump_flag (di, TDF_SLIM, t) && TYPE_BINFO (t))
        {
        {
          int i;
          int i;
          tree binfo;
          tree binfo;
          tree base_binfo;
          tree base_binfo;
 
 
          for (binfo = TYPE_BINFO (t), i = 0;
          for (binfo = TYPE_BINFO (t), i = 0;
               BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
               BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
            {
            {
              dump_child ("base", BINFO_TYPE (base_binfo));
              dump_child ("base", BINFO_TYPE (base_binfo));
              if (BINFO_VIRTUAL_P (base_binfo))
              if (BINFO_VIRTUAL_P (base_binfo))
                dump_string_field (di, "spec", "virt");
                dump_string_field (di, "spec", "virt");
              dump_access (di, base_binfo);
              dump_access (di, base_binfo);
            }
            }
        }
        }
      break;
      break;
 
 
    case FIELD_DECL:
    case FIELD_DECL:
      dump_access (di, t);
      dump_access (di, t);
      if (DECL_MUTABLE_P (t))
      if (DECL_MUTABLE_P (t))
        dump_string_field (di, "spec", "mutable");
        dump_string_field (di, "spec", "mutable");
      break;
      break;
 
 
    case VAR_DECL:
    case VAR_DECL:
      if (TREE_CODE (CP_DECL_CONTEXT (t)) == RECORD_TYPE)
      if (TREE_CODE (CP_DECL_CONTEXT (t)) == RECORD_TYPE)
        dump_access (di, t);
        dump_access (di, t);
      if (TREE_STATIC (t) && !TREE_PUBLIC (t))
      if (TREE_STATIC (t) && !TREE_PUBLIC (t))
        dump_string_field (di, "link", "static");
        dump_string_field (di, "link", "static");
      break;
      break;
 
 
    case FUNCTION_DECL:
    case FUNCTION_DECL:
      if (!DECL_THUNK_P (t))
      if (!DECL_THUNK_P (t))
        {
        {
          if (DECL_OVERLOADED_OPERATOR_P (t)) {
          if (DECL_OVERLOADED_OPERATOR_P (t)) {
            dump_string_field (di, "note", "operator");
            dump_string_field (di, "note", "operator");
            dump_op (di, t);
            dump_op (di, t);
          }
          }
          if (DECL_FUNCTION_MEMBER_P (t))
          if (DECL_FUNCTION_MEMBER_P (t))
            {
            {
              dump_string_field (di, "note", "member");
              dump_string_field (di, "note", "member");
              dump_access (di, t);
              dump_access (di, t);
            }
            }
          if (DECL_PURE_VIRTUAL_P (t))
          if (DECL_PURE_VIRTUAL_P (t))
            dump_string_field (di, "spec", "pure");
            dump_string_field (di, "spec", "pure");
          if (DECL_VIRTUAL_P (t))
          if (DECL_VIRTUAL_P (t))
            dump_string_field (di, "spec", "virt");
            dump_string_field (di, "spec", "virt");
          if (DECL_CONSTRUCTOR_P (t))
          if (DECL_CONSTRUCTOR_P (t))
            dump_string_field (di, "note", "constructor");
            dump_string_field (di, "note", "constructor");
          if (DECL_DESTRUCTOR_P (t))
          if (DECL_DESTRUCTOR_P (t))
            dump_string_field (di, "note", "destructor");
            dump_string_field (di, "note", "destructor");
          if (DECL_CONV_FN_P (t))
          if (DECL_CONV_FN_P (t))
            dump_string_field (di, "note", "conversion");
            dump_string_field (di, "note", "conversion");
          if (DECL_GLOBAL_CTOR_P (t))
          if (DECL_GLOBAL_CTOR_P (t))
            dump_string_field (di, "note", "global init");
            dump_string_field (di, "note", "global init");
          if (DECL_GLOBAL_DTOR_P (t))
          if (DECL_GLOBAL_DTOR_P (t))
            dump_string_field (di, "note", "global fini");
            dump_string_field (di, "note", "global fini");
          if (DECL_FRIEND_PSEUDO_TEMPLATE_INSTANTIATION (t))
          if (DECL_FRIEND_PSEUDO_TEMPLATE_INSTANTIATION (t))
            dump_string_field (di, "note", "pseudo tmpl");
            dump_string_field (di, "note", "pseudo tmpl");
        }
        }
      else
      else
        {
        {
          tree virt = THUNK_VIRTUAL_OFFSET (t);
          tree virt = THUNK_VIRTUAL_OFFSET (t);
 
 
          dump_string_field (di, "note", "thunk");
          dump_string_field (di, "note", "thunk");
          if (DECL_THIS_THUNK_P (t))
          if (DECL_THIS_THUNK_P (t))
            dump_string_field (di, "note", "this adjusting");
            dump_string_field (di, "note", "this adjusting");
          else
          else
            {
            {
              dump_string_field (di, "note", "result adjusting");
              dump_string_field (di, "note", "result adjusting");
              if (virt)
              if (virt)
                virt = BINFO_VPTR_FIELD (virt);
                virt = BINFO_VPTR_FIELD (virt);
            }
            }
          dump_int (di, "fixd", THUNK_FIXED_OFFSET (t));
          dump_int (di, "fixd", THUNK_FIXED_OFFSET (t));
          if (virt)
          if (virt)
            dump_int (di, "virt", tree_low_cst (virt, 0));
            dump_int (di, "virt", tree_low_cst (virt, 0));
          dump_child ("fn", DECL_INITIAL (t));
          dump_child ("fn", DECL_INITIAL (t));
        }
        }
      break;
      break;
 
 
    case NAMESPACE_DECL:
    case NAMESPACE_DECL:
      if (DECL_NAMESPACE_ALIAS (t))
      if (DECL_NAMESPACE_ALIAS (t))
        dump_child ("alis", DECL_NAMESPACE_ALIAS (t));
        dump_child ("alis", DECL_NAMESPACE_ALIAS (t));
      else if (!dump_flag (di, TDF_SLIM, t))
      else if (!dump_flag (di, TDF_SLIM, t))
        dump_child ("dcls", cp_namespace_decls (t));
        dump_child ("dcls", cp_namespace_decls (t));
      break;
      break;
 
 
    case TEMPLATE_DECL:
    case TEMPLATE_DECL:
      dump_child ("rslt", DECL_TEMPLATE_RESULT (t));
      dump_child ("rslt", DECL_TEMPLATE_RESULT (t));
      dump_child ("inst", DECL_TEMPLATE_INSTANTIATIONS (t));
      dump_child ("inst", DECL_TEMPLATE_INSTANTIATIONS (t));
      dump_child ("spcs", DECL_TEMPLATE_SPECIALIZATIONS (t));
      dump_child ("spcs", DECL_TEMPLATE_SPECIALIZATIONS (t));
      dump_child ("prms", DECL_TEMPLATE_PARMS (t));
      dump_child ("prms", DECL_TEMPLATE_PARMS (t));
      break;
      break;
 
 
    case OVERLOAD:
    case OVERLOAD:
      dump_child ("crnt", OVL_CURRENT (t));
      dump_child ("crnt", OVL_CURRENT (t));
      dump_child ("chan", OVL_CHAIN (t));
      dump_child ("chan", OVL_CHAIN (t));
      break;
      break;
 
 
    case TRY_BLOCK:
    case TRY_BLOCK:
      dump_stmt (di, t);
      dump_stmt (di, t);
      if (CLEANUP_P (t))
      if (CLEANUP_P (t))
        dump_string_field (di, "note", "cleanup");
        dump_string_field (di, "note", "cleanup");
      dump_child ("body", TRY_STMTS (t));
      dump_child ("body", TRY_STMTS (t));
      dump_child ("hdlr", TRY_HANDLERS (t));
      dump_child ("hdlr", TRY_HANDLERS (t));
      break;
      break;
 
 
    case EH_SPEC_BLOCK:
    case EH_SPEC_BLOCK:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("body", EH_SPEC_STMTS (t));
      dump_child ("body", EH_SPEC_STMTS (t));
      dump_child ("raises", EH_SPEC_RAISES (t));
      dump_child ("raises", EH_SPEC_RAISES (t));
      break;
      break;
 
 
    case PTRMEM_CST:
    case PTRMEM_CST:
      dump_child ("clas", PTRMEM_CST_CLASS (t));
      dump_child ("clas", PTRMEM_CST_CLASS (t));
      dump_child ("mbr", PTRMEM_CST_MEMBER (t));
      dump_child ("mbr", PTRMEM_CST_MEMBER (t));
      break;
      break;
 
 
    case THROW_EXPR:
    case THROW_EXPR:
      /* These nodes are unary, but do not have code class `1'.  */
      /* These nodes are unary, but do not have code class `1'.  */
      dump_child ("op 0", TREE_OPERAND (t, 0));
      dump_child ("op 0", TREE_OPERAND (t, 0));
      break;
      break;
 
 
    case AGGR_INIT_EXPR:
    case AGGR_INIT_EXPR:
      {
      {
        int i = 0;
        int i = 0;
        tree arg;
        tree arg;
        aggr_init_expr_arg_iterator iter;
        aggr_init_expr_arg_iterator iter;
        dump_int (di, "ctor", AGGR_INIT_VIA_CTOR_P (t));
        dump_int (di, "ctor", AGGR_INIT_VIA_CTOR_P (t));
        dump_child ("fn", AGGR_INIT_EXPR_FN (t));
        dump_child ("fn", AGGR_INIT_EXPR_FN (t));
        FOR_EACH_AGGR_INIT_EXPR_ARG (arg, iter, t)
        FOR_EACH_AGGR_INIT_EXPR_ARG (arg, iter, t)
          {
          {
            char buffer[32];
            char buffer[32];
            sprintf (buffer, "%u", i);
            sprintf (buffer, "%u", i);
            dump_child (buffer, arg);
            dump_child (buffer, arg);
            i++;
            i++;
          }
          }
        dump_child ("decl", AGGR_INIT_EXPR_SLOT (t));
        dump_child ("decl", AGGR_INIT_EXPR_SLOT (t));
      }
      }
      break;
      break;
 
 
    case HANDLER:
    case HANDLER:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("parm", HANDLER_PARMS (t));
      dump_child ("parm", HANDLER_PARMS (t));
      dump_child ("body", HANDLER_BODY (t));
      dump_child ("body", HANDLER_BODY (t));
      break;
      break;
 
 
    case MUST_NOT_THROW_EXPR:
    case MUST_NOT_THROW_EXPR:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("body", TREE_OPERAND (t, 0));
      dump_child ("body", TREE_OPERAND (t, 0));
      break;
      break;
 
 
    case USING_STMT:
    case USING_STMT:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("nmsp", USING_STMT_NAMESPACE (t));
      dump_child ("nmsp", USING_STMT_NAMESPACE (t));
      break;
      break;
 
 
    case CLEANUP_STMT:
    case CLEANUP_STMT:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("decl", CLEANUP_DECL (t));
      dump_child ("decl", CLEANUP_DECL (t));
      dump_child ("expr", CLEANUP_EXPR (t));
      dump_child ("expr", CLEANUP_EXPR (t));
      dump_child ("body", CLEANUP_BODY (t));
      dump_child ("body", CLEANUP_BODY (t));
      break;
      break;
 
 
    case IF_STMT:
    case IF_STMT:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("cond", IF_COND (t));
      dump_child ("cond", IF_COND (t));
      dump_child ("then", THEN_CLAUSE (t));
      dump_child ("then", THEN_CLAUSE (t));
      dump_child ("else", ELSE_CLAUSE (t));
      dump_child ("else", ELSE_CLAUSE (t));
      break;
      break;
 
 
    case BREAK_STMT:
    case BREAK_STMT:
    case CONTINUE_STMT:
    case CONTINUE_STMT:
      dump_stmt (di, t);
      dump_stmt (di, t);
      break;
      break;
 
 
    case DO_STMT:
    case DO_STMT:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("body", DO_BODY (t));
      dump_child ("body", DO_BODY (t));
      dump_child ("cond", DO_COND (t));
      dump_child ("cond", DO_COND (t));
      break;
      break;
 
 
    case FOR_STMT:
    case FOR_STMT:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("init", FOR_INIT_STMT (t));
      dump_child ("init", FOR_INIT_STMT (t));
      dump_child ("cond", FOR_COND (t));
      dump_child ("cond", FOR_COND (t));
      dump_child ("expr", FOR_EXPR (t));
      dump_child ("expr", FOR_EXPR (t));
      dump_child ("body", FOR_BODY (t));
      dump_child ("body", FOR_BODY (t));
      break;
      break;
 
 
    case SWITCH_STMT:
    case SWITCH_STMT:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("cond", SWITCH_STMT_COND (t));
      dump_child ("cond", SWITCH_STMT_COND (t));
      dump_child ("body", SWITCH_STMT_BODY (t));
      dump_child ("body", SWITCH_STMT_BODY (t));
      break;
      break;
 
 
    case WHILE_STMT:
    case WHILE_STMT:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("cond", WHILE_COND (t));
      dump_child ("cond", WHILE_COND (t));
      dump_child ("body", WHILE_BODY (t));
      dump_child ("body", WHILE_BODY (t));
      break;
      break;
 
 
    case STMT_EXPR:
    case STMT_EXPR:
      dump_child ("stmt", STMT_EXPR_STMT (t));
      dump_child ("stmt", STMT_EXPR_STMT (t));
      break;
      break;
 
 
    case EXPR_STMT:
    case EXPR_STMT:
      dump_stmt (di, t);
      dump_stmt (di, t);
      dump_child ("expr", EXPR_STMT_EXPR (t));
      dump_child ("expr", EXPR_STMT_EXPR (t));
      break;
      break;
 
 
    default:
    default:
      break;
      break;
    }
    }
 
 
  return c_dump_tree (di, t);
  return c_dump_tree (di, t);
}
}
 
 

powered by: WebSVN 2.1.0

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