Awesome
Boost C++ for iOS and Mac OS X (Intel & Apple Silicon M1) & Catalyst - arm64 / x86_64
Supported versions: 1.80.0, 1.79.0, 1.78.0, 1.77.0, 1.76.0, 1.75.0 (use the appropriate tag or branch to choose a version)
This repo provides a universal script for building static Boost C++ libraries for use in iOS and Mac OS X & Catalyst applications. The latest supported Boost version is taken from: https://boostorg.jfrog.io/artifactory/main/release/1.80.0/source/boost_1_80_0.tar.bz2
Building libraries
atomic, chrono, container, context, contract, coroutine, date_time, exception, fiber, filesystem, graph, iostreams, json, locale, log, math, nowide, program_options, random, regex, serialization, stacktrace, system, test, thread, timer, type_erasure, wave
Not building libraries
graph_parallel, mpi, python
Prerequisites
- Xcode must be installed because xcodebuild is used to create xcframeworks
xcode-select -p
must point to Xcode app developer directory (by default e.g. /Applications/Xcode.app/Contents/Developer). If it points to CommandLineTools directory you should execute:sudo xcode-select --reset
orsudo xcode-select -s /Applications/Xcode.app/Contents/Developer
- You should not have your own user-config.jam file in your home directory!
Building notes
- Libraries 'locale' and 'regex' are being built with ICU backend. ICU build scripts are being taken from https://github.com/apotocki/icu4c-iosx and run with the help of 'pod' utility.
- 'test' library is building for iOS with BOOST_TEST_NO_MAIN flag.
How to build?
- Manually
# clone the repo
git clone https://github.com/apotocki/boost-iosx
# build libraries
cd boost-iosx
scripts/build.sh
# have fun, the result artifacts will be located in 'frameworks' folder.
# Then you can add desirable xcframewors in your XCode project. The process is described, e.g., at https://www.simpleswiftguide.com/how-to-add-xcframework-to-xcode-project/
- Use cocoapods. Add the following lines into your project's Podfile:
use_frameworks!
pod 'boost-iosx'
# or optionally more precisely, e.g.:
# pod 'boost-iosx', :git => 'https://github.com/apotocki/boost-iosx', :tag => '1.80.0.1'
If you want to use particular boost libraries, specify them as in the following example for log and program_options libraries:
pod 'boost-iosx/log'
pod 'boost-iosx/program_options'
# note: Some libraries have dependencies on other Boost libraries. In that case, you should explicitly add all their dependencies to your Podfile.
Then install new dependencies:
pod install --verbose
As an advertisement…
The Boost libraries built by this project are used in my iOS application on the App Store:
This app is designed for inspecting and editing files at the byte or character level.
You can support my open-source development by trying the App.
Feedback is welcome!