Commit Graph

60 Commits

Author SHA1 Message Date
a33f6cd191 fix(parser): clear pendingIdentifiers after FunctionCall to prevent test state leakage
The scope tracker uses module-level state (pendingIdentifiers) that was not being
cleared after FunctionCall reductions, causing identifier state to leak between
tests. This caused the test 'readme.txt is Word when used in function' to break
the following test by leaving 'echo' in pendingIdentifiers.

- Add FunctionCall to the list of terms that clear pendingIdentifiers
- Un-skip the previously failing test 'readme.txt is Word when used in function'

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-17 10:44:14 -07:00
8a29090364 fix(parser): make DotGet whitespace-sensitive
- Add IdentifierBeforeDot token emitted when identifier immediately precedes '.'
- Move DotGet into @skip {} block using IdentifierBeforeDot
- Prevents 'basename . prop' from parsing as DotGet
- Allows 'basename.prop' to work as expected when identifier is in scope
- Fixes test: 'a word can be contained in parens'

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-17 10:40:28 -07:00
d894713744 feat(parser): complete DotGet implementation with scope tracking
- Fixed tokenizer input.read() to use absolute positions
- Fixed FN_KEYWORD term ID (33 after DotGet added to expression)
- Added DotGet to expression for use as function argument
- All 8 DotGet tests passing

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-17 07:42:07 -07:00
3cd1936de4 wip 2025-10-16 16:13:16 -07:00
e8a1befdcc regex and null 2025-10-16 13:51:50 -07:00
80e489f55d regexs work! 2025-10-16 09:35:31 -07:00
de36b0a711 Cool dude! 2025-10-15 16:47:42 -07:00
d9bc5a64a4 wip 2025-10-15 16:18:18 -07:00
fe7abb8b21 wip 2025-10-15 08:45:37 -07:00
57711c4e89 wip 2025-10-14 16:45:45 -07:00