toplev.c (main): Call the front-end specific post_options hook if one is given.
* toplev.c (main): Call the front-end specific post_options hook if one is given. * toplev.h (struct_lang_hooks, lang_hooks): New. * c-lang.c (c_post_options, lang_hooks): Implement lang_hooks for the C front end. * cp/decl2.c (cxx_post_options, lang_hooks): Implement lang_hooks for the C++ front end. * objc/objc-act.c (objc_post_options, lang_hooks): Implement lang_hooks for the ObjC front end. * f/com.c (lang_hooks): Hooks for the Fortran front end. * java/lang.c (lang_hooks): Hooks for the Java front end. From-SVN: r38757
This commit is contained in:
parent
65289a3a42
commit
cd2a3ba227
@ -1,3 +1,17 @@
|
|||||||
|
2001-01-07 Neil Booth <neil@daikokuya.demon.co.uk>
|
||||||
|
|
||||||
|
* toplev.c (main): Call the front-end specific post_options
|
||||||
|
hook if one is given.
|
||||||
|
* toplev.h (struct_lang_hooks, lang_hooks): New.
|
||||||
|
* c-lang.c (c_post_options, lang_hooks): Implement lang_hooks
|
||||||
|
for the C front end.
|
||||||
|
* cp/decl2.c (cxx_post_options, lang_hooks): Implement
|
||||||
|
lang_hooks for the C++ front end.
|
||||||
|
* objc/objc-act.c (objc_post_options, lang_hooks): Implement
|
||||||
|
lang_hooks for the ObjC front end.
|
||||||
|
* f/com.c (lang_hooks): Hooks for the Fortran front end.
|
||||||
|
* java/lang.c (lang_hooks): Hooks for the Java front end.
|
||||||
|
|
||||||
2001-01-07 Neil Booth <neil@daikokuya.demon.co.uk>
|
2001-01-07 Neil Booth <neil@daikokuya.demon.co.uk>
|
||||||
|
|
||||||
* c-lex.c (init_c_lex): Request #define / #undef callbacks
|
* c-lex.c (init_c_lex): Request #define / #undef callbacks
|
||||||
|
11
gcc/c-lang.c
11
gcc/c-lang.c
@ -38,10 +38,19 @@ Boston, MA 02111-1307, USA. */
|
|||||||
|
|
||||||
static int c_tree_printer PARAMS ((output_buffer *));
|
static int c_tree_printer PARAMS ((output_buffer *));
|
||||||
static int c_missing_noreturn_ok_p PARAMS ((tree));
|
static int c_missing_noreturn_ok_p PARAMS ((tree));
|
||||||
|
static void c_post_options PARAMS ((void));
|
||||||
|
|
||||||
|
/* Each front end provides its own. */
|
||||||
|
struct lang_hooks lang_hooks = {c_post_options};
|
||||||
|
|
||||||
|
/* Post-switch processing. */
|
||||||
|
static void
|
||||||
|
c_post_options ()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
/* Each of the functions defined here
|
/* Each of the functions defined here
|
||||||
is an alternative to a function in objc-actions.c. */
|
is an alternative to a function in objc-actions.c. */
|
||||||
|
|
||||||
int
|
int
|
||||||
lang_decode_option (argc, argv)
|
lang_decode_option (argc, argv)
|
||||||
int argc;
|
int argc;
|
||||||
|
@ -59,6 +59,7 @@ typedef struct priority_info_s {
|
|||||||
int destructions_p;
|
int destructions_p;
|
||||||
} *priority_info;
|
} *priority_info;
|
||||||
|
|
||||||
|
static void cxx_post_options PARAMS ((void));
|
||||||
static void mark_vtable_entries PARAMS ((tree));
|
static void mark_vtable_entries PARAMS ((tree));
|
||||||
static void grok_function_init PARAMS ((tree, tree));
|
static void grok_function_init PARAMS ((tree, tree));
|
||||||
static int finish_vtable_vardecl PARAMS ((tree *, void *));
|
static int finish_vtable_vardecl PARAMS ((tree *, void *));
|
||||||
@ -543,6 +544,15 @@ static const char * const unsupported_options[] = {
|
|||||||
"strict-prototype",
|
"strict-prototype",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* Each front end provides its own. */
|
||||||
|
struct lang_hooks lang_hooks = {cxx_post_options};
|
||||||
|
|
||||||
|
/* Post-switch processing. */
|
||||||
|
static void
|
||||||
|
cxx_post_options ()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
/* Compare two option strings, pointed two by P1 and P2, for use with
|
/* Compare two option strings, pointed two by P1 and P2, for use with
|
||||||
bsearch. */
|
bsearch. */
|
||||||
|
|
||||||
|
@ -14676,6 +14676,9 @@ insert_block (block)
|
|||||||
= chainon (current_binding_level->blocks, block);
|
= chainon (current_binding_level->blocks, block);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Each front end provides its own. */
|
||||||
|
struct lang_hooks lang_hooks = {NULL /* post_options */};
|
||||||
|
|
||||||
int
|
int
|
||||||
lang_decode_option (argc, argv)
|
lang_decode_option (argc, argv)
|
||||||
int argc;
|
int argc;
|
||||||
|
@ -186,6 +186,9 @@ static int dependency_tracking = 0;
|
|||||||
#define DEPEND_TARGET_SET 4
|
#define DEPEND_TARGET_SET 4
|
||||||
#define DEPEND_FILE_ALREADY_SET 8
|
#define DEPEND_FILE_ALREADY_SET 8
|
||||||
|
|
||||||
|
/* Each front end provides its own. */
|
||||||
|
struct lang_hooks lang_hooks = {NULL /* post_options */};
|
||||||
|
|
||||||
/* Process an option that can accept a `no-' form.
|
/* Process an option that can accept a `no-' form.
|
||||||
Return 1 if option found, 0 otherwise. */
|
Return 1 if option found, 0 otherwise. */
|
||||||
static int
|
static int
|
||||||
|
@ -148,6 +148,7 @@ char *util_firstobj;
|
|||||||
|
|
||||||
static void init_objc PARAMS ((void));
|
static void init_objc PARAMS ((void));
|
||||||
static void finish_objc PARAMS ((void));
|
static void finish_objc PARAMS ((void));
|
||||||
|
static void objc_post_options PARAMS ((void));
|
||||||
|
|
||||||
/* Code generation. */
|
/* Code generation. */
|
||||||
|
|
||||||
@ -626,6 +627,15 @@ static int generating_instance_variables = 0;
|
|||||||
|
|
||||||
static int print_struct_values = 0;
|
static int print_struct_values = 0;
|
||||||
|
|
||||||
|
/* Each front end provides its own. */
|
||||||
|
struct lang_hooks lang_hooks = {objc_post_options};
|
||||||
|
|
||||||
|
/* Post-switch processing. */
|
||||||
|
static void
|
||||||
|
objc_post_options ()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
/* Some platforms pass small structures through registers versus through
|
/* Some platforms pass small structures through registers versus through
|
||||||
an invisible pointer. Determine at what size structure is the
|
an invisible pointer. Determine at what size structure is the
|
||||||
transition point between the two possibilities. */
|
transition point between the two possibilities. */
|
||||||
|
@ -4750,6 +4750,10 @@ main (argc, argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* All command line options have been processed. */
|
||||||
|
if (lang_hooks.post_options)
|
||||||
|
(*lang_hooks.post_options) ();
|
||||||
|
|
||||||
/* Reflect any language-specific diagnostic option setting. */
|
/* Reflect any language-specific diagnostic option setting. */
|
||||||
reshape_diagnostic_buffer ();
|
reshape_diagnostic_buffer ();
|
||||||
|
|
||||||
|
10
gcc/toplev.h
10
gcc/toplev.h
@ -133,4 +133,14 @@ extern int sorrycount;
|
|||||||
|
|
||||||
extern const char *progname;
|
extern const char *progname;
|
||||||
|
|
||||||
|
/* Language-specific hooks. */
|
||||||
|
struct lang_hooks
|
||||||
|
{
|
||||||
|
/* If non-NULL, called when all command line options have been processed. */
|
||||||
|
void (*post_options) PARAMS ((void));
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Each front end provides its own. */
|
||||||
|
extern struct lang_hooks lang_hooks;
|
||||||
|
|
||||||
#endif /* __GCC_TOPLEV_H */
|
#endif /* __GCC_TOPLEV_H */
|
||||||
|
Loading…
Reference in New Issue
Block a user