OSDN Git Service

Daily bump.
[pf3gnuchains/gcc-fork.git] / gcc / c-common.h
index ab0cdec..9fd9bdd 100644 (file)
@@ -1,5 +1,6 @@
 /* Definitions for c-common.c.
-   Copyright (C) 1987, 93, 94, 95, 97, 98, 1999 Free Software Foundation, Inc.
+   Copyright (C) 1987, 1993, 1994, 1995, 1997, 1998,
+   1999, 2000 Free Software Foundation, Inc.
 
 This file is part of GNU CC.
 
@@ -18,54 +19,73 @@ 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.  */
 
+/* Reserved identifiers.  */
+
+enum rid
+{
+  RID_UNUSED,
+  RID_INT,
+  RID_CHAR,
+  RID_FLOAT,
+  RID_DOUBLE,
+  RID_VOID,
+  RID_UNUSED1,
+
+  /* The first seven are in the order of most frequently used,
+     as emiprically determined.  */
+  RID_FIRST_MODIFIER,
+  RID_EXTERN = RID_FIRST_MODIFIER,
+  RID_CONST,
+  RID_LONG,
+  RID_TYPEDEF,
+  RID_UNSIGNED,
+  RID_SHORT,
+  RID_INLINE,
+  RID_AUTO,
+  RID_STATIC,
+  RID_REGISTER,
+  RID_SIGNED,
+  RID_RESTRICT,
+  RID_VOLATILE,
+  RID_BOUNDED,
+  RID_UNBOUNDED,
+  RID_NOALIAS,
+  RID_ITERATOR,
+  RID_COMPLEX,
+
+  RID_IN,
+  RID_OUT,
+  RID_INOUT,
+  RID_BYCOPY,
+  RID_BYREF,
+  RID_ONEWAY,
+  RID_ID,
+
+  RID_MAX
+};
+
+#define NORID RID_UNUSED
+
+/* The elements of `ridpointers' are identifier nodes for the reserved
+   type names and storage classes.  It is indexed by a RID_... value.  */
+extern tree *ridpointers;
+
 /* Standard named or nameless data types of the C compiler.  */
 
 enum c_tree_index
 {
-    CTI_INTQI_TYPE,
-    CTI_INTHI_TYPE,
-    CTI_INTSI_TYPE,
-    CTI_INTDI_TYPE,
-    CTI_INTTI_TYPE,
-
-    CTI_UINTQI_TYPE,
-    CTI_UINTHI_TYPE,
-    CTI_UINTSI_TYPE,
-    CTI_UINTDI_TYPE,
-    CTI_UINTTI_TYPE,
-    
-    CTI_SIGNED_CHAR_TYPE,
-    CTI_UNSIGNED_CHAR_TYPE,
     CTI_WCHAR_TYPE,
     CTI_SIGNED_WCHAR_TYPE,
     CTI_UNSIGNED_WCHAR_TYPE,
-    CTI_SHORT_INTEGER_TYPE,
-    CTI_SHORT_UNSIGNED_TYPE,
-    CTI_LONG_INTEGER_TYPE,
-    CTI_LONG_UNSIGNED_TYPE,
-    CTI_LONG_LONG_INTEGER_TYPE,
-    CTI_LONG_LONG_UNSIGNED_TYPE,
     CTI_WIDEST_INT_LIT_TYPE,
     CTI_WIDEST_UINT_LIT_TYPE,
 
-    CTI_COMPLEX_INTEGER_TYPE,
-    CTI_COMPLEX_FLOAT_TYPE,
-    CTI_COMPLEX_DOUBLE_TYPE,
-    CTI_COMPLEX_LONG_DOUBLE_TYPE,
-
-    CTI_FLOAT_TYPE,
-    CTI_DOUBLE_TYPE,
-    CTI_LONG_DOUBLE_TYPE,
-
     CTI_CHAR_ARRAY_TYPE,
     CTI_WCHAR_ARRAY_TYPE,
     CTI_INT_ARRAY_TYPE,
     CTI_STRING_TYPE,
     CTI_CONST_STRING_TYPE,
 
-    CTI_CONST_PTR_TYPE,
-    CTI_PTRDIFF_TYPE,
-
     CTI_BOOLEAN_TYPE,
     CTI_BOOLEAN_TRUE,
     CTI_BOOLEAN_FALSE,
@@ -76,58 +96,25 @@ enum c_tree_index
     CTI_VOID_FTYPE_PTR,
     CTI_INT_FTYPE_INT,
     CTI_PTR_FTYPE_SIZETYPE,
-    
-    CTI_MAX
-};
 
-extern tree c_global_trees[CTI_MAX];
-
-#define intQI_type_node                        c_global_trees[CTI_INTQI_TYPE]
-#define intHI_type_node                        c_global_trees[CTI_INTHI_TYPE]
-#define intSI_type_node                        c_global_trees[CTI_INTSI_TYPE]
-#define intDI_type_node                        c_global_trees[CTI_INTDI_TYPE]
-#if HOST_BITS_PER_WIDE_INT >= 64
-#define intTI_type_node                        c_global_trees[CTI_INTTI_TYPE]
-#endif
+    CTI_G77_INTEGER_TYPE,
+    CTI_G77_UINTEGER_TYPE,
+    CTI_G77_LONGINT_TYPE,
+    CTI_G77_ULONGINT_TYPE,
 
-#define unsigned_intQI_type_node       c_global_trees[CTI_UINTQI_TYPE]
-#define unsigned_intHI_type_node       c_global_trees[CTI_UINTHI_TYPE]
-#define unsigned_intSI_type_node       c_global_trees[CTI_UINTSI_TYPE]
-#define unsigned_intDI_type_node       c_global_trees[CTI_UINTDI_TYPE]
-#if HOST_BITS_PER_WIDE_INT >= 64
-#define unsigned_intTI_type_node       c_global_trees[CTI_UINTTI_TYPE]
-#endif
+    CTI_MAX
+};
 
-#define signed_char_type_node          c_global_trees[CTI_SIGNED_CHAR_TYPE]
-#define unsigned_char_type_node                c_global_trees[CTI_UNSIGNED_CHAR_TYPE]
 #define wchar_type_node                        c_global_trees[CTI_WCHAR_TYPE]
 #define signed_wchar_type_node         c_global_trees[CTI_SIGNED_WCHAR_TYPE]
 #define unsigned_wchar_type_node       c_global_trees[CTI_UNSIGNED_WCHAR_TYPE]
-#define short_integer_type_node                c_global_trees[CTI_SHORT_INTEGER_TYPE]
-#define short_unsigned_type_node       c_global_trees[CTI_SHORT_UNSIGNED_TYPE]
-#define long_integer_type_node         c_global_trees[CTI_LONG_INTEGER_TYPE]
-#define long_unsigned_type_node                c_global_trees[CTI_LONG_UNSIGNED_TYPE]
-#define long_long_integer_type_node    c_global_trees[CTI_LONG_LONG_INTEGER_TYPE]
-#define long_long_unsigned_type_node   c_global_trees[CTI_LONG_LONG_UNSIGNED_TYPE]
 #define widest_integer_literal_type_node c_global_trees[CTI_WIDEST_INT_LIT_TYPE]
 #define widest_unsigned_literal_type_node c_global_trees[CTI_WIDEST_UINT_LIT_TYPE]
 
-#define float_type_node                        c_global_trees[CTI_FLOAT_TYPE]
-#define double_type_node               c_global_trees[CTI_DOUBLE_TYPE]
-#define long_double_type_node          c_global_trees[CTI_LONG_DOUBLE_TYPE]
-
-#define complex_integer_type_node      c_global_trees[CTI_COMPLEX_INTEGER_TYPE]
-#define complex_float_type_node                c_global_trees[CTI_COMPLEX_FLOAT_TYPE]
-#define complex_double_type_node       c_global_trees[CTI_COMPLEX_DOUBLE_TYPE]
-#define complex_long_double_type_node  c_global_trees[CTI_COMPLEX_LONG_DOUBLE_TYPE]
-
 #define boolean_type_node              c_global_trees[CTI_BOOLEAN_TYPE]
 #define boolean_true_node              c_global_trees[CTI_BOOLEAN_TRUE]
 #define boolean_false_node             c_global_trees[CTI_BOOLEAN_FALSE]
 
-#define const_ptr_type_node            c_global_trees[CTI_CONST_PTR_TYPE]
-#define ptrdiff_type_node              c_global_trees[CTI_PTRDIFF_TYPE]
-
 #define char_array_type_node           c_global_trees[CTI_CHAR_ARRAY_TYPE]
 #define wchar_array_type_node          c_global_trees[CTI_WCHAR_ARRAY_TYPE]
 #define int_array_type_node            c_global_trees[CTI_INT_ARRAY_TYPE]
@@ -141,54 +128,296 @@ extern tree c_global_trees[CTI_MAX];
 #define int_ftype_int                  c_global_trees[CTI_INT_FTYPE_INT]
 #define ptr_ftype_sizetype             c_global_trees[CTI_PTR_FTYPE_SIZETYPE]
 
-extern void declare_function_name              PROTO((void));
-extern void decl_attributes                    PROTO((tree, tree, tree));
-extern void init_function_format_info          PROTO((void));
-extern void check_function_format              PROTO((tree, tree, tree));
-extern void c_apply_type_quals_to_decl         PROTO((int, tree));
-extern int c_get_alias_set                     PROTO((tree));
+/* g77 integer types, which which must be kept in sync with f/com.h */
+#define g77_integer_type_node          c_global_trees[CTI_G77_INTEGER_TYPE]
+#define g77_uinteger_type_node         c_global_trees[CTI_G77_UINTEGER_TYPE]
+#define g77_longint_type_node          c_global_trees[CTI_G77_LONGINT_TYPE]
+#define g77_ulongint_type_node         c_global_trees[CTI_G77_ULONGINT_TYPE]
+
+extern tree c_global_trees[CTI_MAX];
+
+typedef enum c_language_kind
+{
+  clk_c,           /* A dialect of C: K&R C, ANSI/ISO C89, C2000,
+                      etc. */
+  clk_cplusplus,   /* ANSI/ISO C++ */
+  clk_objective_c  /* Objective C */
+} 
+c_language_kind;
+
+/* The variant of the C language being processed.  Each C language
+   front-end defines this variable.  */
+
+extern c_language_kind c_language;
+
+/* Nonzero means give string constants the type `const char *', rather
+   than `char *'.  */
+
+extern int flag_const_strings;
+
+/* Warn about *printf or *scanf format/argument anomalies. */
+
+extern int warn_format;
+
+/* Nonzero means do some things the same way PCC does.  */
+
+extern int flag_traditional;
+
+/* Nonzero means use the ISO C99 dialect of C.  */
+
+extern int flag_isoc99;
+
+/* Nonzero means warn about suggesting putting in ()'s.  */
+
+extern int warn_parentheses;
+
+/* Warn if a type conversion is done that might have confusing results.  */
+
+extern int warn_conversion;
+
+/* C types are partitioned into three subsets: object, function, and
+   incomplete types.  */
+#define C_TYPE_OBJECT_P(type) \
+  (TREE_CODE (type) != FUNCTION_TYPE && TYPE_SIZE (type))
+
+#define C_TYPE_INCOMPLETE_P(type) \
+  (TREE_CODE (type) != FUNCTION_TYPE && TYPE_SIZE (type) == 0)
+
+#define C_TYPE_FUNCTION_P(type) \
+  (TREE_CODE (type) == FUNCTION_TYPE)
+
+/* For convenience we define a single macro to identify the class of
+   object or incomplete types.  */
+#define C_TYPE_OBJECT_OR_INCOMPLETE_P(type) \
+  (!C_TYPE_FUNCTION_P (type))
+
+/* Record in each node resulting from a binary operator
+   what operator was specified for it.  */
+#define C_EXP_ORIGINAL_CODE(exp) ((enum tree_code) TREE_COMPLEXITY (exp))
+
+/* Pointer to function to generate the VAR_DECL for __FUNCTION__ etc.
+   ID is the identifier to use, NAME is the string.
+   TYPE_DEP indicates whether it depends on type of the function or not
+   (i.e. __PRETTY_FUNCTION__).  */
+
+extern tree (*make_fname_decl)                  PARAMS ((tree, const char *, int));
+
+extern void declare_function_name              PARAMS ((void));
+extern void decl_attributes                    PARAMS ((tree, tree, tree));
+extern void init_function_format_info          PARAMS ((void));
+extern void check_function_format              PARAMS ((tree, tree, tree));
+extern void c_apply_type_quals_to_decl         PARAMS ((int, tree));
 /* Print an error message for invalid operands to arith operation CODE.
    NOP_EXPR is used as a special case (see truthvalue_conversion).  */
-extern void binary_op_error                    PROTO((enum tree_code));
-extern void c_expand_expr_stmt                 PROTO((tree));
-extern void c_expand_start_cond                        PROTO((tree, int, int));
-extern void c_expand_start_else                        PROTO((void));
-extern void c_expand_end_cond                  PROTO((void));
+extern void binary_op_error                    PARAMS ((enum tree_code));
+extern void c_expand_expr_stmt                 PARAMS ((tree));
+extern void c_expand_start_cond                        PARAMS ((tree, int, int));
+extern void c_expand_start_else                        PARAMS ((void));
+extern void c_expand_end_cond                  PARAMS ((void));
 /* Validate the expression after `case' and apply default promotions.  */
-extern tree check_case_value                   PROTO((tree));
+extern tree check_case_value                   PARAMS ((tree));
 /* Concatenate a list of STRING_CST nodes into one STRING_CST.  */
-extern tree combine_strings                    PROTO((tree));
-extern void constant_expression_warning                PROTO((tree));
-extern tree convert_and_check                  PROTO((tree, tree));
-extern void overflow_warning                   PROTO((tree));
-extern void unsigned_conversion_warning                PROTO((tree, tree));
+extern tree combine_strings                    PARAMS ((tree));
+extern void constant_expression_warning                PARAMS ((tree));
+extern tree convert_and_check                  PARAMS ((tree, tree));
+extern void overflow_warning                   PARAMS ((tree));
+extern void unsigned_conversion_warning                PARAMS ((tree, tree));
+
 /* Read the rest of the current #-directive line.  */
 #if USE_CPPLIB
-extern char *get_directive_line                        PROTO((void));
+extern char *get_directive_line                        PARAMS ((void));
 #define GET_DIRECTIVE_LINE() get_directive_line ()
 #else
-extern char *get_directive_line                        PROTO((FILE *));
+extern char *get_directive_line                        PARAMS ((FILE *));
 #define GET_DIRECTIVE_LINE() get_directive_line (finput)
 #endif
 
 /* Subroutine of build_binary_op, used for comparison operations.
    See if the operands have both been converted from subword integer types
    and, if so, perhaps change them both back to their original type.  */
-extern tree shorten_compare                    PROTO((tree *, tree *, tree *, enum tree_code *));
+extern tree shorten_compare                    PARAMS ((tree *, tree *, tree *, enum tree_code *));
 /* Prepare expr to be an argument of a TRUTH_NOT_EXPR,
    or validate its data type for an `if' or `while' statement or ?..: exp. */
-extern tree truthvalue_conversion              PROTO((tree));
-extern tree type_for_mode                      PROTO((enum machine_mode, int));
-extern tree type_for_size                      PROTO((unsigned, int));
-
-/* Declare a predefined function.  Return the declaration.  This function is
-   provided by each language frontend.  */
-extern tree builtin_function                   PROTO((const char *, tree, enum built_in_function, const char *));
+extern tree truthvalue_conversion              PARAMS ((tree));
+extern tree type_for_mode                      PARAMS ((enum machine_mode, int));
+extern tree type_for_size                      PARAMS ((unsigned, int));
 
 /* Build tree nodes and builtin functions common to both C and C++ language
    frontends.  */
-extern void c_common_nodes_and_builtins                PROTO((int, int, int));
+extern void c_common_nodes_and_builtins                PARAMS ((int, int, int));
+
+extern tree build_va_arg                       PARAMS ((tree, tree));
+
+/* Nonzero if the type T promotes to itself.
+   ANSI C states explicitly the list of types that promote;
+   in particular, short promotes to int even if they have the same width.  */
+#define C_PROMOTING_INTEGER_TYPE_P(t)                          \
+  (TREE_CODE ((t)) == INTEGER_TYPE                             \
+   && (TYPE_MAIN_VARIANT (t) == char_type_node                 \
+       || TYPE_MAIN_VARIANT (t) == signed_char_type_node       \
+       || TYPE_MAIN_VARIANT (t) == unsigned_char_type_node     \
+       || TYPE_MAIN_VARIANT (t) == short_integer_type_node     \
+       || TYPE_MAIN_VARIANT (t) == short_unsigned_type_node))
+
+extern int self_promoting_args_p               PARAMS ((tree));
+extern tree simple_type_promotes_to            PARAMS ((tree));
+
+\f
+/* These macros provide convenient access to the various _STMT nodes
+   created when parsing template declarations.  */
+
+/* IF_STMT accessors. These give access to the condtion of the if
+   statement, the then block of the if statement, and the else block
+   of the if stsatement if it exists. */
+#define IF_COND(NODE)           TREE_OPERAND (IF_STMT_CHECK (NODE), 0)
+#define THEN_CLAUSE(NODE)       TREE_OPERAND (IF_STMT_CHECK (NODE), 1)
+#define ELSE_CLAUSE(NODE)       TREE_OPERAND (IF_STMT_CHECK (NODE), 2)
+
+/* WHILE_STMT accessors. These give access to the condtion of the
+   while statement and the body of the while statement, respectively. */
+#define WHILE_COND(NODE)        TREE_OPERAND (WHILE_STMT_CHECK (NODE), 0)
+#define WHILE_BODY(NODE)        TREE_OPERAND (WHILE_STMT_CHECK (NODE), 1)
+
+/* DO_STMT accessors. These give access to the condition of the do
+   statement and the body of the do statement, respectively. */
+#define DO_COND(NODE)           TREE_OPERAND (DO_STMT_CHECK (NODE), 0)
+#define DO_BODY(NODE)           TREE_OPERAND (DO_STMT_CHECK (NODE), 1)
+
+/* RETURN_STMT accessor. This gives the expression associated with a
+   return statement. */
+#define RETURN_EXPR(NODE)       TREE_OPERAND (RETURN_STMT_CHECK (NODE), 0)
+
+/* EXPR_STMT accessor. This gives the expression associated with an
+   expression statement. */
+#define EXPR_STMT_EXPR(NODE)    TREE_OPERAND (EXPR_STMT_CHECK (NODE), 0)
+
+/* FOR_STMT accessors. These give access to the init statement,
+   condition, update expression, and body of the for statement,
+   respectively. */
+#define FOR_INIT_STMT(NODE)     TREE_OPERAND (FOR_STMT_CHECK (NODE), 0)
+#define FOR_COND(NODE)          TREE_OPERAND (FOR_STMT_CHECK (NODE), 1)
+#define FOR_EXPR(NODE)          TREE_OPERAND (FOR_STMT_CHECK (NODE), 2)
+#define FOR_BODY(NODE)          TREE_OPERAND (FOR_STMT_CHECK (NODE), 3)
+
+/* SWITCH_STMT accessors. These give access to the condition and body
+   of the switch statement, respectively. */
+#define SWITCH_COND(NODE)       TREE_OPERAND (SWITCH_STMT_CHECK (NODE), 0)
+#define SWITCH_BODY(NODE)       TREE_OPERAND (SWITCH_STMT_CHECK (NODE), 1)
+
+/* CASE_LABEL accessors. These give access to the high and low values
+   of a case label, respectively. */
+#define CASE_LOW(NODE)          TREE_OPERAND (CASE_LABEL_CHECK (NODE), 0)
+#define CASE_HIGH(NODE)         TREE_OPERAND (CASE_LABEL_CHECK (NODE), 1)
+
+/* GOTO_STMT accessor. This gives access to the label associated with
+   a goto statement. */
+#define GOTO_DESTINATION(NODE)  TREE_OPERAND (GOTO_STMT_CHECK (NODE), 0)
+
+/* COMPOUND_STMT accessor. This gives access to the TREE_LIST of
+   statements assocated with a compound statement. The result is the
+   first statement in the list. Succeeding nodes can be acccessed by
+   calling TREE_CHAIN on a node in the list. */
+#define COMPOUND_BODY(NODE)     TREE_OPERAND (COMPOUND_STMT_CHECK (NODE), 0)
+
+/* ASM_STMT accessors. ASM_STRING returns a STRING_CST for the
+   instruction (e.g., "mov x, y"). ASM_OUTPUTS, ASM_INPUTS, and
+   ASM_CLOBBERS represent the outputs, inputs, and clobbers for the
+   statement. */
+#define ASM_CV_QUAL(NODE)       TREE_OPERAND (ASM_STMT_CHECK (NODE), 0)
+#define ASM_STRING(NODE)        TREE_OPERAND (ASM_STMT_CHECK (NODE), 1)
+#define ASM_OUTPUTS(NODE)       TREE_OPERAND (ASM_STMT_CHECK (NODE), 2)
+#define ASM_INPUTS(NODE)        TREE_OPERAND (ASM_STMT_CHECK (NODE), 3)
+#define ASM_CLOBBERS(NODE)      TREE_OPERAND (ASM_STMT_CHECK (NODE), 4)
+
+/* DECL_STMT accessor. This gives access to the DECL associated with
+   the given declaration statement. */ 
+#define DECL_STMT_DECL(NODE)    TREE_OPERAND (DECL_STMT_CHECK (NODE), 0)
+
+/* STMT_EXPR accessor. */
+#define STMT_EXPR_STMT(NODE)    TREE_OPERAND (STMT_EXPR_CHECK (NODE), 0)
+
+/* LABEL_STMT accessor. This gives access to the label associated with
+   the given label statement. */
+#define LABEL_STMT_LABEL(NODE)  TREE_OPERAND (LABEL_STMT_CHECK (NODE), 0)
+
+/* Nonzero if this SCOPE_STMT is for the beginning of a scope.  */
+#define SCOPE_BEGIN_P(NODE) \
+  (TREE_LANG_FLAG_0 (SCOPE_STMT_CHECK (NODE))) 
+
+/* Nonzero if this SCOPE_STMT is for the end of a scope.  */
+#define SCOPE_END_P(NODE) \
+  (!SCOPE_BEGIN_P (SCOPE_STMT_CHECK (NODE)))
+
+/* The BLOCK containing the declarations contained in this scope.  */
+#define SCOPE_STMT_BLOCK(NODE) \
+  (TREE_OPERAND (SCOPE_STMT_CHECK (NODE), 0))
+
+/* Nonzero for a SCOPE_STMT if there were no variables in this scope.  */
+#define SCOPE_NULLIFIED_P(NODE) \
+  (SCOPE_STMT_BLOCK ((NODE)) == NULL_TREE)
+
+/* Nonzero for a SCOPE_STMT which represents a lexical scope, but
+   which should be treated as non-existant from the point of view of
+   running cleanup actions.  */
+#define SCOPE_NO_CLEANUPS_P(NODE) \
+  (TREE_LANG_FLAG_3 (SCOPE_STMT_CHECK (NODE)))
+
+/* Nonzero for a SCOPE_STMT if this statement is for a partial scope.
+   For example, in:
+  
+     S s;
+     l:
+     S s2;
+     goto l;
+
+   there is (implicitly) a new scope after `l', even though there are
+   no curly braces.  In particular, when we hit the goto, we must
+   destroy s2 and then re-construct it.  For the implicit scope,
+   SCOPE_PARTIAL_P will be set.  */
+#define SCOPE_PARTIAL_P(NODE) \
+  (TREE_LANG_FLAG_4 (SCOPE_STMT_CHECK (NODE)))
+
+/* Nonzero for an ASM_STMT if the assembly statement is volatile.  */
+#define ASM_VOLATILE_P(NODE)                   \
+  (ASM_CV_QUAL (ASM_STMT_CHECK (NODE)) != NULL_TREE)
+
+/* The line-number at which a statement began.  But if
+   STMT_LINENO_FOR_FN_P does holds, then this macro gives the
+   line number for the end of the current function instead.  */
+#define STMT_LINENO(NODE)                      \
+  (TREE_COMPLEXITY ((NODE)))
+
+/* If non-zero, the STMT_LINENO for NODE is the line at which the
+   function ended.  */
+#define STMT_LINENO_FOR_FN_P(NODE)             \
+  (TREE_LANG_FLAG_2 ((NODE)))
+
+
+#define DEFTREECODE(SYM, NAME, TYPE, LENGTH) SYM,
+
+enum c_tree_code {
+  C_DUMMY_TREE_CODE = LAST_AND_UNUSED_TREE_CODE,
+#include "c-common.def"
+  LAST_C_TREE_CODE
+};
+
+#undef DEFTREECODE
+
+extern void add_c_tree_codes                   PARAMS ((void));
+\f
+
+/* These functions must be defined by each front-end which implements
+   a variant of the C language.  They are used in c-common.c.  */
+
+extern tree build_unary_op                      PARAMS ((enum tree_code,
+                                                        tree, int));
+extern tree build_binary_op                     PARAMS ((enum tree_code,
+                                                        tree, tree, int));
+extern int lvalue_p                            PARAMS ((tree));
+extern tree default_conversion                  PARAMS ((tree));
+
+/* Given two integer or real types, return the type for their sum.
+   Given two compatible ANSI C types, returns the merged type.  */
 
-extern tree build_va_arg                       PROTO((tree, tree));
+extern tree common_type                         PARAMS ((tree, tree));
 
-extern tree initializer_constant_valid_p       PROTO((tree, tree));