X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=gas%2Fmacro.h;h=e9bd9e1110cac1c44e5b9feaecd47670774198eb;hb=301a9420d947da145884261ac31a7a52438c2894;hp=4fdaa52d09745af518a2c16eb64bfb796f7f9881;hpb=6eaeac8ad728ca5efd19aca44c559199dcb296e2;p=deliverable%2Fbinutils-gdb.git diff --git a/gas/macro.h b/gas/macro.h index 4fdaa52d09..e9bd9e1110 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 - Free Software Foundation, Inc. + Copyright (C) 1994-2020 Free Software Foundation, Inc. Written by Steve and Judy Chamberlain of Cygnus Support, sac@cygnus.com @@ -9,7 +8,7 @@ GAS 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, or (at your option) + the Free Software Foundation; either version 3, or (at your option) any later version. GAS is distributed in the hope that it will be useful, @@ -26,9 +25,6 @@ #define MACRO_H -#include "ansidecl.h" -#include "sb.h" - /* Structures used to store macros. Each macro knows its name and included text. It gets built with a @@ -37,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 { @@ -45,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. */ @@ -67,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; @@ -83,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