This commit was generated by cvs2svn to track changes on a CVS vendor
[deliverable/binutils-gdb.git] / gdb / jv-typeprint.c
index 59539a0da9ff16d60505e5b059b10cbe27f7cafb..1b60830a854ad41524a8432bc93d48a7b008fbe6 100644 (file)
@@ -1,21 +1,22 @@
 /* Support for printing Java types for GDB, the GNU debugger.
-   Copyright 1997, 1998, 1999 Free Software Foundation, Inc.
+   Copyright 1997-2000 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
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 2 of the License, or
-(at your option) any later version.
+   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
+   the Free Software Foundation; either version 2 of the License, or
+   (at your option) any later version.
 
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
 
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
+   You should have received a copy of the GNU General Public License
+   along with this program; if not, write to the Free Software
+   Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
 
 
 #include "defs.h"
@@ -26,10 +27,17 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 #include "jv-lang.h"
 #include "gdb_string.h"
 #include "typeprint.h"
+#include "c-lang.h"
+
+/* Local functions */
+
+static void java_type_print_base (struct type * type,
+                                 struct ui_file *stream, int show,
+                                 int level);
 
 static void
 java_type_print_derivation_info (stream, type)
-     GDB_FILE *stream;
+     struct ui_file *stream;
      struct type *type;
 {
   char *name;
@@ -43,7 +51,7 @@ java_type_print_derivation_info (stream, type)
     {
       int kind;
 
-      kind = BASETYPE_VIA_VIRTUAL(type, i) ? 'I' : 'E';
+      kind = BASETYPE_VIA_VIRTUAL (type, i) ? 'I' : 'E';
 
       fputs_filtered (kind == prev ? ", "
                      : kind == 'I' ? " implements "
@@ -75,10 +83,10 @@ java_type_print_derivation_info (stream, type)
    LEVEL is the number of spaces to indent by.
    We increase it for some recursive calls.  */
 
-void
+static void
 java_type_print_base (type, stream, show, level)
      struct type *type;
-     GDB_FILE *stream;
+     struct ui_file *stream;
      int show;
      int level;
 {
@@ -144,13 +152,15 @@ java_type_print_base (type, stream, show, level)
       else if (show > 0 || TYPE_TAG_NAME (type) == NULL)
        {
          java_type_print_derivation_info (stream, type);
-         
+
          fprintf_filtered (stream, "{\n");
          if ((TYPE_NFIELDS (type) == 0) && (TYPE_NFN_FIELDS (type) == 0))
-           if (TYPE_FLAGS (type) & TYPE_FLAG_STUB)
-             fprintfi_filtered (level + 4, stream, "<incomplete type>\n");
-           else
-             fprintfi_filtered (level + 4, stream, "<no data fields>\n");
+           {
+             if (TYPE_FLAGS (type) & TYPE_FLAG_STUB)
+               fprintfi_filtered (level + 4, stream, "<incomplete type>\n");
+             else
+               fprintfi_filtered (level + 4, stream, "<no data fields>\n");
+           }
 
          /* If there is a base class for this type,
             do not print the field that it occupies.  */
@@ -171,12 +181,14 @@ java_type_print_base (type, stream, show, level)
              print_spaces_filtered (level + 4, stream);
 
              if (HAVE_CPLUS_STRUCT (type))
-               if (TYPE_FIELD_PROTECTED (type, i))
-                 fprintf_filtered (stream, "protected ");
-               else if (TYPE_FIELD_PRIVATE (type, i))
-                 fprintf_filtered (stream, "private ");
-               else
-                 fprintf_filtered (stream, "public ");
+               {
+                 if (TYPE_FIELD_PROTECTED (type, i))
+                   fprintf_filtered (stream, "protected ");
+                 else if (TYPE_FIELD_PRIVATE (type, i))
+                   fprintf_filtered (stream, "private ");
+                 else
+                   fprintf_filtered (stream, "public ");
+               }
 
              if (TYPE_FIELD_STATIC (type, i))
                fprintf_filtered (stream, "static ");
@@ -191,7 +203,7 @@ java_type_print_base (type, stream, show, level)
          /* If there are both fields and methods, put a space between. */
          len = TYPE_NFN_FIELDS (type);
          if (len)
-            fprintf_filtered (stream, "\n");
+           fprintf_filtered (stream, "\n");
 
          /* Print out the methods */
 
@@ -217,7 +229,7 @@ java_type_print_base (type, stream, show, level)
 
                  physname = TYPE_FN_FIELD_PHYSNAME (f, j);
 
-                 is_full_physname_constructor = 
+                 is_full_physname_constructor =
                    ((physname[0] == '_' && physname[1] == '_'
                      && strchr ("0123456789Qt", physname[2]))
                     || STREQN (physname, "__ct__", 6)
@@ -250,7 +262,7 @@ java_type_print_base (type, stream, show, level)
                    {
                      /* Keep GDB from crashing here.  */
                      fprintf_filtered (stream, "<undefined type> %s;\n",
-                              TYPE_FN_FIELD_PHYSNAME (f, j));
+                                       TYPE_FN_FIELD_PHYSNAME (f, j));
                      break;
                    }
                  else if (!is_constructor && !is_full_physname_constructor)
@@ -271,7 +283,7 @@ java_type_print_base (type, stream, show, level)
                                    DMGL_ANSI | DMGL_PARAMS | DMGL_JAVA);
 
                  if (demangled_name == NULL)
-                   demangled_name = strdup (mangled_name);
+                   demangled_name = xstrdup (mangled_name);
 
                  {
                    char *demangled_no_class;
@@ -306,18 +318,21 @@ java_type_print_base (type, stream, show, level)
        }
       break;
 
-      default:
-       c_type_print_base (type, stream, show, level);
+    default:
+      c_type_print_base (type, stream, show, level);
     }
 }
 
 /* LEVEL is the depth to indent lines by.  */
 
+extern void c_type_print_varspec_suffix (struct type *, struct ui_file *,
+                                        int, int, int);
+
 void
 java_print_type (type, varstring, stream, show, level)
      struct type *type;
      char *varstring;
-     GDB_FILE *stream;
+     struct ui_file *stream;
      int show;
      int level;
 {
@@ -334,6 +349,6 @@ java_print_type (type, varstring, stream, show, level)
   /* For demangled function names, we have the arglist as part of the name,
      so don't print an additional pair of ()'s */
 
-  demangled_args = strchr(varstring, '(') != NULL;
+  demangled_args = strchr (varstring, '(') != NULL;
   c_type_print_varspec_suffix (type, stream, show, 0, demangled_args);
 }
This page took 0.026684 seconds and 4 git commands to generate.