ios: add iOS recipe
This commit is contained in:
parent
01c243217e
commit
6ec26f957b
6 changed files with 71 additions and 0 deletions
71
recipes/ios/__init__.py
Normal file
71
recipes/ios/__init__.py
Normal file
|
@ -0,0 +1,71 @@
|
|||
from toolchain import Recipe, shprint
|
||||
from os.path import join, exists
|
||||
import sh
|
||||
import os
|
||||
import fnmatch
|
||||
import shutil
|
||||
|
||||
|
||||
class IosRecipe(Recipe):
|
||||
version = "master"
|
||||
url = "src"
|
||||
library = "libios.a"
|
||||
depends = ["python"]
|
||||
|
||||
def cythonize(self, filename):
|
||||
if filename.startswith(self.build_dir):
|
||||
filename = filename[len(self.build_dir) + 1:]
|
||||
print("Cythonize {}".format(filename))
|
||||
cmd = sh.Command(join(self.ctx.root_dir, "tools", "cythonize.py"))
|
||||
shprint(cmd, filename)
|
||||
|
||||
def cythonize_build(self):
|
||||
root_dir = self.build_dir
|
||||
for root, dirnames, filenames in os.walk(root_dir):
|
||||
for filename in fnmatch.filter(filenames, "*.pyx"):
|
||||
self.cythonize(join(root, filename))
|
||||
|
||||
def get_kivy_env(self, arch):
|
||||
build_env = arch.get_env()
|
||||
build_env["KIVYIOSROOT"] = self.ctx.root_dir
|
||||
build_env["IOSSDKROOT"] = arch.sysroot
|
||||
build_env["LDSHARED"] = join(self.ctx.root_dir, "tools", "liblink")
|
||||
build_env["ARM_LD"] = build_env["LD"]
|
||||
build_env["ARCH"] = arch.arch
|
||||
return build_env
|
||||
|
||||
def build_arch(self, arch):
|
||||
build_env = self.get_kivy_env(arch)
|
||||
hostpython = sh.Command(self.ctx.hostpython)
|
||||
self.cythonize_build()
|
||||
shprint(hostpython, "setup.py", "build_ext", "-g",
|
||||
_env=build_env)
|
||||
self.biglink()
|
||||
|
||||
def biglink(self):
|
||||
dirs = []
|
||||
for root, dirnames, filenames in os.walk(self.build_dir):
|
||||
if fnmatch.filter(filenames, "*.so.libs"):
|
||||
dirs.append(root)
|
||||
cmd = sh.Command(join(self.ctx.root_dir, "tools", "biglink"))
|
||||
shprint(cmd, join(self.build_dir, "libios.a"), *dirs)
|
||||
|
||||
def install(self):
|
||||
arch = list(self.filtered_archs)[0]
|
||||
build_dir = self.get_build_dir(arch.arch)
|
||||
os.chdir(build_dir)
|
||||
hostpython = sh.Command(self.ctx.hostpython)
|
||||
build_env = self.get_kivy_env(arch)
|
||||
shprint(hostpython, "setup.py", "install", "-O2",
|
||||
"--prefix", join(build_dir, "iosbuild"),
|
||||
_env=build_env)
|
||||
dest_dir = join(self.ctx.dist_dir, "root", "python", "lib", "python2.7",
|
||||
"site-packages", "ios.so")
|
||||
shutil.copy(
|
||||
join(build_dir, "iosbuild", "lib",
|
||||
"python2.7", "site-packages", "ios.so"),
|
||||
dest_dir)
|
||||
|
||||
recipe = IosRecipe()
|
||||
|
||||
|
Loading…
Reference in a new issue