File: pexpandmacro.c

package info (click to toggle)
yodl 4.05.02-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,724 kB
  • sloc: ansic: 7,803; perl: 683; cpp: 570; sh: 411; xml: 190; makefile: 163
file content (55 lines) | stat: -rw-r--r-- 1,836 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include "parser.ih"

/*
    We've seen macroname, and know the next token is open-paren.

    Extract a parameterlist for each of the arguments.

    Each of the parameters is then replaced by its definition in the
    definition of the macro.

    Having done this, the full macro text is returned as the expansion

    If we can't find the macro's definition, that's an error
*/

void p_expand_macro(register Parser *pp, register HashItem *item)
{
    Macro *mp               = (Macro *)hashitem_value(item);
    char const *name        = hashitem_key(item);
    size_t argc             = macro_nArgs(mp);
    char const *def         = macro_definition(mp);
    String expansion;

    parser_push_fun(name);

    string_construct(&expansion, 0);

    if (def == PFAILED)
    {
        if (message_show(MSG_ERR))
            message("No stacked definition for macro `%s'", parser_fun());
    }
    else
    {
        if (message_show(MSG_NOTICE))
            message("Expanding macro`%s' to `%s'", parser_fun(),
                                                        string_short(def));
        string_addstr(&expansion, def);

        if (argc)                               /* macro with arguments     */
            p_macro_args(pp, &expansion, argc);
        else                                    /* no arguments:            */
        {                                       /* eat empty parameter list */
            char *argument = parser_parlist(pp, COLLECT_SET);
            if (*argument)
                if (message_show(MSG_WARNING))
                    message("macro `%s' called with non-zero parameter list",
                            parser_fun());
            free(argument);
        }
        lexer_push_str(&pp->d_lexer, string_str(&expansion));
    }
    string_destruct(&expansion);
    parser_pop_fun();
}