xc-strings is a command-line tool designed to help Swift developers manage and optimize their localization files.
It provides functionalities to find unused localization keys, clean them from .strings files, and optionally sort the keys in these files for better organization.
- Find Unused Keys: Scans Swift files to detect any localization keys that are no longer used.
- Find Duplicate Keys: Scans .stringsfiles to detect any duplicate keys within the same file.
- Sort .stringsFiles: Sorts keys in.stringsfiles to maintain a consistent order.
- Go 1.15 or later
Clone the repository and build the executable:
git clone git@github.com:phillippbertram/go-xc-strings.git
cd go-xc-strings
# run directly
go run main.go help
# build and run the executable (macOS)
make build
./dist/go-xc-strings_darwin_arm64/xcs help- Install Go
- Optional: Install golangci-lint: brew install golangci-lint
- Optional: Install goreleaser: brew install goreleaser
# get help and list all available commands
xcs help
# list unused localization keys
# -b: path to the base localization file
# args: path to the directory containing the Swift files
# --strings: path to the directory containing the .strings files
# -i: optional glob pattern to exclude files (useful to ignore R.string generated files)
xcs unused -b path/to/Localizable.strings -d path/to/swift/files -i "*.generated.swift" App/Resources --remove
# sort strings files
xcs sort App/Resources
# find and remove specific keys from all strings files that are not used in the Swift files
xcs keys "this_is_a_key" "another_key" App/Resources --remove
# find missing translations
xcs missing App/Resources -b App/Resources/en.lproj/Localizable.strings
# open github repository or release page
xcs gh [--releases]No additional configuration is needed to run xc-strings.
- Make sure you are on the mainbranch
- Make sure the version in version.gois correctly set during goreleaser build
- Create a tag: git tag -a v0.1.0 -m "Release v0.1.0"and push it:git push origin v0.1.0
- Run make release/localto create a new release
- Publish Draft Release
Contributions are welcome! Please fork the repository and submit pull requests with any enhancements or bug fixes.
This project is licensed under the MIT License - see the LICENSE file for details.
For support, you can open an issue in the GitHub issue tracker.
- Phillipp Bertram - Initial work - phillippbertram