Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/emergetools/smallstrings
Minification of localized strings
https://github.com/emergetools/smallstrings
Last synced: about 2 months ago
JSON representation
Minification of localized strings
- Host: GitHub
- URL: https://github.com/emergetools/smallstrings
- Owner: EmergeTools
- License: mit
- Created: 2021-10-21T19:24:30.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2023-11-13T16:03:38.000Z (about 1 year ago)
- Last Synced: 2024-04-23T19:18:11.864Z (8 months ago)
- Language: Objective-C
- Size: 19.5 KB
- Stars: 92
- Watchers: 1
- Forks: 5
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![Emerge Tools rounded](https://user-images.githubusercontent.com/6634452/205205728-19b3376a-e99a-4a74-916b-0519deeff08b.png)
# SmallStrings | Reduce localized .strings file sizes by 80%
#### Maintained by [Emerge Tools](https://emergetools.com?utm_source=smallstrings)### How does it work
- Convert .strings files (of the form App.app/\*.lproj/Localizable.strings only) into a minified form
- Eliminate key duplication ([read more about the strategy](https://eisel.me/localization)), this typically reduces the size by about 50%
- Keep small files in a compressed form on disk, using LZFSE, to reduce the size further
- Replace the original language.lproj/Localizable.strings with placeholders that have one key-value pair each. This shows Apple that the same languages are still supported, so that it can pick the correct one based on the user's settings.
- Use the iOS library that replaces `NSLocalizedString` with a new version, `SSTStringForKey` that fetches values for keys from this minified format.### Usage
#### Cocoapods
Add this to your Podfile:
```
pod 'SmallStrings'
```Then add a Run Script build phase after the "Copy bundle resources" phase:
```
cd ${PODS_ROOT}/SmallStrings && ./localize.sh ${CODESIGNING_FOLDER_PATH} ${DERIVED_FILES_DIR}/SmallStrings.cache
```Lastly, replace all usages of `NSLocalizedString(key, comment)` with `SSTStringForKey(key)`.
#### Manual
- Add `Source/SSTSmallStrings.{h,m}` to your project.
- Create a `compress` binary via `clang -O3 compress.m -framework Foundation -lcompression -o compress` and put the executable in the same directory as `localize.{rb,sh}`.
- Add a build step with `cd /path/to/SmallStrings && ./localize.sh ${CODESIGNING_FOLDER_PATH} ${DERIVED_FILES_DIR}/SmallStrings.cache`.
- Lastly, replace all usages of `NSLocalizedString(key, comment)` with `SSTStringForKey(key)`.