Fix -Werror -Wuninitialized warnings.
[deliverable/binutils-gdb.git] / gdb / complaints.c
index e441db4218d7d36c7f6e8dca7694075f14a70fe1..b29d3c6a576a2c75138c89ec1364943456367220 100644 (file)
@@ -1,34 +1,38 @@
 /* Support for complaint handling during symbol reading in GDB.
-   Copyright (C) 1990, 1991, 1992  Free Software Foundation, Inc.
+   Copyright 1990, 1991, 1992, 1993, 1995, 1998, 1999, 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., 675 Mass Ave, Cambridge, MA 02139, 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"
 #include "complaints.h"
 #include "gdbcmd.h"
-#include <varargs.h>
+
+extern void _initialize_complaints (void);
 
 /* Structure to manage complaints about symbol file contents.  */
 
-struct complaint complaint_root[1] = {
+struct complaint complaint_root[1] =
+{
   {
-    (char *) NULL,     /* Complaint message */
-    0,                 /* Complaint counter */
-    complaint_root     /* Next complaint. */
+    (char *) NULL,             /* Complaint message */
+    0,                         /* Complaint counter */
+    complaint_root             /* Next complaint. */
   }
 };
 
@@ -43,37 +47,33 @@ static unsigned int stop_whining = 0;
    case 0:  self explanatory message.
    case 1:  First message of a series that must start off with explanation.
    case 2:  Subsequent message, when user already knows we are reading
-            symbols and we can just state our piece.  */
+   symbols and we can just state our piece.  */
 
 static int complaint_series = 0;
 
 /* External variables and functions referenced. */
 
 extern int info_verbose;
-
 \f
+
 /* Functions to handle complaints during symbol reading.  */
 
 /* Print a complaint about the input symbols, and link the complaint block
    into a chain for later handling.  */
 
-/* VARARGS */
 void
-complain (va_alist)
-     va_dcl
+complain (struct complaint *complaint,...)
 {
   va_list args;
-  struct complaint *complaint;
+  va_start (args, complaint);
 
-  va_start (args);
-  complaint = va_arg (args, struct complaint *);
-  complaint -> counter++;
-  if (complaint -> next == NULL)
+  complaint->counter++;
+  if (complaint->next == NULL)
     {
-      complaint -> next = complaint_root -> next;
-      complaint_root -> next = complaint;
+      complaint->next = complaint_root->next;
+      complaint_root->next = complaint;
     }
-  if (complaint -> counter > stop_whining)
+  if (complaint->counter > stop_whining)
     {
       return;
     }
@@ -83,36 +83,51 @@ complain (va_alist)
     {
 
       /* Isolated messages, must be self-explanatory.  */
-      case 0:
-        begin_line ();
-        puts_filtered ("During symbol reading, ");
-       wrap_here ("");
-       vprintf_filtered (complaint -> message, args);
-       puts_filtered (".\n");
-       break;
+    case 0:
+      if (warning_hook)
+        (*warning_hook) (complaint->message, args);
+      else
+        {
+          begin_line ();
+          fputs_filtered ("During symbol reading, ", gdb_stderr);
+          wrap_here ("");
+          vfprintf_filtered (gdb_stderr, complaint->message, args);
+          fputs_filtered (".\n", gdb_stderr);
+        }
+      break;
 
       /* First of a series, without `set verbose'.  */
-      case 1:
-        begin_line ();
-       puts_filtered ("During symbol reading...");
-       vprintf_filtered (complaint -> message, args);
-       puts_filtered ("...");
-       wrap_here ("");
-       complaint_series++;
-       break;
+    case 1:
+      if (warning_hook)
+        (*warning_hook) (complaint->message, args);
+      else
+        {
+          begin_line ();
+          fputs_filtered ("During symbol reading...", gdb_stderr);
+          vfprintf_filtered (gdb_stderr, complaint->message, args);
+          fputs_filtered ("...", gdb_stderr);
+          wrap_here ("");
+          complaint_series++;
+        }
+      break;
 
       /* Subsequent messages of a series, or messages under `set verbose'.
-        (We'll already have produced a "Reading in symbols for XXX..."
-        message and will clean up at the end with a newline.)  */
-      default:
-       vprintf_filtered (complaint -> message, args);
-       puts_filtered ("...");
-       wrap_here ("");
+         (We'll already have produced a "Reading in symbols for XXX..."
+         message and will clean up at the end with a newline.)  */
+    default:
+      if (warning_hook)
+        (*warning_hook) (complaint->message, args);
+      else
+        {
+          vfprintf_filtered (gdb_stderr, complaint->message, args);
+          fputs_filtered ("...", gdb_stderr);
+          wrap_here ("");
+        }
     }
   /* If GDB dumps core, we'd like to see the complaints first.  Presumably
      GDB will not be sending so many complaints that this becomes a
      performance hog.  */
-  gdb_flush (gdb_stdout);
+  gdb_flush (gdb_stderr);
   va_end (args);
 }
 
@@ -125,18 +140,16 @@ complain (va_alist)
    context for the user to figure it out.  */
 
 void
-clear_complaints (sym_reading, noisy)
-     int sym_reading;
-     int noisy;
+clear_complaints (int sym_reading, int noisy)
 {
   struct complaint *p;
 
-  for (p = complaint_root -> next; p != complaint_root; p = p -> next)
+  for (p = complaint_root->next; p != complaint_root; p = p->next)
     {
-      p -> counter = 0;
+      p->counter = 0;
     }
 
-  if (!sym_reading && !noisy && complaint_series > 1)
+  if (!sym_reading && !noisy && complaint_series > 1 && !warning_hook)
     {
       /* Terminate previous series, since caller won't.  */
       puts_filtered ("\n");
@@ -146,7 +159,7 @@ clear_complaints (sym_reading, noisy)
 }
 
 void
-_initialize_complaints ()
+_initialize_complaints (void)
 {
   add_show_from_set
     (add_set_cmd ("complaints", class_support, var_zinteger,
This page took 0.03258 seconds and 4 git commands to generate.