diff --git a/src/asm/lexer.c b/src/asm/lexer.c index 4f23187e7..c066b0c6d 100644 --- a/src/asm/lexer.c +++ b/src/asm/lexer.c @@ -736,7 +736,11 @@ static char const *readMacroArg(char name) static int peekInternal(uint8_t distance) { for (struct Expansion *exp = lexerState->expansions; exp; exp = exp->parent) { - assert(exp->offset < exp->size); + /* + * An expansion that has reached its end will have `exp->offset` == `exp->size`, + * and `peekInternal` will continue with its parent + */ + assert(exp->offset <= exp->size); if (distance < exp->size - exp->offset) return exp->contents.unowned[exp->offset + distance]; distance -= exp->size - exp->offset; @@ -870,16 +874,21 @@ static void shiftChar(void) lexerState->macroArgScanDistance--; +restart: if (lexerState->expansions) { /* Advance within the current expansion */ - assert(lexerState->expansions->offset < lexerState->expansions->size); + assert(lexerState->expansions->offset <= lexerState->expansions->size); lexerState->expansions->offset++; - if (lexerState->expansions->offset == lexerState->expansions->size) { - /* When an expansion is done, free it and move up to its parent */ + if (lexerState->expansions->offset > lexerState->expansions->size) { + /* + * When advancing would go past an expansion's end, free it, + * move up to its parent, and try again to advance + */ struct Expansion *exp = lexerState->expansions; lexerState->expansions = lexerState->expansions->parent; freeExpansion(exp); + goto restart; } } else { /* Advance within the file contents */ diff --git a/test/asm/equs-newline.err b/test/asm/equs-newline.err index 04ceb7beb..3208a80aa 100644 --- a/test/asm/equs-newline.err +++ b/test/asm/equs-newline.err @@ -3,5 +3,6 @@ warning: equs-newline.asm(3): [-Wuser] while expanding symbol "ACT" warning: equs-newline.asm(3): [-Wuser] Second +while expanding symbol "ACT" warning: equs-newline.asm(4): [-Wuser] Third diff --git a/test/asm/equs-recursion.asm b/test/asm/equs-recursion.asm index 3aae90530..9ca7c997c 100644 --- a/test/asm/equs-recursion.asm +++ b/test/asm/equs-recursion.asm @@ -1,6 +1,2 @@ -recurse EQUS "recurse " +recurse EQUS "recurse" recurse - -; FIXME: also handle the following: -; recurse EQUS "recurse" -; recurse diff --git a/test/asm/interpolation-recursion.asm b/test/asm/interpolation-recursion.asm index f522b1e8c..a1e2ba5c4 100644 --- a/test/asm/interpolation-recursion.asm +++ b/test/asm/interpolation-recursion.asm @@ -1,6 +1,2 @@ -recurse EQUS "\{recurse\} " +recurse EQUS "\{recurse\}" {recurse} - -; FIXME: also handle the following: -; recurse EQUS "\{recurse\}" -; {recurse} diff --git a/test/asm/interpolation-recursion.err b/test/asm/interpolation-recursion.err index 3597573d1..50fd075e7 100644 --- a/test/asm/interpolation-recursion.err +++ b/test/asm/interpolation-recursion.err @@ -1,67 +1,67 @@ FATAL: interpolation-recursion.asm(2): Recursion limit (64) exceeded -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " -while expanding symbol "{recurse} " +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" +while expanding symbol "{recurse}" diff --git a/test/asm/rst.asm b/test/asm/rst.asm index 09dafe843..e42683cb3 100644 --- a/test/asm/rst.asm +++ b/test/asm/rst.asm @@ -16,12 +16,8 @@ SECTION "calls", ROM0[0] defRST: MACRO -; FIXME: This is required, otherwise the lexer does not paste the two tokens -ADDR equs "$\1" -SECTION "rst\1", ROM0[ADDR] - -rst\1: - PURGE ADDR + SECTION "rst\1", ROM0[$\1] + rst\1: ENDM defRST 00 defRST 08 diff --git a/test/asm/test.sh b/test/asm/test.sh index 7056cf2b0..90b02add8 100755 --- a/test/asm/test.sh +++ b/test/asm/test.sh @@ -62,6 +62,7 @@ EOF cat > quote\"file.err < unique-id.asm::m(4): [-Wuser] _u1 +while expanding symbol "warn_unique" warning: unique-id.asm(12) -> unique-id.asm::m(5) -> unique-id.asm::m::REPT~1(6): [-Wuser] _u2 +while expanding symbol "warn_unique" warning: unique-id.asm(12) -> unique-id.asm::m(5) -> unique-id.asm::m::REPT~2(6): [-Wuser] _u3 +while expanding symbol "warn_unique" warning: unique-id.asm(12) -> unique-id.asm::m(8): [-Wuser] _u1 +while expanding symbol "warn_unique" warning: unique-id.asm(14) -> unique-id.asm::m(4): [-Wuser] _u4 +while expanding symbol "warn_unique" warning: unique-id.asm(14) -> unique-id.asm::m(5) -> unique-id.asm::m::REPT~1(6): [-Wuser] _u5 +while expanding symbol "warn_unique" warning: unique-id.asm(14) -> unique-id.asm::m(5) -> unique-id.asm::m::REPT~2(6): [-Wuser] _u6 +while expanding symbol "warn_unique" warning: unique-id.asm(14) -> unique-id.asm::m(8): [-Wuser] _u4 +while expanding symbol "warn_unique" FATAL: unique-id.asm(15): Macro argument '\@' not defined while expanding symbol "warn_unique" diff --git a/test/link/rst.asm b/test/link/rst.asm index 14df973d1..76f2afa06 100644 --- a/test/link/rst.asm +++ b/test/link/rst.asm @@ -14,12 +14,8 @@ SECTION "calls", ROM0[0] defRST: MACRO -; FIXME: This is required, otherwise the lexer does not paste the two tokens -ADDR equs "$\1" -SECTION "rst\1", ROM0[ADDR] - -rst\1: - PURGE ADDR + SECTION "rst\1", ROM0[$\1] + rst\1: ENDM defRST 00 defRST 08