Linux build multiarch (#2)
* Add bash abiproxy builder * Adjust python part remove unneeded python dependencies do not rely on current working directory * Add bash apk builder and signer * Restore multiarch support
This commit is contained in:
parent
3990ee0d85
commit
deebb890df
|
@ -419,6 +419,10 @@ FodyWeavers.xsd
|
||||||
.vscode/
|
.vscode/
|
||||||
|
|
||||||
abiproxy/build/
|
abiproxy/build/
|
||||||
|
abiproxy/.ninja_deps
|
||||||
|
abiproxy/.ninja_log
|
||||||
|
abiproxy/build.ninja
|
||||||
lib/cocos_old/
|
lib/cocos_old/
|
||||||
lib/Dobby_old/
|
lib/Dobby_old/
|
||||||
sign.bat
|
sign.bat
|
||||||
|
sign.sh
|
||||||
|
|
|
@ -0,0 +1,69 @@
|
||||||
|
#!/bin/bash
|
||||||
|
BASEDIR="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
# env-based
|
||||||
|
CMAKE="${MT_CMAKE:-cmake}" # /usr/bin/cmake
|
||||||
|
NINJA="${MT_NINJA:-ninja}" # /usr/bin/ninja
|
||||||
|
|
||||||
|
# arg-based
|
||||||
|
NDK="${1:-${BASEDIR}/../ndk/android-ndk-r16b}"
|
||||||
|
TARCHS="${2:-"armeabi-v7a arm64-v8a"}"
|
||||||
|
|
||||||
|
_start() {
|
||||||
|
[ -d "${NDK}" ] || _errorexit 6 "NDK directory does not exist! Tried path: ${NDK}"
|
||||||
|
NDK=$(realpath "${NDK}")
|
||||||
|
echo "Found ndk directory ${NDK}"
|
||||||
|
|
||||||
|
[ -f "${NDK}/build/cmake/android.toolchain.cmake" ] || _errorexit 7 "NDK is missing! Unpack it into ${NDK}"
|
||||||
|
|
||||||
|
mkdir -p "${BASEDIR}/build"
|
||||||
|
_build
|
||||||
|
}
|
||||||
|
|
||||||
|
_build() {
|
||||||
|
echo "Building libraries."
|
||||||
|
|
||||||
|
for tarch in ${TARCHS}
|
||||||
|
do
|
||||||
|
rm -rf "${BASEDIR}/build/${tarch}"
|
||||||
|
mkdir -p "${BASEDIR}/build/${tarch}"
|
||||||
|
|
||||||
|
echo "Running cmake ${tarch}..."
|
||||||
|
cd "${BASEDIR}"
|
||||||
|
${CMAKE} -G Ninja \
|
||||||
|
-DANDROID_ABI="${tarch}" \
|
||||||
|
-DCMAKE_BUILD_TYPE:STRING="Release" \
|
||||||
|
-DCMAKE_INSTALL_PREFIX:PATH="${BASEDIR}/build/${tarch}" \
|
||||||
|
-DCMAKE_TOOLCHAIN_FILE:FILEPATH="${NDK}/build/cmake/android.toolchain.cmake" \
|
||||||
|
-DCMAKE_MAKE_PROGRAM:FILEPATH="${NINJA}" \
|
||||||
|
-DANDROID_PLATFORM="android-19" \
|
||||||
|
-DCMAKE_SYSTEM_NAME="Android" \
|
||||||
|
-DCMAKE_ANDROID_ARCH_ABI="${tarch}" \
|
||||||
|
-DCMAKE_ANDROID_NDK="${NDK}" \
|
||||||
|
-DCMAKE_SYSTEM_VERSION="16" \
|
||||||
|
-DCMAKE_ANDROID_NDK_TOOLCHAIN_VERSION="clang" \
|
||||||
|
-DCMAKE_ANDROID_STL_TYPE="gnustl_static" \
|
||||||
|
"${BASEDIR}/"
|
||||||
|
[ "$?" -ne "0" ] && _errorexit 1 "cmake failed for ${tarch}"
|
||||||
|
${NINJA}
|
||||||
|
[ "$?" -ne "0" ] && _errorexit 2 "ninja failed for ${tarch}"
|
||||||
|
|
||||||
|
[ -f "${BASEDIR}/libabiproxy.so" ] || _errorexit 3 "libabiproxy was not cmade for ${tarch}!"
|
||||||
|
mv "${BASEDIR}/libabiproxy.so" "${BASEDIR}/build/${tarch}/libabiproxy.so"
|
||||||
|
done
|
||||||
|
|
||||||
|
_exit
|
||||||
|
}
|
||||||
|
|
||||||
|
_errorexit() {
|
||||||
|
[ ! -z "$2" ] && echo "$2"
|
||||||
|
echo "An error has occurred, exiting."
|
||||||
|
exit ${1}
|
||||||
|
}
|
||||||
|
|
||||||
|
_exit() {
|
||||||
|
echo "Successful."
|
||||||
|
exit 0
|
||||||
|
}
|
||||||
|
|
||||||
|
_start
|
|
@ -0,0 +1,152 @@
|
||||||
|
#!/bin/bash
|
||||||
|
BASEDIR="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
# env-based
|
||||||
|
BASH="${BASH:-bash}" # /bin/bash
|
||||||
|
CMAKE="${MT_CMAKE:-cmake}" # /usr/bin/cmake
|
||||||
|
NINJA="${MT_NINJA:-ninja}" # /usr/bin/ninja
|
||||||
|
CURL="${MT_CURL:-curl}" # /usr/bin/curl
|
||||||
|
JAVA="${MT_JAVA:-java}" # /usr/bin/java
|
||||||
|
PYTHON="${MT_PYTHON:-python3}" # /usr/bin/python3.8
|
||||||
|
JARSIGNER="${MT_JARSIGNER:-jarsigner}" # /usr/bin/jarsigner
|
||||||
|
APKTOOL="${MT_APKTOOL:-apktool_2.5.0.jar}"
|
||||||
|
|
||||||
|
# arg-based
|
||||||
|
SRCAPK="${1:-${BASEDIR}/apk/vanilla.apk}"
|
||||||
|
VERSION="${2:-v0.50}"
|
||||||
|
NDK="${3:-${BASEDIR}/ndk/android-ndk-r21e}"
|
||||||
|
FORCEOW="${4:-true}"
|
||||||
|
TARCHS="${5:-"armeabi-v7a arm64-v8a"}"
|
||||||
|
|
||||||
|
RESULT="${BASEDIR}/build/io.kamihama.magiatranslate.${VERSION}.apk"
|
||||||
|
|
||||||
|
_pre() {
|
||||||
|
[ -f "${SRCAPK}" ] || _errorexit 5 "Did not find MagiReco APK! Tried path: ${SRCAPK}"
|
||||||
|
echo "Found apk ${SRCAPK}"
|
||||||
|
|
||||||
|
[ -d "${NDK}" ] || _errorexit 6 "NDK directory does not exist! Tried path: ${NDK}"
|
||||||
|
NDK=$(realpath "${NDK}")
|
||||||
|
echo "Found ndk directory ${NDK}"
|
||||||
|
|
||||||
|
[ -f "${NDK}/build/cmake/android.toolchain.cmake" ] || _errorexit 7 "NDK is missing! Unpack it into ${NDK}"
|
||||||
|
|
||||||
|
for executie in ${BASH} ${CMAKE} ${NINJA} ${CURL} ${JAVA} ${PYTHON}
|
||||||
|
do
|
||||||
|
[ -x "$(command -v "${executie}")" ] || echo "Warning: ${executie} is missing, please install or provide path via environment"
|
||||||
|
done
|
||||||
|
|
||||||
|
_start
|
||||||
|
}
|
||||||
|
|
||||||
|
_start() {
|
||||||
|
mkdir -p "${BASEDIR}/build"
|
||||||
|
|
||||||
|
[ ! -f "${BASEDIR}/build/${APKTOOL}" ] && _get_apktool
|
||||||
|
|
||||||
|
[[ ! -d "${BASEDIR}/build/app/" || "${FORCEOW}" = true ]] && _create
|
||||||
|
|
||||||
|
_build
|
||||||
|
}
|
||||||
|
|
||||||
|
_get_apktool() {
|
||||||
|
echo "Downloading apktool..."
|
||||||
|
${CURL} -A "Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64)" -o "${BASEDIR}/build/${APKTOOL}" -L "https://bitbucket.org/iBotPeaches/apktool/downloads/${APKTOOL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
_create() {
|
||||||
|
echo "Removing existing build files..."
|
||||||
|
rm -rf "${BASEDIR}/build/app"
|
||||||
|
echo "Running apktool..."
|
||||||
|
${JAVA} -jar "${BASEDIR}/build/${APKTOOL}" d "${SRCAPK}" -o "${BASEDIR}/build/app/"
|
||||||
|
mkdir -p "${BASEDIR}/build/app/smali/com/loadLib"
|
||||||
|
for tarch in ${TARCHS}
|
||||||
|
do
|
||||||
|
mkdir -p "${BASEDIR}/build/app/lib/${tarch}"
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "Applying smali patches..."
|
||||||
|
git -C "${BASEDIR}" apply --stat "${BASEDIR}/patches/NativeBridge.patch"
|
||||||
|
git -C "${BASEDIR}" apply --stat "${BASEDIR}/patches/Hook.patch"
|
||||||
|
git -C "${BASEDIR}" apply "${BASEDIR}/patches/NativeBridge.patch"
|
||||||
|
git -C "${BASEDIR}" apply "${BASEDIR}/patches/Hook.patch"
|
||||||
|
echo "Applying misc patches..."
|
||||||
|
# cp "${BASEDIR}/patches/images/story_ui_sprites00_patch.plist" "${BASEDIR}/build/app/assets/package/story/story_ui_sprites00.plist"
|
||||||
|
# cp "${BASEDIR}/patches/images/story_ui_sprites00_patch.png" "${BASEDIR}/build/app/assets/package/story/story_ui_sprites00.png"
|
||||||
|
|
||||||
|
cp "${BASEDIR}/patches/koruri-semibold.ttf" "${BASEDIR}/build/app/assets/fonts/koruri-semibold.ttf"
|
||||||
|
|
||||||
|
echo "Updating sprites and AndroidManifest.xml..."
|
||||||
|
${PYTHON} "${BASEDIR}/buildassets.py"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
_build() {
|
||||||
|
echo "Copying new smali files..."
|
||||||
|
cp "${BASEDIR}"/smali/loader/*.smali "${BASEDIR}/build/app/smali/com/loadLib/"
|
||||||
|
mkdir -p "${BASEDIR}/build/app/smali_classes2/io/kamihama/magianative"
|
||||||
|
echo "Copying magianative..."
|
||||||
|
cp "${BASEDIR}"/smali/MagiaNative/app/src/main/java/io/kamihama/magianative/*.smali "${BASEDIR}/build/app/smali_classes2/io/kamihama/magianative/"
|
||||||
|
echo "Copying libraries..."
|
||||||
|
cp -r "${BASEDIR}/smali/okhttp-smali/okhttp3/" "${BASEDIR}/build/app/smali_classes2/okhttp3/"
|
||||||
|
cp -r "${BASEDIR}/smali/okhttp-smali/okio/" "${BASEDIR}/build/app/smali_classes2/okio/"
|
||||||
|
echo "Copying unknown..."
|
||||||
|
cp -r "${BASEDIR}/patches/unknown/" "${BASEDIR}/build/app/unknown/"
|
||||||
|
cp "${BASEDIR}/patches/strings.xml" "${BASEDIR}/build/app/res/values/strings.xml"
|
||||||
|
|
||||||
|
echo "Building libraries."
|
||||||
|
|
||||||
|
for tarch in ${TARCHS}
|
||||||
|
do
|
||||||
|
rm -rf "${BASEDIR}/build/${tarch}"
|
||||||
|
mkdir -p "${BASEDIR}/build/${tarch}"
|
||||||
|
|
||||||
|
echo "Running cmake ${tarch}..."
|
||||||
|
cd "${BASEDIR}/build/${tarch}"
|
||||||
|
${CMAKE} -G Ninja \
|
||||||
|
-DANDROID_ABI="${tarch}" \
|
||||||
|
-DCMAKE_BUILD_TYPE:STRING="Release" \
|
||||||
|
-DCMAKE_INSTALL_PREFIX:PATH="${BASEDIR}/build/${tarch}" \
|
||||||
|
-DCMAKE_TOOLCHAIN_FILE:FILEPATH="${NDK}/build/cmake/android.toolchain.cmake" \
|
||||||
|
-DCMAKE_MAKE_PROGRAM:FILEPATH="${NINJA}" \
|
||||||
|
-DANDROID_PLATFORM="21" \
|
||||||
|
-DCMAKE_SYSTEM_NAME="Android" \
|
||||||
|
-DCMAKE_ANDROID_ARCH_ABI="${tarch}" \
|
||||||
|
-DCMAKE_ANDROID_NDK="${NDK}" \
|
||||||
|
-DCMAKE_SYSTEM_VERSION="16" \
|
||||||
|
-DCMAKE_ANDROID_NDK_TOOLCHAIN_VERSION="clang" \
|
||||||
|
-DDOBBY_DEBUG="OFF" \
|
||||||
|
"${BASEDIR}/"
|
||||||
|
[ "$?" -ne "0" ] && _errorexit 1 "cmake failed for ${tarch}"
|
||||||
|
${NINJA}
|
||||||
|
[ "$?" -ne "0" ] && _errorexit 2 "ninja failed for ${tarch}"
|
||||||
|
|
||||||
|
echo "Copying libraries for ${tarch}..."
|
||||||
|
cp "${BASEDIR}/build/${tarch}/libuwasa.so" "${BASEDIR}/build/app/lib/${tarch}/libuwasa.so"
|
||||||
|
cp "${BASEDIR}/abiproxy/build/${tarch}/libabiproxy.so" "${BASEDIR}/build/app/lib/${tarch}/libabiproxy.so"
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "Rebuilding APK..."
|
||||||
|
${JAVA} -jar "${BASEDIR}/build/${APKTOOL}" b "${BASEDIR}/build/app/" -o "${RESULT}"
|
||||||
|
|
||||||
|
_signandupload
|
||||||
|
}
|
||||||
|
|
||||||
|
_signandupload() {
|
||||||
|
echo "Signing apk..."
|
||||||
|
[ -f "${BASEDIR}/sign.sh" ] || _errorexit 8 "Signer is missing! It must be there: ${BASEDIR}/sign.sh"
|
||||||
|
${BASH} "${BASEDIR}/sign.sh" "${RESULT}"
|
||||||
|
[ "$?" -ne "0" ] && _errorexit 3 || _exit
|
||||||
|
}
|
||||||
|
|
||||||
|
_errorexit() {
|
||||||
|
[ ! -z "$2" ] && echo "$2"
|
||||||
|
echo "An error has occurred, exiting."
|
||||||
|
exit ${1}
|
||||||
|
}
|
||||||
|
|
||||||
|
_exit() {
|
||||||
|
echo "Finished!"
|
||||||
|
exit 0
|
||||||
|
}
|
||||||
|
|
||||||
|
_pre
|
|
@ -3,7 +3,7 @@ from PIL import Image
|
||||||
import plistlib
|
import plistlib
|
||||||
import ast
|
import ast
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
sys.path.append('lib/untp/src/untp')
|
sys.path.append(os.path.dirname(os.path.realpath(__file__)) + '/lib/untp/src/untp')
|
||||||
import untp
|
import untp
|
||||||
from PyTexturePacker import Packer
|
from PyTexturePacker import Packer
|
||||||
from shutil import copyfile
|
from shutil import copyfile
|
||||||
|
@ -20,8 +20,11 @@ def rmdir(directory):
|
||||||
item.unlink()
|
item.unlink()
|
||||||
directory.rmdir()
|
directory.rmdir()
|
||||||
|
|
||||||
en_path = os.path.dirname(os.path.realpath(__file__)) + "/patches/magia-en-apk-assets/"
|
basePath = os.path.dirname(os.path.realpath(__file__))
|
||||||
jp_path = os.path.dirname(os.path.realpath(__file__)) + "/build/app/assets/package/"
|
os.chdir(basePath)
|
||||||
|
|
||||||
|
en_path = basePath + "/patches/magia-en-apk-assets/"
|
||||||
|
jp_path = basePath + "/build/app/assets/package/"
|
||||||
print("EN Path: " + en_path)
|
print("EN Path: " + en_path)
|
||||||
print("JP Path: " + jp_path)
|
print("JP Path: " + jp_path)
|
||||||
|
|
||||||
|
@ -59,7 +62,6 @@ text = path.read_text()
|
||||||
text = text.replace("com.aniplex.magireco", "io.kamihama.magiatranslate")
|
text = text.replace("com.aniplex.magireco", "io.kamihama.magiatranslate")
|
||||||
path.write_text(text)
|
path.write_text(text)
|
||||||
|
|
||||||
basePath = os.path.dirname(os.path.realpath(__file__))
|
|
||||||
rmdir("build/assets")
|
rmdir("build/assets")
|
||||||
Path("build/assets").mkdir(parents=True, exist_ok=True)
|
Path("build/assets").mkdir(parents=True, exist_ok=True)
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,2 @@
|
||||||
parse==1.18.0
|
parse==1.18.0
|
||||||
Pillow==8.0.1
|
|
||||||
pkg-resources==0.0.0
|
|
||||||
PyTexturePacker==1.1.0
|
PyTexturePacker==1.1.0
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
#!/bin/bash
|
||||||
|
BASEDIR="$(realpath "$(dirname "${0}")")"
|
||||||
|
|
||||||
|
# env-based
|
||||||
|
JARSIGNER="${MT_JARSIGNER:-jarsigner}" # /usr/bin/jarsigner
|
||||||
|
|
||||||
|
# arg-based
|
||||||
|
APK="${1:-${BASEDIR}/build/io.kamihama.magiatranslate.v0.50.apk}"
|
||||||
|
KEYSTORE="${2:-${BASEDIR}/changeme.keystore}"
|
||||||
|
|
||||||
|
if [ ! -f "${APK}" ]
|
||||||
|
then
|
||||||
|
echo "Missing apk to sign! Tried file: ${APK}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ ! -f "${KEYSTORE}" ]
|
||||||
|
then
|
||||||
|
echo "Missing keystore! Tried file: ${KEYSTORE}"
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
${JARSIGNER} -sigalg SHA512withRSA -digestalg SHA-512 -keystore "${KEYSTORE}" "${APK}" -storepass changeme name
|
Loading…
Reference in New Issue