feat: add upward config discovery and enhanced error messages #1235
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.
Problem
Users must run CLI commands from the exact directory containing
i18n.json, which creates a poor user experience:lingo.dev runfrom a subdirectory fails with a generic errorsrc/,components/, etc.) is brokenBefore:
Solution
Commands now automatically search parent directories for
i18n.json(similar to how Git finds.git) and provide helpful guidance when the config isn't found.After:
Key Improvements
i18n.jsonor reach the filesystem rootrun,status,i18n) behave identicallyTesting Instructions
Test 1: Run from subdirectory
Test 2: Helpful error messages
Test 3: Monorepo scenario
Test 4: All commands work consistently
Behavior Notes
What's Changed
utils/config.tsgetConfigOrThrow()for consistent error handling