gdb: LoongArch: Remove nonportable #include
[binutils-gdb.git] / gdb / complaints.h
index f43feb0fc6a65f4bb00518f89f78205108434fc0..68c79bd6d0a1f99994805b976bca082d6ad1db88 100644 (file)
@@ -1,13 +1,12 @@
 /* Definitions for complaint handling during symbol reading in GDB.
 
-   Copyright 1990, 1991, 1992, 1995, 1998, 2000, 2002 Free Software
-   Foundation, Inc.
+   Copyright (C) 1990-2022 Free Software Foundation, Inc.
 
    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
+   the Free Software Foundation; either version 3 of the License, or
    (at your option) any later version.
 
    This program is distributed in the hope that it will be useful,
    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.  */
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
 
 
 #if !defined (COMPLAINTS_H)
 #define COMPLAINTS_H
 
-/* Opaque object used to track the number of complaints of a
-   particular category.  */
-struct complaints;
+#include <unordered_set>
 
-/* Predefined categories.  */
-extern struct complaints *symfile_complaints;
+/* Helper for complaint.  */
+extern void complaint_internal (const char *fmt, ...)
+  ATTRIBUTE_PRINTF (1, 2);
 
-/* Register a complaint.  */
-extern void complaint (struct complaints **complaints, const char *fmt,
-                      ...) ATTR_FORMAT (printf, 2, 3);
-extern void internal_complaint (struct complaints **complaints,
-                               const char *file, int line, const char *fmt,
-                               ...) ATTR_FORMAT (printf, 4, 5);
+/* This controls whether complaints are emitted.  */
 
-/* Clear out / initialize all complaint counters that have ever been
-   incremented.  If LESS_VERBOSE is 1, be less verbose about
-   successive complaints, since the messages are appearing all
-   together during a command that is reporting a contiguous block of
-   complaints (rather than being interleaved with other messages).  If
-   noisy is 1, we are in a noisy command, and our caller will print
-   enough context for the user to figure it out.  */
+extern int stop_whining;
 
-extern void clear_complaints (struct complaints **complaints,
-                             int less_verbose, int noisy);
+/* Register a complaint.  This is a macro around complaint_internal to
+   avoid computing complaint's arguments when complaints are disabled.
+   Running FMT via gettext [i.e., _(FMT)] can be quite expensive, for
+   example.  */
+#define complaint(FMT, ...)                                    \
+  do                                                           \
+    {                                                          \
+      if (stop_whining > 0)                                    \
+       complaint_internal (FMT, ##__VA_ARGS__);                \
+    }                                                          \
+  while (0)
 
+/* Clear out / initialize all complaint counters that have ever been
+   incremented.  */
 
-/* Deprecated interfaces to keep the old code working (until it is all
-   converted to the above).  Existing code such as:
+extern void clear_complaints ();
 
-     struct deprecated_complaint msg = { "msg 0x%08x[sic]", 0, 0 };
-     deprecated_complain (&msg, addr);
+/* A class that can handle calls to complaint from multiple threads.
+   When this is instantiated, it hooks into the complaint mechanism,
+   so the 'complaint' macro can continue to be used.  When it is
+   destroyed, it issues all the complaints that have been stored.  It
+   should only be instantiated in the main thread.  */
 
-   should be replaced by either the new call (for the singular case):
+class complaint_interceptor
+{
+public:
 
-     complaint (&symtab_complaints, "msg 0x%s", paddr (addr));
+  complaint_interceptor ();
+  ~complaint_interceptor ();
 
-   or with a wrapper function (for the many-of case):
+  DISABLE_COPY_AND_ASSIGN (complaint_interceptor);
 
-     msg_complaint (CORE_ADDR addr)
-     { complaint (&symtab_complaints, "msg 0x%s", paddr (addr)); }
-     ...
-     msg_complaint (addr);
+private:
 
-   Yes, the typo is intentional.  The motivation behind this interface
-   change is to eliminate all possability of this problem re-occuring
-   (it has occured in the past and no one is sure that it isn't
-   present now).
+  /* The issued complaints.  */
+  std::unordered_set<std::string> m_complaints;
 
-   Support for complaining about things in the symbol file that aren't
-   catastrophic.
+  /* The saved value of deprecated_warning_hook.  */
+  void (*m_saved_warning_hook) (const char *, va_list)
+    ATTRIBUTE_FPTR_PRINTF (1,0);
 
-   Each such thing gets a counter.  The first time we have the problem,
-   during a symbol read, we report it.  At the end of symbol reading,
-   if verbose, we report how many of each problem we had.  */
+  /* A helper function that is used by the 'complaint' implementation
+     to issue a complaint.  */
+  static void issue_complaint (const char *, va_list)
+    ATTRIBUTE_PRINTF (1, 0);
 
-struct deprecated_complaint
-{
-  const char *message;
-  unsigned counter_ignored;
-  struct deprecated_complaint *next_ignored;
+  /* This object.  Used by the static callback function.  */
+  static complaint_interceptor *g_complaint_interceptor;
 };
 
-extern void complain (struct deprecated_complaint *, ...);
-
 #endif /* !defined (COMPLAINTS_H) */