Convert SEVERITY constants to type-safe enum #101
Closed
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.
Overview
This PR modernizes the severity level API by converting the integer constants
SEVERITY_WARNINGandSEVERITY_ERRORto a type-safe enum, addressing issue #XX.Problem
The current implementation uses primitive integer constants for severity levels:
This approach has several drawbacks:
999,-1,42)1and2are less clear than named constantsSolution
Introduced a new
Severityenum withWARNINGandERRORvalues:Added a new type-safe method signature:
Benefits
Severity.WARNINGis clearer than1Backward Compatibility
All existing code continues to work without modification:
SEVERITY_WARNINGandSEVERITY_ERRORconstants remain available (deprecated)addMessage(int severity)method still works (deprecated)getValue()andfromValue()Migration Path
Old code (still works):
New code (recommended):
Changes
src/main/java/org/codehaus/plexus/build/Severity.java- Type-safe enumBuildContext.java- Added enum-based method, deprecated int-based APIDefaultBuildContext.java- Implements both enum and deprecated int-based methodsFixes #XX
Original prompt
Fixes #40
✨ Let Copilot coding agent set things up for you — coding agent works faster and does higher quality work when set up for your repo.