These scripts are meant to extract and upload to gs://sentryio-system-symbols-0
Apple system symbols for iOS
, tvOS
and macOS
. Simulators are also supported - see macos-13, macos-14, macos-15. The repositories of IPSW archives we use might not be completely up-to-date, and so there could still be missing symbols in the future. At the moment, we have to upload symbols for AppleTV 4K (2nd gen), intel based Macs, and watchOS manually. We keep track of the manual uploads in Notion.
A GitHub action will run every 4 hours to check for new versions of supported OSes.
Each script checks on the bucket if the bundle already exists before extracting and uploading symbols. See the bundles
directory inside each OS directory on the bucket.
This project is instrumented with Sentry and errors are sent to the sentry
organization, project apple-system-symbols-upload
(https://sentry.io/organizations/sentry/issues/?project=6418660&query=is%3Aunresolved).
Install gsutil
and configure access to the bucket.
brew install --cask google-cloud-sdk
echo "/usr/local/Caskroom/google-cloud-sdk/latest/google-cloud-sdk/bin" >> $GITHUB_PATH
You need access to gs://sentryio-system-symbols-0
. The key is in the OSS vault in 1Password.
gcloud auth activate-service-account --key-file="$key_path"
Install some binary dependencies to unzip the IPSW archives and extract the symbols.
brew install p7zip keith/formulae/dyld-shared-cache-extractor
You will need symsorter
to extract the symcache and organize it for the bucket.
git clone https://github.com/getsentry/symbolicator.git
pushd symbolicator/crates/symsorter
cargo build --release
popd
cp ./symbolicator/target/release/symsorter .
You also need to install Xcode
and configure it properly.
sudo xcode-select -s /Applications/Xcode.app/Contents/Developer
Finally, you'll need Python >=3.8 and some packages to run the scripts.
python3 -m pip install --user -r requirements.txt
You need to specify which os you want to extract the symbols for and it will target the latest version.
python3 import_system_symbols_from_ipsw.py --os-name tvos
You can also specify a specific version of the OS.
python3 import_system_symbols_from_ipsw.py --os-name tvos --os-version 15.3
The script to extract from simulators doesn't take any argument.
python3 import_system_symbols_from_simulators.py