OSDN Git Service

wchar_t now gets wrapped inside "ifndef __cplusplus",
[pf3gnuchains/gcc-fork.git] / gcc / diagnostic.h
index 196f3f7..9d01758 100644 (file)
@@ -1,5 +1,5 @@
 /* Various declarations for language-independent diagnostics subroutines.
-   Copyright (C) 2000 Free Software Foundation, Inc.
+   Copyright (C) 2000, 2001 Free Software Foundation, Inc.
    Contributed by Gabriel Dos Reis <gdr@codesourcery.com>
 
 This file is part of GNU CC.
@@ -19,8 +19,8 @@ along with GNU CC; see the file COPYING.  If not, write to
 the Free Software Foundation, 59 Temple Place - Suite 330,
 Boston, MA 02111-1307, USA.  */
 
-#ifndef __GCC_DIAGNOSTIC_H__
-#define __GCC_DIAGNOSTIC_H__
+#ifndef GCC_DIAGNOSTIC_H
+#define GCC_DIAGNOSTIC_H
 
 #include "obstack.h"
 
@@ -31,6 +31,16 @@ typedef void (*diagnostic_starter_fn) PARAMS ((output_buffer *,
                                                diagnostic_context *));
 typedef diagnostic_starter_fn diagnostic_finalizer_fn;
 
+typedef enum
+{
+#define DEFINE_DIAGNOSTIC_KIND(K, M) K,  
+#include "diagnostic.def"
+#undef DEFINE_DIAGNOSTIC_KIND
+  DK_LAST_DIAGNOSTIC_KIND
+} diagnostic_t;
+
+#define pedantic_error_kind() (flag_pedantic_errors ? DK_ERROR : DK_WARNING)
+
 #define DIAGNOSTICS_SHOW_PREFIX_ONCE       0x0
 #define DIAGNOSTICS_SHOW_PREFIX_NEVER      0x1
 #define DIAGNOSTICS_SHOW_PREFIX_EVERY_LINE 0x2
@@ -40,17 +50,21 @@ typedef diagnostic_starter_fn diagnostic_finalizer_fn;
    everything goes well. */
 typedef int (*printer_fn) PARAMS ((output_buffer *));
 
-/* This data structure encapulates an output_buffer's state.  */
+/* This data structure encapsulates an output_buffer's state.  */
 typedef struct
 {
   /* The prefix for each new line.   */
   const char *prefix;
   /* The real upper bound of number of characters per line, taking into
-     accompt the case of a very very looong prefix.  */  
+     account the case of a very very looong prefix.  */  
   int maximum_length;
   /* The ideal upper bound of number of characters per line, as suggested
      by front-end. */  
   int ideal_maximum_length;
+
+  /* Indentation count.  */
+  int indent_skip;
+
   /* Nonzero if current PREFIX was emitted at least once.  */
   int emitted_prefix_p;
 
@@ -76,6 +90,8 @@ struct output_buffer
   /* Internal data.  These fields should not be accessed directly by
      front-ends.  */
 
+  /* Where to output formatted text.  */
+  FILE* stream;
   /* The obstack where the text is built up.  */  
   struct obstack obstack;
   /* The amount of characters output so far.  */  
@@ -84,12 +100,16 @@ struct output_buffer
   output_state state;
 };
 
+#define output_buffer_attached_stream(BUFFER) (BUFFER)->stream
 #define output_buffer_text_cursor(BUFFER) (BUFFER)->state.cursor
 #define output_buffer_format_args(BUFFER) *((BUFFER)->state.format_args)
 #define output_needs_newline(BUFFER) (BUFFER)->state.need_newline_p
 #define output_buffer_state(BUFFER) (BUFFER)->state
+#define output_indentation(BUFFER) (BUFFER)->state.indent_skip
+#define output_message_text(BUFFER) \
+   ((const char *) obstack_base (&(BUFFER)->obstack))
 
-/* This data structure bundles altogether any information relevent to
+/* This data structure bundles altogether any information relevant to
    the context of a diagnostic message.  */
 struct diagnostic_context
 {
@@ -97,7 +117,7 @@ struct diagnostic_context
   const char *message;
 
   /* A pointer to a variable list of the arguments necessary for the
-     purpose of  message formatting.  */
+     purpose of message formatting.  */
   va_list *args_ptr;
 
   /* The name of the source file involved in the diiagnostic.  */     
@@ -106,11 +126,11 @@ struct diagnostic_context
   /* The line-location in the source file.  */
   int line;
 
-  /* Is it message a warning?  */
+  /* Is this message a warning?  */
   int warn;
 
   /* This function is called before any message is printed out.  It is
-     respondible for preparing message prefix and such.  For example, it
+     responsible for preparing message prefix and such.  For example, it
      might say:
      In file included from "/usr/local/include/curses.h:5:
                       from "/home/gdr/src/nifty_printer.h:56:
@@ -153,49 +173,58 @@ extern int diagnostic_message_length_per_line;
 
 /* This output buffer is used by front-ends that directly output
    diagnostic messages without going through `error', `warning',
-   and simillar functions.  In general, such usage should be
+   and similar functions.  In general, such usage should be
    avoided.  This global buffer will go away, once all such usage
    has been removed.  */
 extern output_buffer *diagnostic_buffer;
 
 /* Prototypes */
-void set_diagnostic_context     PARAMS ((diagnostic_context *, const char *,
-                                         va_list *, const char *, int, int));
-void set_fatal_function                PARAMS ((void (*) PARAMS ((const char *,
-                                                          va_list *))));
-void report_diagnostic          PARAMS ((diagnostic_context *));
-void initialize_diagnostics     PARAMS ((void));
-void reshape_diagnostic_buffer  PARAMS ((void));
-void default_initialize_buffer  PARAMS ((output_buffer *));
-void init_output_buffer                PARAMS ((output_buffer *, const char *, int));
-void output_clear              PARAMS ((output_buffer *));
-const char *output_get_prefix  PARAMS ((const output_buffer *));
-void output_set_prefix         PARAMS ((output_buffer *, const char *));
-void output_destroy_prefix      PARAMS ((output_buffer *));
-void output_set_maximum_length  PARAMS ((output_buffer *, int));
-void output_emit_prefix                PARAMS ((output_buffer *));
-void output_add_newline                PARAMS ((output_buffer *));
-void output_add_space          PARAMS ((output_buffer *));
-int output_space_left          PARAMS ((const output_buffer *));
-void output_append             PARAMS ((output_buffer *, const char *,
-                                         const char *));
-void output_add_character      PARAMS ((output_buffer *, int));
-void output_decimal            PARAMS ((output_buffer *, int));
-void output_add_string         PARAMS ((output_buffer *, const char *));
-const char *output_finish      PARAMS ((output_buffer *));
-void output_printf             PARAMS ((output_buffer *, const char *,
-                                         ...)) ATTRIBUTE_PRINTF_2;
-int output_is_line_wrapping    PARAMS ((output_buffer *));
-void set_message_prefixing_rule PARAMS ((int));
-void output_verbatim            PARAMS ((output_buffer *, const char *, ...))
-     ATTRIBUTE_PRINTF_2;
-void verbatim PARAMS ((const char *, ...)) ATTRIBUTE_PRINTF_1;
-char *context_as_prefix         PARAMS ((const char *, int, int));
-char *file_name_as_prefix       PARAMS ((const char *));
-int error_module_changed        PARAMS ((void));
-void record_last_error_module   PARAMS ((void));
-int error_function_changed      PARAMS ((void));
-void record_last_error_function PARAMS ((void));
-void report_problematic_module  PARAMS ((output_buffer *));     
-
-#endif /* __GCC_DIAGNOSTIC_H__ */
+extern void set_diagnostic_context     PARAMS ((diagnostic_context *,
+                                                const char *, va_list *,
+                                                const char *, int, int));
+extern void set_internal_error_function        PARAMS ((void (*)
+                                                PARAMS ((const char *,
+                                                         va_list *))));
+extern void report_diagnostic          PARAMS ((diagnostic_context *));
+extern void initialize_diagnostics     PARAMS ((void));
+extern void reshape_diagnostic_buffer  PARAMS ((void));
+extern void default_initialize_buffer  PARAMS ((output_buffer *));
+extern void init_output_buffer         PARAMS ((output_buffer *,
+                                                const char *, int));
+extern void flush_diagnostic_buffer    PARAMS ((void));
+extern void output_clear               PARAMS ((output_buffer *));
+extern const char *output_get_prefix   PARAMS ((const output_buffer *));
+extern const char *output_last_position PARAMS ((const output_buffer *));
+extern void output_set_prefix          PARAMS ((output_buffer *,
+                                                const char *));
+extern void output_destroy_prefix      PARAMS ((output_buffer *));
+extern void output_set_maximum_length  PARAMS ((output_buffer *, int));
+extern void output_emit_prefix         PARAMS ((output_buffer *));
+extern void output_add_newline         PARAMS ((output_buffer *));
+extern void output_add_space           PARAMS ((output_buffer *));
+extern int output_space_left           PARAMS ((const output_buffer *));
+extern void output_append              PARAMS ((output_buffer *, const char *,
+                                                const char *));
+extern void output_add_character       PARAMS ((output_buffer *, int));
+extern void output_decimal             PARAMS ((output_buffer *, int));
+extern void output_add_string          PARAMS ((output_buffer *,
+                                                const char *));
+extern const char *output_finalize_message PARAMS ((output_buffer *));
+extern void output_clear_message_text  PARAMS ((output_buffer *));
+extern void output_printf              PARAMS ((output_buffer *, const char *,
+                                                ...)) ATTRIBUTE_PRINTF_2;
+extern int output_is_line_wrapping     PARAMS ((output_buffer *));
+extern void set_message_prefixing_rule PARAMS ((int));
+extern void output_verbatim            PARAMS ((output_buffer *, const char *,
+                                                ...)) ATTRIBUTE_PRINTF_2;
+extern void verbatim                   PARAMS ((const char *, ...))
+     ATTRIBUTE_PRINTF_1;
+extern char *context_as_prefix         PARAMS ((const char *, int, int));
+extern char *file_name_as_prefix       PARAMS ((const char *));
+extern int error_module_changed         PARAMS ((void));
+extern void record_last_error_module   PARAMS ((void));
+extern int error_function_changed      PARAMS ((void));
+extern void record_last_error_function PARAMS ((void));
+extern void report_problematic_module  PARAMS ((output_buffer *));     
+
+#endif /* ! GCC_DIAGNOSTIC_H */