mirror of
https://github.com/netwide-assembler/nasm.git
synced 2024-12-03 08:41:02 +08:00
BR3392200: preproc - Fix dangling paste term
In case if there a production {tok},{%+},{whitespace}* the preprocessor does not delete ending paste+spaces tokens. Fix it. http://bugzilla.nasm.us/show_bug.cgi?id=3392200 Reported-by: KO Myung-Hun <komh@chollian.net> Signed-off-by: Cyrill Gorcunov <gorcunov@gmail.com>
This commit is contained in:
parent
bd8cef73d1
commit
99a055add9
12
preproc.c
12
preproc.c
@ -4026,6 +4026,9 @@ static bool paste_tokens(Token **head, const struct tokseq_match *m,
|
||||
char *tmp;
|
||||
int i;
|
||||
|
||||
nasm_dump_stream(*head);
|
||||
nasm_dump_token(*head);
|
||||
|
||||
/* Now handle token pasting... */
|
||||
paste_head = NULL;
|
||||
tail = head;
|
||||
@ -4046,8 +4049,13 @@ static bool paste_tokens(Token **head, const struct tokseq_match *m,
|
||||
while (t && (t->type == TOK_WHITESPACE ||
|
||||
t->type == TOK_PASTE))
|
||||
t = *tail = delete_Token(t);
|
||||
if (!paste_head || !t)
|
||||
break; /* Nothing to paste with */
|
||||
if (!t) { /* Dangling %+ term */
|
||||
if (paste_head)
|
||||
(*paste_head)->next = NULL;
|
||||
else
|
||||
*head = NULL;
|
||||
return did_paste;
|
||||
}
|
||||
tail = paste_head;
|
||||
t = *tail;
|
||||
tt = t->next;
|
||||
|
Loading…
Reference in New Issue
Block a user