Configury changes: update src repository (binutils, gdb, and rda) to use
[binutils.git] / gas / macro.c
blobe6e9d05ba2728814140a2cfefc7e7add80497610
1 /* macro.c - macro support for gas
2 Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003,
3 2004, 2005 Free Software Foundation, Inc.
5 Written by Steve and Judy Chamberlain of Cygnus Support,
6 sac@cygnus.com
8 This file is part of GAS, the GNU Assembler.
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.
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.
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, 51 Franklin Street - Fifth Floor, Boston, MA
23 02110-1301, USA. */
25 #include "config.h"
27 #ifndef __GNUC__
28 # if HAVE_ALLOCA_H
29 # include <alloca.h>
30 # else
31 # ifdef _AIX
32 /* Indented so that pre-ansi C compilers will ignore it, rather than
33 choke on it. Some versions of AIX require this to be the first
34 thing in the file. */
35 #pragma alloca
36 # else
37 # ifndef alloca /* predefined by HP cc +Olibcalls */
38 # if !defined (__STDC__) && !defined (__hpux)
39 extern char *alloca ();
40 # else
41 extern void *alloca ();
42 # endif /* __STDC__, __hpux */
43 # endif /* alloca */
44 # endif /* _AIX */
45 # endif /* HAVE_ALLOCA_H */
46 #endif /* __GNUC__ */
48 #include <stdio.h>
49 #ifdef HAVE_STRING_H
50 #include <string.h>
51 #else
52 #include <strings.h>
53 #endif
54 #ifdef HAVE_STDLIB_H
55 #include <stdlib.h>
56 #endif
57 #include "as.h"
58 #include "libiberty.h"
59 #include "safe-ctype.h"
60 #include "sb.h"
61 #include "hash.h"
62 #include "macro.h"
64 #include "asintl.h"
66 /* The routines in this file handle macro definition and expansion.
67 They are called by gas. */
69 /* Internal functions. */
71 static int get_token (int, sb *, sb *);
72 static int getstring (int, sb *, sb *);
73 static int get_any_string (int, sb *, sb *);
74 static formal_entry *new_formal (void);
75 static void del_formal (formal_entry *);
76 static int do_formals (macro_entry *, int, sb *);
77 static int get_apost_token (int, sb *, sb *, int);
78 static int sub_actual (int, sb *, sb *, struct hash_control *, int, sb *, int);
79 static const char *macro_expand_body
80 (sb *, sb *, formal_entry *, struct hash_control *, const macro_entry *);
81 static const char *macro_expand (int, sb *, macro_entry *, sb *);
82 static void free_macro(macro_entry *);
84 #define ISWHITE(x) ((x) == ' ' || (x) == '\t')
86 #define ISSEP(x) \
87 ((x) == ' ' || (x) == '\t' || (x) == ',' || (x) == '"' || (x) == ';' \
88 || (x) == ')' || (x) == '(' \
89 || ((macro_alternate || macro_mri) && ((x) == '<' || (x) == '>')))
91 #define ISBASE(x) \
92 ((x) == 'b' || (x) == 'B' \
93 || (x) == 'q' || (x) == 'Q' \
94 || (x) == 'h' || (x) == 'H' \
95 || (x) == 'd' || (x) == 'D')
97 /* The macro hash table. */
99 struct hash_control *macro_hash;
101 /* Whether any macros have been defined. */
103 int macro_defined;
105 /* Whether we are in alternate syntax mode. */
107 static int macro_alternate;
109 /* Whether we are in MRI mode. */
111 static int macro_mri;
113 /* Whether we should strip '@' characters. */
115 static int macro_strip_at;
117 /* Function to use to parse an expression. */
119 static int (*macro_expr) (const char *, int, sb *, int *);
121 /* Number of macro expansions that have been done. */
123 static int macro_number;
125 /* Initialize macro processing. */
127 void
128 macro_init (int alternate, int mri, int strip_at,
129 int (*expr) (const char *, int, sb *, int *))
131 macro_hash = hash_new ();
132 macro_defined = 0;
133 macro_alternate = alternate;
134 macro_mri = mri;
135 macro_strip_at = strip_at;
136 macro_expr = expr;
139 /* Switch in and out of alternate mode on the fly. */
141 void
142 macro_set_alternate (int alternate)
144 macro_alternate = alternate;
147 /* Switch in and out of MRI mode on the fly. */
149 void
150 macro_mri_mode (int mri)
152 macro_mri = mri;
155 /* Read input lines till we get to a TO string.
156 Increase nesting depth if we get a FROM string.
157 Put the results into sb at PTR.
158 FROM may be NULL (or will be ignored) if TO is "ENDR".
159 Add a new input line to an sb using GET_LINE.
160 Return 1 on success, 0 on unexpected EOF. */
163 buffer_and_nest (const char *from, const char *to, sb *ptr,
164 int (*get_line) (sb *))
166 int from_len;
167 int to_len = strlen (to);
168 int depth = 1;
169 int line_start = ptr->len;
171 int more = get_line (ptr);
173 if (to_len == 4 && strcasecmp(to, "ENDR") == 0)
175 from = NULL;
176 from_len = 0;
178 else
179 from_len = strlen (from);
181 while (more)
183 /* Try to find the first pseudo op on the line. */
184 int i = line_start;
186 /* With normal syntax we can suck what we want till we get
187 to the dot. With the alternate, labels have to start in
188 the first column, since we can't tell what's a label and
189 what's a pseudoop. */
191 if (! LABELS_WITHOUT_COLONS)
193 /* Skip leading whitespace. */
194 while (i < ptr->len && ISWHITE (ptr->ptr[i]))
195 i++;
198 for (;;)
200 /* Skip over a label, if any. */
201 if (i >= ptr->len || ! is_name_beginner (ptr->ptr[i]))
202 break;
203 i++;
204 while (i < ptr->len && is_part_of_name (ptr->ptr[i]))
205 i++;
206 if (i < ptr->len && is_name_ender (ptr->ptr[i]))
207 i++;
208 if (LABELS_WITHOUT_COLONS)
209 break;
210 /* Skip whitespace. */
211 while (i < ptr->len && ISWHITE (ptr->ptr[i]))
212 i++;
213 /* Check for the colon. */
214 if (i >= ptr->len || ptr->ptr[i] != ':')
216 i = line_start;
217 break;
219 i++;
220 line_start = i;
223 /* Skip trailing whitespace. */
224 while (i < ptr->len && ISWHITE (ptr->ptr[i]))
225 i++;
227 if (i < ptr->len && (ptr->ptr[i] == '.'
228 || NO_PSEUDO_DOT
229 || macro_mri))
231 if (! flag_m68k_mri && ptr->ptr[i] == '.')
232 i++;
233 if (from == NULL
234 && strncasecmp (ptr->ptr + i, "IRPC", from_len = 4) != 0
235 && strncasecmp (ptr->ptr + i, "IRP", from_len = 3) != 0
236 && strncasecmp (ptr->ptr + i, "IREPC", from_len = 5) != 0
237 && strncasecmp (ptr->ptr + i, "IREP", from_len = 4) != 0
238 && strncasecmp (ptr->ptr + i, "REPT", from_len = 4) != 0
239 && strncasecmp (ptr->ptr + i, "REP", from_len = 3) != 0)
240 from_len = 0;
241 if ((from != NULL
242 ? strncasecmp (ptr->ptr + i, from, from_len) == 0
243 : from_len > 0)
244 && (ptr->len == (i + from_len)
245 || ! (is_part_of_name (ptr->ptr[i + from_len])
246 || is_name_ender (ptr->ptr[i + from_len]))))
247 depth++;
248 if (strncasecmp (ptr->ptr + i, to, to_len) == 0
249 && (ptr->len == (i + to_len)
250 || ! (is_part_of_name (ptr->ptr[i + to_len])
251 || is_name_ender (ptr->ptr[i + to_len]))))
253 depth--;
254 if (depth == 0)
256 /* Reset the string to not include the ending rune. */
257 ptr->len = line_start;
258 break;
263 /* Add the original end-of-line char to the end and keep running. */
264 sb_add_char (ptr, more);
265 line_start = ptr->len;
266 more = get_line (ptr);
269 /* Return 1 on success, 0 on unexpected EOF. */
270 return depth == 0;
273 /* Pick up a token. */
275 static int
276 get_token (int idx, sb *in, sb *name)
278 if (idx < in->len
279 && is_name_beginner (in->ptr[idx]))
281 sb_add_char (name, in->ptr[idx++]);
282 while (idx < in->len
283 && is_part_of_name (in->ptr[idx]))
285 sb_add_char (name, in->ptr[idx++]);
287 if (idx < in->len
288 && is_name_ender (in->ptr[idx]))
290 sb_add_char (name, in->ptr[idx++]);
293 /* Ignore trailing &. */
294 if (macro_alternate && idx < in->len && in->ptr[idx] == '&')
295 idx++;
296 return idx;
299 /* Pick up a string. */
301 static int
302 getstring (int idx, sb *in, sb *acc)
304 while (idx < in->len
305 && (in->ptr[idx] == '"'
306 || (in->ptr[idx] == '<' && (macro_alternate || macro_mri))
307 || (in->ptr[idx] == '\'' && macro_alternate)))
309 if (in->ptr[idx] == '<')
311 int nest = 0;
312 idx++;
313 while ((in->ptr[idx] != '>' || nest)
314 && idx < in->len)
316 if (in->ptr[idx] == '!')
318 idx++;
319 sb_add_char (acc, in->ptr[idx++]);
321 else
323 if (in->ptr[idx] == '>')
324 nest--;
325 if (in->ptr[idx] == '<')
326 nest++;
327 sb_add_char (acc, in->ptr[idx++]);
330 idx++;
332 else if (in->ptr[idx] == '"' || in->ptr[idx] == '\'')
334 char tchar = in->ptr[idx];
335 int escaped = 0;
337 idx++;
339 while (idx < in->len)
341 if (in->ptr[idx - 1] == '\\')
342 escaped ^= 1;
343 else
344 escaped = 0;
346 if (macro_alternate && in->ptr[idx] == '!')
348 idx ++;
350 sb_add_char (acc, in->ptr[idx]);
352 idx ++;
354 else if (escaped && in->ptr[idx] == tchar)
356 sb_add_char (acc, tchar);
357 idx ++;
359 else
361 if (in->ptr[idx] == tchar)
363 idx ++;
365 if (idx >= in->len || in->ptr[idx] != tchar)
366 break;
369 sb_add_char (acc, in->ptr[idx]);
370 idx ++;
376 return idx;
379 /* Fetch string from the input stream,
380 rules:
381 'Bxyx<whitespace> -> return 'Bxyza
382 %<expr> -> return string of decimal value of <expr>
383 "string" -> return string
384 (string) -> return (string-including-whitespaces)
385 xyx<whitespace> -> return xyz. */
387 static int
388 get_any_string (int idx, sb *in, sb *out)
390 sb_reset (out);
391 idx = sb_skip_white (idx, in);
393 if (idx < in->len)
395 if (in->len > idx + 2 && in->ptr[idx + 1] == '\'' && ISBASE (in->ptr[idx]))
397 while (!ISSEP (in->ptr[idx]))
398 sb_add_char (out, in->ptr[idx++]);
400 else if (in->ptr[idx] == '%' && macro_alternate)
402 int val;
403 char buf[20];
405 /* Turns the next expression into a string. */
406 /* xgettext: no-c-format */
407 idx = (*macro_expr) (_("% operator needs absolute expression"),
408 idx + 1,
410 &val);
411 sprintf (buf, "%d", val);
412 sb_add_string (out, buf);
414 else if (in->ptr[idx] == '"'
415 || (in->ptr[idx] == '<' && (macro_alternate || macro_mri))
416 || (macro_alternate && in->ptr[idx] == '\''))
418 if (macro_alternate && ! macro_strip_at && in->ptr[idx] != '<')
420 /* Keep the quotes. */
421 sb_add_char (out, '"');
422 idx = getstring (idx, in, out);
423 sb_add_char (out, '"');
425 else
427 idx = getstring (idx, in, out);
430 else
432 char *br_buf = xmalloc(1);
433 char *in_br = br_buf;
435 *in_br = '\0';
436 while (idx < in->len
437 && (*in_br
438 || (in->ptr[idx] != ' '
439 && in->ptr[idx] != '\t'))
440 && in->ptr[idx] != ','
441 && (in->ptr[idx] != '<'
442 || (! macro_alternate && ! macro_mri)))
444 char tchar = in->ptr[idx];
446 switch (tchar)
448 case '"':
449 case '\'':
450 sb_add_char (out, in->ptr[idx++]);
451 while (idx < in->len
452 && in->ptr[idx] != tchar)
453 sb_add_char (out, in->ptr[idx++]);
454 if (idx == in->len)
455 return idx;
456 break;
457 case '(':
458 case '[':
459 if (in_br > br_buf)
460 --in_br;
461 else
463 br_buf = xmalloc(strlen(in_br) + 2);
464 strcpy(br_buf + 1, in_br);
465 free(in_br);
466 in_br = br_buf;
468 *in_br = tchar;
469 break;
470 case ')':
471 if (*in_br == '(')
472 ++in_br;
473 break;
474 case ']':
475 if (*in_br == '[')
476 ++in_br;
477 break;
479 sb_add_char (out, tchar);
480 ++idx;
482 free(br_buf);
486 return idx;
489 /* Allocate a new formal. */
491 static formal_entry *
492 new_formal (void)
494 formal_entry *formal;
496 formal = xmalloc (sizeof (formal_entry));
498 sb_new (&formal->name);
499 sb_new (&formal->def);
500 sb_new (&formal->actual);
501 formal->next = NULL;
502 formal->type = FORMAL_OPTIONAL;
503 return formal;
506 /* Free a formal. */
508 static void
509 del_formal (formal_entry *formal)
511 sb_kill (&formal->actual);
512 sb_kill (&formal->def);
513 sb_kill (&formal->name);
514 free (formal);
517 /* Pick up the formal parameters of a macro definition. */
519 static int
520 do_formals (macro_entry *macro, int idx, sb *in)
522 formal_entry **p = &macro->formals;
523 const char *name;
525 idx = sb_skip_white (idx, in);
526 while (idx < in->len)
528 formal_entry *formal = new_formal ();
529 int cidx;
531 idx = get_token (idx, in, &formal->name);
532 if (formal->name.len == 0)
534 if (macro->formal_count)
535 --idx;
536 break;
538 idx = sb_skip_white (idx, in);
539 /* This is a formal. */
540 name = sb_terminate (&formal->name);
541 if (! macro_mri
542 && idx < in->len
543 && in->ptr[idx] == ':'
544 && (! is_name_beginner (':')
545 || idx + 1 >= in->len
546 || ! is_part_of_name (in->ptr[idx + 1])))
548 /* Got a qualifier. */
549 sb qual;
551 sb_new (&qual);
552 idx = get_token (sb_skip_white (idx + 1, in), in, &qual);
553 sb_terminate (&qual);
554 if (qual.len == 0)
555 as_bad_where (macro->file,
556 macro->line,
557 _("Missing parameter qualifier for `%s' in macro `%s'"),
558 name,
559 macro->name);
560 else if (strcmp (qual.ptr, "req") == 0)
561 formal->type = FORMAL_REQUIRED;
562 else if (strcmp (qual.ptr, "vararg") == 0)
563 formal->type = FORMAL_VARARG;
564 else
565 as_bad_where (macro->file,
566 macro->line,
567 _("`%s' is not a valid parameter qualifier for `%s' in macro `%s'"),
568 qual.ptr,
569 name,
570 macro->name);
571 sb_kill (&qual);
572 idx = sb_skip_white (idx, in);
574 if (idx < in->len && in->ptr[idx] == '=')
576 /* Got a default. */
577 idx = get_any_string (idx + 1, in, &formal->def);
578 idx = sb_skip_white (idx, in);
579 if (formal->type == FORMAL_REQUIRED)
581 sb_reset (&formal->def);
582 as_warn_where (macro->file,
583 macro->line,
584 _("Pointless default value for required parameter `%s' in macro `%s'"),
585 name,
586 macro->name);
590 /* Add to macro's hash table. */
591 if (! hash_find (macro->formal_hash, name))
592 hash_jam (macro->formal_hash, name, formal);
593 else
594 as_bad_where (macro->file,
595 macro->line,
596 _("A parameter named `%s' already exists for macro `%s'"),
597 name,
598 macro->name);
600 formal->index = macro->formal_count++;
601 *p = formal;
602 p = &formal->next;
603 if (formal->type == FORMAL_VARARG)
604 break;
605 cidx = idx;
606 idx = sb_skip_comma (idx, in);
607 if (idx != cidx && idx >= in->len)
609 idx = cidx;
610 break;
614 if (macro_mri)
616 formal_entry *formal = new_formal ();
618 /* Add a special NARG formal, which macro_expand will set to the
619 number of arguments. */
620 /* The same MRI assemblers which treat '@' characters also use
621 the name $NARG. At least until we find an exception. */
622 if (macro_strip_at)
623 name = "$NARG";
624 else
625 name = "NARG";
627 sb_add_string (&formal->name, name);
629 /* Add to macro's hash table. */
630 if (hash_find (macro->formal_hash, name))
631 as_bad_where (macro->file,
632 macro->line,
633 _("Reserved word `%s' used as parameter in macro `%s'"),
634 name,
635 macro->name);
636 hash_jam (macro->formal_hash, name, formal);
638 formal->index = NARG_INDEX;
639 *p = formal;
642 return idx;
645 /* Define a new macro. Returns NULL on success, otherwise returns an
646 error message. If NAMEP is not NULL, *NAMEP is set to the name of
647 the macro which was defined. */
649 const char *
650 define_macro (int idx, sb *in, sb *label,
651 int (*get_line) (sb *),
652 char *file, unsigned int line,
653 const char **namep)
655 macro_entry *macro;
656 sb name;
657 const char *error = NULL;
659 macro = (macro_entry *) xmalloc (sizeof (macro_entry));
660 sb_new (&macro->sub);
661 sb_new (&name);
662 macro->file = file;
663 macro->line = line;
665 macro->formal_count = 0;
666 macro->formals = 0;
667 macro->formal_hash = hash_new ();
669 idx = sb_skip_white (idx, in);
670 if (! buffer_and_nest ("MACRO", "ENDM", &macro->sub, get_line))
671 error = _("unexpected end of file in macro `%s' definition");
672 if (label != NULL && label->len != 0)
674 sb_add_sb (&name, label);
675 macro->name = sb_terminate (&name);
676 if (idx < in->len && in->ptr[idx] == '(')
678 /* It's the label: MACRO (formals,...) sort */
679 idx = do_formals (macro, idx + 1, in);
680 if (idx < in->len && in->ptr[idx] == ')')
681 idx = sb_skip_white (idx + 1, in);
682 else if (!error)
683 error = _("missing `)' after formals in macro definition `%s'");
685 else
687 /* It's the label: MACRO formals,... sort */
688 idx = do_formals (macro, idx, in);
691 else
693 int cidx;
695 idx = get_token (idx, in, &name);
696 macro->name = sb_terminate (&name);
697 if (name.len == 0)
698 error = _("Missing macro name");
699 cidx = sb_skip_white (idx, in);
700 idx = sb_skip_comma (cidx, in);
701 if (idx == cidx || idx < in->len)
702 idx = do_formals (macro, idx, in);
703 else
704 idx = cidx;
706 if (!error && idx < in->len)
707 error = _("Bad parameter list for macro `%s'");
709 /* And stick it in the macro hash table. */
710 for (idx = 0; idx < name.len; idx++)
711 name.ptr[idx] = TOLOWER (name.ptr[idx]);
712 if (hash_find (macro_hash, macro->name))
713 error = _("Macro `%s' was already defined");
714 if (!error)
715 error = hash_jam (macro_hash, macro->name, (PTR) macro);
717 if (namep != NULL)
718 *namep = macro->name;
720 if (!error)
721 macro_defined = 1;
722 else
723 free_macro (macro);
725 return error;
728 /* Scan a token, and then skip KIND. */
730 static int
731 get_apost_token (int idx, sb *in, sb *name, int kind)
733 idx = get_token (idx, in, name);
734 if (idx < in->len
735 && in->ptr[idx] == kind
736 && (! macro_mri || macro_strip_at)
737 && (! macro_strip_at || kind == '@'))
738 idx++;
739 return idx;
742 /* Substitute the actual value for a formal parameter. */
744 static int
745 sub_actual (int start, sb *in, sb *t, struct hash_control *formal_hash,
746 int kind, sb *out, int copyifnotthere)
748 int src;
749 formal_entry *ptr;
751 src = get_apost_token (start, in, t, kind);
752 /* See if it's in the macro's hash table, unless this is
753 macro_strip_at and kind is '@' and the token did not end in '@'. */
754 if (macro_strip_at
755 && kind == '@'
756 && (src == start || in->ptr[src - 1] != '@'))
757 ptr = NULL;
758 else
759 ptr = (formal_entry *) hash_find (formal_hash, sb_terminate (t));
760 if (ptr)
762 if (ptr->actual.len)
764 sb_add_sb (out, &ptr->actual);
766 else
768 sb_add_sb (out, &ptr->def);
771 else if (kind == '&')
773 /* Doing this permits people to use & in macro bodies. */
774 sb_add_char (out, '&');
775 sb_add_sb (out, t);
777 else if (copyifnotthere)
779 sb_add_sb (out, t);
781 else
783 sb_add_char (out, '\\');
784 sb_add_sb (out, t);
786 return src;
789 /* Expand the body of a macro. */
791 static const char *
792 macro_expand_body (sb *in, sb *out, formal_entry *formals,
793 struct hash_control *formal_hash, const macro_entry *macro)
795 sb t;
796 int src = 0, inquote = 0, macro_line = 0;
797 formal_entry *loclist = NULL;
798 const char *err = NULL;
800 sb_new (&t);
802 while (src < in->len && !err)
804 if (in->ptr[src] == '&')
806 sb_reset (&t);
807 if (macro_mri)
809 if (src + 1 < in->len && in->ptr[src + 1] == '&')
810 src = sub_actual (src + 2, in, &t, formal_hash, '\'', out, 1);
811 else
812 sb_add_char (out, in->ptr[src++]);
814 else
816 /* FIXME: Why do we do this? */
817 /* At least in alternate mode this seems correct; without this
818 one can't append a literal to a parameter. */
819 src = sub_actual (src + 1, in, &t, formal_hash, '&', out, 0);
822 else if (in->ptr[src] == '\\')
824 src++;
825 if (src < in->len && in->ptr[src] == '(')
827 /* Sub in till the next ')' literally. */
828 src++;
829 while (src < in->len && in->ptr[src] != ')')
831 sb_add_char (out, in->ptr[src++]);
833 if (src < in->len)
834 src++;
835 else if (!macro)
836 err = _("missing `)'");
837 else
838 as_bad_where (macro->file, macro->line + macro_line, _("missing `)'"));
840 else if (src < in->len && in->ptr[src] == '@')
842 /* Sub in the macro invocation number. */
844 char buffer[10];
845 src++;
846 sprintf (buffer, "%d", macro_number);
847 sb_add_string (out, buffer);
849 else if (src < in->len && in->ptr[src] == '&')
851 /* This is a preprocessor variable name, we don't do them
852 here. */
853 sb_add_char (out, '\\');
854 sb_add_char (out, '&');
855 src++;
857 else if (macro_mri && src < in->len && ISALNUM (in->ptr[src]))
859 int ind;
860 formal_entry *f;
862 if (ISDIGIT (in->ptr[src]))
863 ind = in->ptr[src] - '0';
864 else if (ISUPPER (in->ptr[src]))
865 ind = in->ptr[src] - 'A' + 10;
866 else
867 ind = in->ptr[src] - 'a' + 10;
868 ++src;
869 for (f = formals; f != NULL; f = f->next)
871 if (f->index == ind - 1)
873 if (f->actual.len != 0)
874 sb_add_sb (out, &f->actual);
875 else
876 sb_add_sb (out, &f->def);
877 break;
881 else
883 sb_reset (&t);
884 src = sub_actual (src, in, &t, formal_hash, '\'', out, 0);
887 else if ((macro_alternate || macro_mri)
888 && is_name_beginner (in->ptr[src])
889 && (! inquote
890 || ! macro_strip_at
891 || (src > 0 && in->ptr[src - 1] == '@')))
893 if (! macro
894 || src + 5 >= in->len
895 || strncasecmp (in->ptr + src, "LOCAL", 5) != 0
896 || ! ISWHITE (in->ptr[src + 5]))
898 sb_reset (&t);
899 src = sub_actual (src, in, &t, formal_hash,
900 (macro_strip_at && inquote) ? '@' : '\'',
901 out, 1);
903 else
905 src = sb_skip_white (src + 5, in);
906 while (in->ptr[src] != '\n')
908 const char *name;
909 formal_entry *f = new_formal ();
911 src = get_token (src, in, &f->name);
912 name = sb_terminate (&f->name);
913 if (! hash_find (formal_hash, name))
915 static int loccnt;
916 char buf[20];
918 f->index = LOCAL_INDEX;
919 f->next = loclist;
920 loclist = f;
922 sprintf (buf, IS_ELF ? ".LL%04x" : "LL%04x", ++loccnt);
923 sb_add_string (&f->actual, buf);
925 err = hash_jam (formal_hash, name, f);
926 if (err != NULL)
927 break;
929 else
931 as_bad_where (macro->file,
932 macro->line + macro_line,
933 _("`%s' was already used as parameter (or another local) name"),
934 name);
935 del_formal (f);
938 src = sb_skip_comma (src, in);
942 else if (in->ptr[src] == '"'
943 || (macro_mri && in->ptr[src] == '\''))
945 inquote = !inquote;
946 sb_add_char (out, in->ptr[src++]);
948 else if (in->ptr[src] == '@' && macro_strip_at)
950 ++src;
951 if (src < in->len
952 && in->ptr[src] == '@')
954 sb_add_char (out, '@');
955 ++src;
958 else if (macro_mri
959 && in->ptr[src] == '='
960 && src + 1 < in->len
961 && in->ptr[src + 1] == '=')
963 formal_entry *ptr;
965 sb_reset (&t);
966 src = get_token (src + 2, in, &t);
967 ptr = (formal_entry *) hash_find (formal_hash, sb_terminate (&t));
968 if (ptr == NULL)
970 /* FIXME: We should really return a warning string here,
971 but we can't, because the == might be in the MRI
972 comment field, and, since the nature of the MRI
973 comment field depends upon the exact instruction
974 being used, we don't have enough information here to
975 figure out whether it is or not. Instead, we leave
976 the == in place, which should cause a syntax error if
977 it is not in a comment. */
978 sb_add_char (out, '=');
979 sb_add_char (out, '=');
980 sb_add_sb (out, &t);
982 else
984 if (ptr->actual.len)
986 sb_add_string (out, "-1");
988 else
990 sb_add_char (out, '0');
994 else
996 if (in->ptr[src] == '\n')
997 ++macro_line;
998 sb_add_char (out, in->ptr[src++]);
1002 sb_kill (&t);
1004 while (loclist != NULL)
1006 formal_entry *f;
1008 f = loclist->next;
1009 /* Setting the value to NULL effectively deletes the entry. We
1010 avoid calling hash_delete because it doesn't reclaim memory. */
1011 hash_jam (formal_hash, sb_terminate (&loclist->name), NULL);
1012 del_formal (loclist);
1013 loclist = f;
1016 return err;
1019 /* Assign values to the formal parameters of a macro, and expand the
1020 body. */
1022 static const char *
1023 macro_expand (int idx, sb *in, macro_entry *m, sb *out)
1025 sb t;
1026 formal_entry *ptr;
1027 formal_entry *f;
1028 int is_keyword = 0;
1029 int narg = 0;
1030 const char *err = NULL;
1032 sb_new (&t);
1034 /* Reset any old value the actuals may have. */
1035 for (f = m->formals; f; f = f->next)
1036 sb_reset (&f->actual);
1037 f = m->formals;
1038 while (f != NULL && f->index < 0)
1039 f = f->next;
1041 if (macro_mri)
1043 /* The macro may be called with an optional qualifier, which may
1044 be referred to in the macro body as \0. */
1045 if (idx < in->len && in->ptr[idx] == '.')
1047 /* The Microtec assembler ignores this if followed by a white space.
1048 (Macro invocation with empty extension) */
1049 idx++;
1050 if ( idx < in->len
1051 && in->ptr[idx] != ' '
1052 && in->ptr[idx] != '\t')
1054 formal_entry *n = new_formal ();
1056 n->index = QUAL_INDEX;
1058 n->next = m->formals;
1059 m->formals = n;
1061 idx = get_any_string (idx, in, &n->actual);
1066 /* Peel off the actuals and store them away in the hash tables' actuals. */
1067 idx = sb_skip_white (idx, in);
1068 while (idx < in->len)
1070 int scan;
1072 /* Look and see if it's a positional or keyword arg. */
1073 scan = idx;
1074 while (scan < in->len
1075 && !ISSEP (in->ptr[scan])
1076 && !(macro_mri && in->ptr[scan] == '\'')
1077 && (!macro_alternate && in->ptr[scan] != '='))
1078 scan++;
1079 if (scan < in->len && !macro_alternate && in->ptr[scan] == '=')
1081 is_keyword = 1;
1083 /* It's OK to go from positional to keyword. */
1085 /* This is a keyword arg, fetch the formal name and
1086 then the actual stuff. */
1087 sb_reset (&t);
1088 idx = get_token (idx, in, &t);
1089 if (in->ptr[idx] != '=')
1091 err = _("confusion in formal parameters");
1092 break;
1095 /* Lookup the formal in the macro's list. */
1096 ptr = (formal_entry *) hash_find (m->formal_hash, sb_terminate (&t));
1097 if (!ptr)
1098 as_bad (_("Parameter named `%s' does not exist for macro `%s'"),
1099 t.ptr,
1100 m->name);
1101 else
1103 /* Insert this value into the right place. */
1104 if (ptr->actual.len)
1106 as_warn (_("Value for parameter `%s' of macro `%s' was already specified"),
1107 ptr->name.ptr,
1108 m->name);
1109 sb_reset (&ptr->actual);
1111 idx = get_any_string (idx + 1, in, &ptr->actual);
1112 if (ptr->actual.len > 0)
1113 ++narg;
1116 else
1118 if (is_keyword)
1120 err = _("can't mix positional and keyword arguments");
1121 break;
1124 if (!f)
1126 formal_entry **pf;
1127 int c;
1129 if (!macro_mri)
1131 err = _("too many positional arguments");
1132 break;
1135 f = new_formal ();
1137 c = -1;
1138 for (pf = &m->formals; *pf != NULL; pf = &(*pf)->next)
1139 if ((*pf)->index >= c)
1140 c = (*pf)->index + 1;
1141 if (c == -1)
1142 c = 0;
1143 *pf = f;
1144 f->index = c;
1147 if (f->type != FORMAL_VARARG)
1148 idx = get_any_string (idx, in, &f->actual);
1149 else
1151 sb_add_buffer (&f->actual, in->ptr + idx, in->len - idx);
1152 idx = in->len;
1154 if (f->actual.len > 0)
1155 ++narg;
1158 f = f->next;
1160 while (f != NULL && f->index < 0);
1163 if (! macro_mri)
1164 idx = sb_skip_comma (idx, in);
1165 else
1167 if (in->ptr[idx] == ',')
1168 ++idx;
1169 if (ISWHITE (in->ptr[idx]))
1170 break;
1174 if (! err)
1176 for (ptr = m->formals; ptr; ptr = ptr->next)
1178 if (ptr->type == FORMAL_REQUIRED && ptr->actual.len == 0)
1179 as_bad (_("Missing value for required parameter `%s' of macro `%s'"),
1180 ptr->name.ptr,
1181 m->name);
1184 if (macro_mri)
1186 char buffer[20];
1188 sb_reset (&t);
1189 sb_add_string (&t, macro_strip_at ? "$NARG" : "NARG");
1190 ptr = (formal_entry *) hash_find (m->formal_hash, sb_terminate (&t));
1191 sprintf (buffer, "%d", narg);
1192 sb_add_string (&ptr->actual, buffer);
1195 err = macro_expand_body (&m->sub, out, m->formals, m->formal_hash, m);
1198 /* Discard any unnamed formal arguments. */
1199 if (macro_mri)
1201 formal_entry **pf;
1203 pf = &m->formals;
1204 while (*pf != NULL)
1206 if ((*pf)->name.len != 0)
1207 pf = &(*pf)->next;
1208 else
1210 f = (*pf)->next;
1211 del_formal (*pf);
1212 *pf = f;
1217 sb_kill (&t);
1218 if (!err)
1219 macro_number++;
1221 return err;
1224 /* Check for a macro. If one is found, put the expansion into
1225 *EXPAND. Return 1 if a macro is found, 0 otherwise. */
1228 check_macro (const char *line, sb *expand,
1229 const char **error, macro_entry **info)
1231 const char *s;
1232 char *copy, *cs;
1233 macro_entry *macro;
1234 sb line_sb;
1236 if (! is_name_beginner (*line)
1237 && (! macro_mri || *line != '.'))
1238 return 0;
1240 s = line + 1;
1241 while (is_part_of_name (*s))
1242 ++s;
1243 if (is_name_ender (*s))
1244 ++s;
1246 copy = (char *) alloca (s - line + 1);
1247 memcpy (copy, line, s - line);
1248 copy[s - line] = '\0';
1249 for (cs = copy; *cs != '\0'; cs++)
1250 *cs = TOLOWER (*cs);
1252 macro = (macro_entry *) hash_find (macro_hash, copy);
1254 if (macro == NULL)
1255 return 0;
1257 /* Wrap the line up in an sb. */
1258 sb_new (&line_sb);
1259 while (*s != '\0' && *s != '\n' && *s != '\r')
1260 sb_add_char (&line_sb, *s++);
1262 sb_new (expand);
1263 *error = macro_expand (0, &line_sb, macro, expand);
1265 sb_kill (&line_sb);
1267 /* Export the macro information if requested. */
1268 if (info)
1269 *info = macro;
1271 return 1;
1274 /* Free the memory allocated to a macro. */
1276 static void
1277 free_macro(macro_entry *macro)
1279 formal_entry *formal;
1281 for (formal = macro->formals; formal; )
1283 formal_entry *f;
1285 f = formal;
1286 formal = formal->next;
1287 del_formal (f);
1289 hash_die (macro->formal_hash);
1290 sb_kill (&macro->sub);
1291 free (macro);
1294 /* Delete a macro. */
1296 void
1297 delete_macro (const char *name)
1299 char *copy;
1300 size_t i, len;
1301 macro_entry *macro;
1303 len = strlen (name);
1304 copy = (char *) alloca (len + 1);
1305 for (i = 0; i < len; ++i)
1306 copy[i] = TOLOWER (name[i]);
1307 copy[i] = '\0';
1309 /* Since hash_delete doesn't free memory, just clear out the entry. */
1310 if ((macro = hash_find (macro_hash, copy)) != NULL)
1312 hash_jam (macro_hash, copy, NULL);
1313 free_macro (macro);
1315 else
1316 as_warn (_("Attempt to purge non-existant macro `%s'"), copy);
1319 /* Handle the MRI IRP and IRPC pseudo-ops. These are handled as a
1320 combined macro definition and execution. This returns NULL on
1321 success, or an error message otherwise. */
1323 const char *
1324 expand_irp (int irpc, int idx, sb *in, sb *out, int (*get_line) (sb *))
1326 sb sub;
1327 formal_entry f;
1328 struct hash_control *h;
1329 const char *err;
1331 idx = sb_skip_white (idx, in);
1333 sb_new (&sub);
1334 if (! buffer_and_nest (NULL, "ENDR", &sub, get_line))
1335 return _("unexpected end of file in irp or irpc");
1337 sb_new (&f.name);
1338 sb_new (&f.def);
1339 sb_new (&f.actual);
1341 idx = get_token (idx, in, &f.name);
1342 if (f.name.len == 0)
1343 return _("missing model parameter");
1345 h = hash_new ();
1346 err = hash_jam (h, sb_terminate (&f.name), &f);
1347 if (err != NULL)
1348 return err;
1350 f.index = 1;
1351 f.next = NULL;
1352 f.type = FORMAL_OPTIONAL;
1354 sb_reset (out);
1356 idx = sb_skip_comma (idx, in);
1357 if (idx >= in->len)
1359 /* Expand once with a null string. */
1360 err = macro_expand_body (&sub, out, &f, h, 0);
1362 else
1364 if (irpc && in->ptr[idx] == '"')
1365 ++idx;
1366 while (idx < in->len)
1368 if (!irpc)
1369 idx = get_any_string (idx, in, &f.actual);
1370 else
1372 if (in->ptr[idx] == '"')
1374 int nxt;
1376 nxt = sb_skip_white (idx + 1, in);
1377 if (nxt >= in->len)
1379 idx = nxt;
1380 break;
1383 sb_reset (&f.actual);
1384 sb_add_char (&f.actual, in->ptr[idx]);
1385 ++idx;
1387 err = macro_expand_body (&sub, out, &f, h, 0);
1388 if (err != NULL)
1389 break;
1390 if (!irpc)
1391 idx = sb_skip_comma (idx, in);
1392 else
1393 idx = sb_skip_white (idx, in);
1397 hash_die (h);
1398 sb_kill (&f.actual);
1399 sb_kill (&f.def);
1400 sb_kill (&f.name);
1401 sb_kill (&sub);
1403 return err;