New Pycrypto recipe
This commit is contained in:
parent
9826a7cba0
commit
70d2b43e2a
2 changed files with 67 additions and 0 deletions
56
recipes/pycrypto/__init__.py
Normal file
56
recipes/pycrypto/__init__.py
Normal file
|
@ -0,0 +1,56 @@
|
|||
'''Recipe for pycrypto on ios
|
||||
'''
|
||||
from toolchain import CythonRecipe, shprint
|
||||
from os.path import join, exists
|
||||
import sh
|
||||
import os
|
||||
|
||||
|
||||
class PycryptoRecipe(CythonRecipe):
|
||||
version = "2.6.1"
|
||||
url = "https://ftp.dlitz.net/pub/dlitz/crypto/pycrypto/pycrypto-{version}.tar.gz"
|
||||
#url = 'src'
|
||||
depends = ["python", "openssl"]
|
||||
#cythonize = False
|
||||
include_per_arch = True
|
||||
library="libpycrypto.a"
|
||||
#pre_build_ext = True
|
||||
|
||||
|
||||
def build_arch(self, arch):
|
||||
build_env = arch.get_env()
|
||||
self.apply_patch('hash_SHA2_template.c.patch', target_dir=self.build_dir + '/src')
|
||||
configure = sh.Command(join(self.build_dir, "configure"))
|
||||
shprint(configure,
|
||||
"CC={}".format(build_env["CC"]),
|
||||
"LD={}".format(build_env["LD"]),
|
||||
"CFLAGS={}".format(build_env["CFLAGS"]),
|
||||
"LDFLAGS={} -Wno-error ".format(build_env["LDFLAGS"]),
|
||||
"--prefix=/",
|
||||
"--host={}".format(arch),
|
||||
"ac_cv_func_malloc_0_nonnull=yes",
|
||||
"ac_cv_func_realloc_0_nonnull=yes",
|
||||
#"enable-static=yes",
|
||||
#"enable-shared=no"
|
||||
)
|
||||
hostpython = sh.Command(self.ctx.hostpython)
|
||||
#shprint(hostpython, "setup.py", "build_ext", "--inplace", "-v",
|
||||
# _env=build_env)
|
||||
super(PycryptoRecipe, self).build_arch(arch)
|
||||
|
||||
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 = arch.get_env()
|
||||
dest_dir = join(self.ctx.dist_dir, "root", "python")
|
||||
build_env['PYTHONPATH'] = join(dest_dir, 'lib', 'python2.7', 'site-packages')
|
||||
shprint(hostpython, "-m", "easy_install",
|
||||
"--prefix", dest_dir, "-Z", "./",
|
||||
_env=build_env)
|
||||
#print('installing to {}').format(dest_dir)
|
||||
#shprint(hostpython, "setup.py", "install", "--home={}".format(dest_dir + '/lib/python2.7'), _env=build_env)
|
||||
#shprint(hostpython, "-m", "pip", "install", "--root", dest_dir, "./")
|
||||
|
||||
recipe = PycryptoRecipe()
|
11
recipes/pycrypto/hash_SHA2_template.c.patch
Normal file
11
recipes/pycrypto/hash_SHA2_template.c.patch
Normal file
|
@ -0,0 +1,11 @@
|
|||
--- ../src/src/hash_SHA2_template.c 2015-07-15 15:25:59.000000000 +0530
|
||||
+++ src/hash_SHA2_template.c 2015-07-17 15:35:13.000000000 +0530
|
||||
@@ -87,7 +87,7 @@
|
||||
* return 1 on success
|
||||
* return 0 if the length overflows
|
||||
*/
|
||||
-static int add_length(hash_state *hs, sha2_word_t inc) {
|
||||
+int add_length(hash_state *hs, sha2_word_t inc) {
|
||||
sha2_word_t overflow_detector;
|
||||
overflow_detector = hs->length_lower;
|
||||
hs->length_lower += inc;
|
Loading…
Add table
Reference in a new issue