mirror of
https://github.com/netwide-assembler/nasm.git
synced 2025-01-06 16:04:43 +08:00
preproc: fix list iteration in the case of expand_indirect()
Linked lists where an element may be deleted or substituted during processing can be subtle to deal with. Fix the iteration conditions in this particular case. Signed-off-by: H. Peter Anvin <hpa@zytor.com>
This commit is contained in:
parent
992fe7591d
commit
c0ab1cd15a
21
preproc.c
21
preproc.c
@ -3901,7 +3901,8 @@ static Token *expand_id(Token * tline)
|
||||
}
|
||||
|
||||
/*
|
||||
* Expand indirect tokens, %[...].
|
||||
* Expand indirect tokens, %[...]. Just like expand_smacro(),
|
||||
* the input is considered destroyed.
|
||||
*/
|
||||
static Token *expand_indirect(Token * tline, int level)
|
||||
{
|
||||
@ -3914,9 +3915,12 @@ static Token *expand_indirect(Token * tline, int level)
|
||||
error(ERR_NONFATAL, "interminable indirect expansion");
|
||||
} else {
|
||||
thead = NULL;
|
||||
for (tp = &tline; (t = *tp); thead = t, tp = &t->next) {
|
||||
if (t->type != TOK_INDIRECT)
|
||||
continue;
|
||||
tp = &tline;
|
||||
while ((t = *tp)) {
|
||||
if (t->type != TOK_INDIRECT) {
|
||||
thead = t;
|
||||
tp = &t->next;
|
||||
} else {
|
||||
it = tokenize(t->text);
|
||||
it = expand_indirect(it, level+1);
|
||||
it = expand_smacro(it);
|
||||
@ -3926,20 +3930,18 @@ static Token *expand_indirect(Token * tline, int level)
|
||||
case TOK_WHITESPACE:
|
||||
skip = (it->type == TOK_WHITESPACE);
|
||||
break;
|
||||
|
||||
case TOK_ID:
|
||||
case TOK_NUMBER:
|
||||
if (it->type == thead->type || it->type == TOK_NUMBER) {
|
||||
char *tmp = nasm_strcat(thead->text, it->text);
|
||||
nasm_free(thead->text);
|
||||
thead->text = tmp;
|
||||
skip = true;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
if (skip) {
|
||||
it = delete_Token(it);
|
||||
} else {
|
||||
@ -3948,8 +3950,9 @@ static Token *expand_indirect(Token * tline, int level)
|
||||
it = it->next;
|
||||
}
|
||||
}
|
||||
*tp = t->next;
|
||||
delete_Token(t);
|
||||
*tp = thead = t->next;
|
||||
t = delete_Token(t);
|
||||
}
|
||||
}
|
||||
}
|
||||
return tline;
|
||||
|
Loading…
Reference in New Issue
Block a user