X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=gas%2Fmacro.h;h=7000197729b738e673457fda4fb5058a5a788c30;hb=c88960d081f0b37ec03c66a13115e2a68e40d1ad;hp=4db8018e1792e20fb8ab5f249e28ff587eb93996;hpb=aa820537ead0135a7c38c619039dce8a6fc74ed1;p=deliverable%2Fbinutils-gdb.git diff --git a/gas/macro.h b/gas/macro.h index 4db8018e17..7000197729 100644 --- a/gas/macro.h +++ b/gas/macro.h @@ -1,6 +1,5 @@ /* macro.h - header file for macro support for gas - Copyright 1994, 1995, 1996, 1997, 1998, 2000, 2002, 2003, 2004, 2005, 2006, - 2007 Free Software Foundation, Inc. + Copyright (C) 1994-2016 Free Software Foundation, Inc. Written by Steve and Judy Chamberlain of Cygnus Support, sac@cygnus.com @@ -34,6 +33,13 @@ name and its default value. Each time the macro is expanded, the formals get the actual values attached to them. */ +enum formal_type + { + FORMAL_OPTIONAL, + FORMAL_REQUIRED, + FORMAL_VARARG + }; + /* Describe the formal arguments to a macro. */ typedef struct formal_struct { @@ -42,12 +48,7 @@ typedef struct formal_struct { sb def; /* The default value. */ sb actual; /* The actual argument (changed on each expansion). */ int index; /* The index of the formal 0..formal_count - 1. */ - enum formal_type - { - FORMAL_OPTIONAL, - FORMAL_REQUIRED, - FORMAL_VARARG - } type; /* The kind of the formal. */ + enum formal_type type; /* The kind of the formal. */ } formal_entry; /* Other values found in the index field of a formal_entry. */ @@ -64,7 +65,7 @@ typedef struct macro_struct formal_entry *formals; /* Pointer to list of formal_structs. */ struct hash_control *formal_hash; /* Hash table of formals. */ const char *name; /* Macro name. */ - char *file; /* File the macro was defined in. */ + const char *file; /* File the macro was defined in. */ unsigned int line; /* Line number of definition. */ } macro_entry; @@ -80,15 +81,16 @@ extern int macro_nest; extern struct hash_control *macro_hash; -extern int buffer_and_nest (const char *, const char *, sb *, int (*) (sb *)); -extern void macro_init - (int, int, int, int (*) (const char *, int, sb *, int *)); +extern int buffer_and_nest (const char *, const char *, sb *, + size_t (*) (sb *)); +extern void macro_init (int, int, int, + size_t (*) (const char *, size_t, sb *, offsetT *)); extern void macro_set_alternate (int); extern void macro_mri_mode (int); -extern const char *define_macro - (int, sb *, sb *, int (*) (sb *), char *, unsigned int, const char **); +extern const char *define_macro (size_t, sb *, sb *, size_t (*) (sb *), + const char *, unsigned int, const char **); extern int check_macro (const char *, sb *, const char **, macro_entry **); extern void delete_macro (const char *); -extern const char *expand_irp (int, int, sb *, sb *, int (*) (sb *)); +extern const char *expand_irp (int, size_t, sb *, sb *, size_t (*) (sb *)); #endif