source: trunk/src/binutils/gas/macro.h@ 823

Last change on this file since 823 was 610, checked in by bird, 22 years ago

This commit was generated by cvs2svn to compensate for changes in r609,
which included commits to RCS files with non-trunk default branches.

  • Property cvs2svn:cvs-rev set to 1.1.1.2
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 2.9 KB
Line 
1/* macro.h - header file for macro support for gas
2 Copyright 1994, 1995, 1996, 1997, 1998, 2000, 2002
3 Free Software Foundation, Inc.
4
5 Written by Steve and Judy Chamberlain of Cygnus Support,
6 sac@cygnus.com
7
8 This file is part of GAS, the GNU Assembler.
9
10 GAS is free software; you can redistribute it and/or modify
11 it under the terms of the GNU General Public License as published by
12 the Free Software Foundation; either version 2, or (at your option)
13 any later version.
14
15 GAS is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License for more details.
19
20 You should have received a copy of the GNU General Public License
21 along with GAS; see the file COPYING. If not, write to the Free
22 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
23 02111-1307, USA. */
24
25#ifndef MACRO_H
26
27#define MACRO_H
28
29#include "ansidecl.h"
30#include "sb.h"
31
32/* Structures used to store macros.
33
34 Each macro knows its name and included text. It gets built with a
35 list of formal arguments, and also keeps a hash table which points
36 into the list to speed up formal search. Each formal knows its
37 name and its default value. Each time the macro is expanded, the
38 formals get the actual values attatched to them. */
39
40/* Describe the formal arguments to a macro. */
41
42typedef struct formal_struct {
43 struct formal_struct *next; /* Next formal in list. */
44 sb name; /* Name of the formal. */
45 sb def; /* The default value. */
46 sb actual; /* The actual argument (changed on each expansion). */
47 int index; /* The index of the formal 0..formal_count - 1. */
48} formal_entry;
49
50/* Other values found in the index field of a formal_entry. */
51#define QUAL_INDEX (-1)
52#define NARG_INDEX (-2)
53#define LOCAL_INDEX (-3)
54
55/* Describe the macro. */
56
57typedef struct macro_struct
58{
59 sb sub; /* Substitution text. */
60 int formal_count; /* Number of formal args. */
61 formal_entry *formals; /* Pointer to list of formal_structs. */
62 struct hash_control *formal_hash; /* Hash table of formals. */
63} macro_entry;
64
65/* Whether any macros have been defined. */
66
67extern int macro_defined;
68
69/* The macro nesting level. */
70
71extern int macro_nest;
72
73extern int buffer_and_nest
74 PARAMS ((const char *, const char *, sb *, int (*) PARAMS ((sb *))));
75extern void macro_init
76 PARAMS ((int, int, int, int (*) PARAMS ((const char *, int, sb *, int *))));
77extern void macro_mri_mode
78 PARAMS ((int));
79extern const char *define_macro
80 PARAMS ((int, sb *, sb *, int (*) PARAMS ((sb *)), const char **));
81extern int check_macro
82 PARAMS ((const char *, sb *, const char **, macro_entry **));
83extern void delete_macro
84 PARAMS ((const char *));
85extern const char *expand_irp
86 PARAMS ((int, int, sb *, sb *, int (*) PARAMS ((sb *))));
87
88#endif
Note: See TracBrowser for help on using the repository browser.