Add context-aware error messages to CSS parser #98
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
CSS parser error messages lacked context about where errors occurred and what was expected, making debugging difficult. Errors like "Error in declaration." provided no actionable information.
Changes
Core Implementation
toCSSParseException()to automatically enrich all error messages with contextual informationstyleRule,declaration, andmediaRuleproductions using try-finally blocksError Message Enhancement
Before:
After:
Nested context:
Testing
ContextAwareErrorTestwith 7 tests covering declaration errors, nested rules, property context, and expected tokensAll 646 tests pass. Changes are backward compatible - existing error handling code unchanged.
Original prompt
Add Context-Aware Error Messages to CSS Parser
Problem
The current CSS parser produces generic error messages that lack context, making it difficult for users to understand:
Current generic error messages:
These messages don't provide:
Solution
Implement a comprehensive context-aware error messaging system that provides rich, actionable error information.
1. Create ParserContext Class
2. Enhance AbstractCSSParser
3. Add Token Category Helper
4. Update CSS3Parser.jj Grammar
Add context tracking to major...
This pull request was created from Copilot chat.
💬 We'd love your input! Share your thoughts on Copilot coding agent in our 2 minute survey.