Switch to FrankeNDK for building native
This commit is contained in:
parent
190646d50c
commit
0f34f0033c
@ -9,10 +9,10 @@
|
|||||||
5. (Windows Only) Python package Colorama: Install with `pip install colorama`, used for ANSI color codes
|
5. (Windows Only) Python package Colorama: Install with `pip install colorama`, used for ANSI color codes
|
||||||
|
|
||||||
## Building Notes and Instructions
|
## Building Notes and Instructions
|
||||||
1. Building is tested on macOS, Ubuntu, and Windows 10 using the latest stable NDK and NDK r10e. Officially released binaries were built with NDK r10e.
|
1. Building is supported on macOS, Linux, and Windows using the custom NDK: [FrankeNDK](https://github.com/topjohnwu/FrankeNDK).
|
||||||
2. Set configurations in `config.prop`. A sample file `config.prop.sample` is provided as an example.
|
2. Set configurations in `config.prop`. A sample file `config.prop.sample` is provided as an example.
|
||||||
3. Run `build.py` with argument `-h` to see the built-in help message. The `-h` option also works for each supported actions, e.g. `./build.py binary -h`
|
3. Run `build.py` with argument `-h` to see the built-in help message. The `-h` option also works for each supported actions, e.g. `./build.py binary -h`
|
||||||
4. By default, `build.py` build binaries and Magisk Manager in debug mode. If you want to build Magisk Manager in release mode (via the `--release` flag), you need a Java Keystore file `release-key.jks` to sign Magisk Manager's APK. For more information, check out [Google's Official Documentation](https://developer.android.com/studio/publish/app-signing.html#signing-manually).
|
4. By default, `build.py` build binaries and Magisk Manager in debug mode. If you want to build Magisk Manager in release mode (via the `-r, --release` flag), you need a Java Keystore file `release-key.jks` (only `JKS` format is supported) to sign APKs and zips. For more information, check out [Google's Official Documentation](https://developer.android.com/studio/publish/app-signing.html#signing-manually).
|
||||||
|
|
||||||
## Documentation
|
## Documentation
|
||||||
[Link to Documentation](docs/README.MD)
|
[Link to Documentation](docs/README.MD)
|
||||||
|
9
build.py
9
build.py
@ -238,15 +238,8 @@ def build_binary(args):
|
|||||||
error('Build binaries failed!')
|
error('Build binaries failed!')
|
||||||
collect_binary()
|
collect_binary()
|
||||||
|
|
||||||
new_plat = False
|
|
||||||
flags = base_flags
|
|
||||||
|
|
||||||
if 'busybox' in args.target:
|
if 'busybox' in args.target:
|
||||||
flags += ' B_BB=1'
|
proc = system('{} -C native {} B_BB=1 -j{}'.format(ndk_build, base_flags, cpu_count))
|
||||||
new_plat = True
|
|
||||||
|
|
||||||
if new_plat:
|
|
||||||
proc = system('{} -C native NEW_PLAT=1 {} -j{}'.format(ndk_build, flags, cpu_count))
|
|
||||||
if proc.returncode != 0:
|
if proc.returncode != 0:
|
||||||
error('Build binaries failed!')
|
error('Build binaries failed!')
|
||||||
collect_binary()
|
collect_binary()
|
||||||
|
@ -2,10 +2,12 @@ APP_ABI := armeabi-v7a x86
|
|||||||
APP_CFLAGS := -std=gnu99 ${MAGISK_DEBUG} \
|
APP_CFLAGS := -std=gnu99 ${MAGISK_DEBUG} \
|
||||||
-DMAGISK_VERSION="${MAGISK_VERSION}" -DMAGISK_VER_CODE=${MAGISK_VER_CODE}
|
-DMAGISK_VERSION="${MAGISK_VERSION}" -DMAGISK_VER_CODE=${MAGISK_VER_CODE}
|
||||||
APP_CPPFLAGS := -std=c++11
|
APP_CPPFLAGS := -std=c++11
|
||||||
APP_SHORT_COMMANDS := true
|
|
||||||
ifdef NEW_PLAT
|
|
||||||
APP_PLATFORM := android-21
|
|
||||||
else
|
|
||||||
APP_PLATFORM := android-16
|
APP_PLATFORM := android-16
|
||||||
APP_CFLAGS += -Wno-implicit-function-declaration
|
APP_CFLAGS += -Wno-implicit-function-declaration
|
||||||
|
|
||||||
|
# Busybox require some additional settings
|
||||||
|
ifdef B_BB
|
||||||
|
APP_SHORT_COMMANDS := true
|
||||||
|
NDK_TOOLCHAIN_VERSION := 4.9
|
||||||
|
APP_PLATFORM := android-21
|
||||||
endif
|
endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user