Skip to content

Commit

Permalink
switch to old boost, change deps to python3crystax
Browse files Browse the repository at this point in the history
  • Loading branch information
jessopb committed Dec 1, 2022
1 parent 85926fe commit 9567a5e
Showing 1 changed file with 47 additions and 43 deletions.
90 changes: 47 additions & 43 deletions recipes/boost/__init__.py
Original file line number Diff line number Diff line change
@@ -1,100 +1,104 @@
from pythonforandroid.util import current_directory
from pythonforandroid.recipe import Recipe
from pythonforandroid.logger import shprint
from pythonforandroid.toolchain import Recipe, shprint, shutil, current_directory
from os.path import join, exists
from os import environ
import shutil
import sh

"""
This recipe bootstraps Boost from source to build Boost.Build
This recipe creates a custom toolchain and bootstraps Boost from source to build Boost.Build
including python bindings
"""


class BoostRecipe(Recipe):
# Todo: make recipe compatible with all p4a architectures
'''
.. note:: This recipe can be built only against API 21+ and an android
ndk >= r19
.. note:: This recipe can be built only against API 21+ and arch armeabi-v7a
.. versionchanged:: 0.6.0
Rewrote recipe to support clang's build. The following changes has
been made:
- Bumped version number to 1.68.0
- Better version handling for url
- Added python 3 compatibility
- Default compiler for ndk's toolchain set to clang
- Python version will be detected via user-config.jam
- Changed stl's lib from ``gnustl_shared`` to ``c++_shared``
.. versionchanged:: 2019.08.09.1.dev0
- Bumped version number to 1.68.0
- Adapted to work with ndk-r19+
'''
version = '1.69.0'
url = (
'https://downloads.sourceforge.net/project/boost/'
'boost/{version}/boost_{version_underscore}.tar.bz2'
)
version = '1.68.0'
url = 'http://downloads.sourceforge.net/project/boost/' \
'boost/{version}/boost_{version_underscore}.tar.bz2'
depends = [('python2', 'python3crystax')]
patches = [
'disable-so-version.patch',
'use-android-libs.patch',
'fix-android-issues.patch',
]
need_stl_shared = True
patches = ['disable-so-version.patch',
'use-android-libs.patch',
'fix-android-issues.patch']

@property
def versioned_url(self):
if self.url is None:
return None
return self.url.format(
version=self.version,
version_underscore=self.version.replace('.', '_'),
)
version_underscore=self.version.replace('.', '_'))

def should_build(self, arch):
return not exists(join(self.get_build_dir(arch.arch), 'b2'))

def prebuild_arch(self, arch):
super().prebuild_arch(arch)
super(BoostRecipe, self).prebuild_arch(arch)
env = self.get_recipe_env(arch)
with current_directory(self.get_build_dir(arch.arch)):
if not exists(env['CROSSHOME']):
# Make custom toolchain
bash = sh.Command('bash')
shprint(bash, join(self.ctx.ndk_dir, 'build/tools/make-standalone-toolchain.sh'),
'--arch=' + env['ARCH'],
'--platform=android-' + str(self.ctx.android_api),
'--toolchain=' + env['CROSSHOST'] + '-' + self.ctx.toolchain_version + ':-llvm',
'--use-llvm',
'--stl=libc++',
'--install-dir=' + env['CROSSHOME']
)
# Set custom configuration
shutil.copyfile(
join(self.get_recipe_dir(), 'user-config.jam'),
join(env['BOOST_BUILD_PATH'], 'user-config.jam'),
)
shutil.copyfile(join(self.get_recipe_dir(), 'user-config.jam'),
join(env['BOOST_BUILD_PATH'], 'user-config.jam'))

def build_arch(self, arch):
super().build_arch(arch)
super(BoostRecipe, self).build_arch(arch)
env = self.get_recipe_env(arch)
env['PYTHON_HOST'] = self.ctx.hostpython
with current_directory(self.get_build_dir(arch.arch)):
if not exists('b2'):
# Compile Boost.Build engine with this custom toolchain
bash = sh.Command('bash')
shprint(bash, 'bootstrap.sh') # Do not pass env
# Compile Boost.Build engine with this custom toolchain
bash = sh.Command('bash')
shprint(bash, 'bootstrap.sh') # Do not pass env
# Install app stl
shutil.copyfile(
join(self.ctx.ndk_dir, 'sources/cxx-stl/llvm-libc++/libs/'
'armeabi-v7a/libc++_shared.so'),
join(self.ctx.get_libs_dir(arch.arch), 'libc++_shared.so'))

def select_build_arch(self, arch):
return arch.arch.replace('eabi-v7a', '').replace('eabi', '')

def get_recipe_env(self, arch):
# We don't use the normal env because we
# are building with a standalone toolchain
env = environ.copy()

# find user-config.jam
env['BOOST_BUILD_PATH'] = self.get_build_dir(arch.arch)
# find boost source
env['BOOST_ROOT'] = env['BOOST_BUILD_PATH']
env['BOOST_BUILD_PATH'] = self.get_build_dir(arch.arch) # find user-config.jam
env['BOOST_ROOT'] = env['BOOST_BUILD_PATH'] # find boost source

env['PYTHON_ROOT'] = self.ctx.python_recipe.link_root(arch.arch)
env['PYTHON_INCLUDE'] = self.ctx.python_recipe.include_root(arch.arch)
env['PYTHON_MAJOR_MINOR'] = self.ctx.python_recipe.version[:3]
env['PYTHON_LINK_VERSION'] = self.ctx.python_recipe.major_minor_version_string # modified from .link_version
env['PYTHON_LINK_VERSION'] = self.ctx.python_recipe.major_minor_version_string
if 'python3' in self.ctx.python_recipe.name:
env['PYTHON_LINK_VERSION'] += 'm'

env['ARCH'] = arch.arch.replace('-', '')
env['TARGET_TRIPLET'] = arch.target
env['CROSSHOST'] = arch.command_prefix
env['CROSSHOME'] = self.ctx.ndk.llvm_prebuilt_dir
env['ARCH'] = self.select_build_arch(arch)
env['CROSSHOST'] = env['ARCH'] + '-linux-androideabi'
env['CROSSHOME'] = join(env['BOOST_ROOT'], 'standalone-' + env['ARCH'] + '-toolchain')
return env


recipe = BoostRecipe()
recipe = BoostRecipe()

0 comments on commit 9567a5e

Please sign in to comment.