1
0
Fork 0
mirror of https://github.com/syncthing/syncthing-android.git synced 2024-11-26 06:11:19 +00:00

Support python3 during build - Install MinGit on-demand on Windows (#69)

* Build with python3 - Replace urllib
* Fix build.gradle cleanNative
* Update README.md
* build-syncthing - Install MinGit on demand if missing on Windows
This commit is contained in:
Catfriend1 2018-09-23 14:36:49 +02:00 committed by GitHub
parent 1f3abb127b
commit 7188f0a923
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 108 additions and 19 deletions

6
.gitignore vendored
View file

@ -33,8 +33,14 @@ gradle/wrapper/gradlew*
syncthing/go syncthing/go
syncthing/go.tgz syncthing/go.tgz
syncthing/go.zip syncthing/go.zip
# Android NDK
syncthing/android-ndk-r* syncthing/android-ndk-r*
syncthing/ndk.zip syncthing/ndk.zip
# MinGit
syncthing/mingit
syncthing/mingit.zip
# External build artifacts # External build artifacts
ext/ ext/

View file

@ -31,6 +31,8 @@ The project is translated on [Transifex](https://www.transifex.com/projects/p/sy
`Make sure, Go is installed and available on the PATH environment variable. If Go is not found on the PATH environment variable, build-syncthing.py will automatically try to download and setup GO on the PATH.` `Make sure, Go is installed and available on the PATH environment variable. If Go is not found on the PATH environment variable, build-syncthing.py will automatically try to download and setup GO on the PATH.`
- Python 2.7 - Python 2.7
`Make sure, Python is installed and available on the PATH environment variable.` `Make sure, Python is installed and available on the PATH environment variable.`
- Git (for Linux) or Git for Windows
`Make sure, git (or git.exe) is installed and available on the PATH environment variable. If Git is not found on the PATH environment variable, build-syncthing.py will automatically try to download and setup MinGit 2.19.0-x64 on the PATH.`
### Build instructions ### Build instructions
@ -41,13 +43,17 @@ Alternatively, run `git submodule init && git submodule update` in the project f
A Linux VM, for example running Debian, is recommended to build this. A Linux VM, for example running Debian, is recommended to build this.
Build Syncthing and the Syncthing-Android wrapper using the following commands: Build Syncthing and the Syncthing-Android wrapper using the following commands:
`./gradlew buildNative` `./gradlew buildNative`
`./gradlew lint assembleDebug` `./gradlew lint assembleDebug`
You can also use Android Studio to build the apk after you manually ran the `./gradlew buildNative` command in the repository root. You can also use Android Studio to build the apk after you manually ran the `./gradlew buildNative` command in the repository root.
To clean up all files generated during build, use the following commands: To clean up all files generated during build, use the following commands:
`./gradlew cleanNative` `./gradlew cleanNative`
`./gradlew clean` `./gradlew clean`
# License # License

View file

@ -4,6 +4,11 @@ import os.path
import sys import sys
import subprocess import subprocess
import platform import platform
#
# Script Compatibility:
# - Python 2.7.15
# - Python 3.7.0
#
SUPPORTED_PYTHON_PLATFORMS = ['Windows', 'Linux', 'Darwin'] SUPPORTED_PYTHON_PLATFORMS = ['Windows', 'Linux', 'Darwin']
@ -71,13 +76,67 @@ def change_permissions_recursive(path, mode):
for file in [os.path.join(root, f) for f in files]: for file in [os.path.join(root, f) for f in files]:
os.chmod(file, mode) os.chmod(file, mode)
def install_git():
import os
import zipfile
import hashlib
if sys.version_info[0] >= 3:
from urllib.request import urlretrieve
else:
from urllib import urlretrieve
# Consts.
pwd_path = os.path.dirname(os.path.realpath(__file__))
if sys.platform == 'win32':
url = 'https://github.com/git-for-windows/git/releases/download/v2.19.0.windows.1/MinGit-2.19.0-64-bit.zip'
expected_shasum = '424d24b5fc185a9c5488d7872262464f2facab4f1d4693ea8008196f14a3c19b'
zip_fullfn = pwd_path + os.path.sep + 'mingit.zip';
else:
print('Portable on-demand git installation is currently not supported on linux.')
return None
# Download MinGit.
url_base_name = os.path.basename(url)
if not os.path.isfile(zip_fullfn):
print('Downloading MinGit to:', zip_fullfn)
zip_fullfn = urlretrieve(url, zip_fullfn)[0]
print('Downloaded MinGit to:', zip_fullfn)
# Verfiy SHA-256 checksum of downloaded files.
with open(zip_fullfn, 'rb') as f:
contents = f.read()
found_shasum = hashlib.sha256(contents).hexdigest()
print("SHA-256:", zip_fullfn, "%s" % found_shasum)
if found_shasum != expected_shasum:
fail('Error: SHA-256 checksum ' + found_shasum + ' of downloaded file does not match expected checksum ' + expected_shasum)
print("[ok] Checksum of", zip_fullfn, "matches expected value.")
# Proceed with extraction of the MinGit.
if not os.path.isfile(pwd_path + os.path.sep + 'mingit' + os.path.sep + 'LICENSE.txt'):
print("Extracting MinGit ...")
# This will go to a subfolder "mingit" in the current path.
zip = zipfile.ZipFile(zip_fullfn, 'r')
zip.extractall(pwd_path + os.path.sep + 'mingit')
zip.close()
# Add "mingit/cmd" to the PATH.
git_bin_path = pwd_path + os.path.sep + 'mingit' + os.path.sep + 'cmd'
print('Adding to PATH:', git_bin_path)
os.environ["PATH"] += os.pathsep + git_bin_path
def install_go(): def install_go():
import os import os
import tarfile import tarfile
import zipfile import zipfile
import urllib
import hashlib import hashlib
if sys.version_info[0] >= 3:
from urllib.request import urlretrieve
else:
from urllib import urlretrieve
# Consts. # Consts.
pwd_path = os.path.dirname(os.path.realpath(__file__)) pwd_path = os.path.dirname(os.path.realpath(__file__))
if sys.platform == 'win32': if sys.platform == 'win32':
@ -93,7 +152,7 @@ def install_go():
url_base_name = os.path.basename(url) url_base_name = os.path.basename(url)
if not os.path.isfile(tar_gz_fullfn): if not os.path.isfile(tar_gz_fullfn):
print('Downloading prebuilt-go to:', tar_gz_fullfn) print('Downloading prebuilt-go to:', tar_gz_fullfn)
tar_gz_fullfn = urllib.urlretrieve(url, tar_gz_fullfn)[0] tar_gz_fullfn = urlretrieve(url, tar_gz_fullfn)[0]
print('Downloaded prebuilt-go to:', tar_gz_fullfn) print('Downloaded prebuilt-go to:', tar_gz_fullfn)
# Verfiy SHA-256 checksum of downloaded files. # Verfiy SHA-256 checksum of downloaded files.
@ -102,7 +161,7 @@ def install_go():
found_shasum = hashlib.sha256(contents).hexdigest() found_shasum = hashlib.sha256(contents).hexdigest()
print("SHA-256:", tar_gz_fullfn, "%s" % found_shasum) print("SHA-256:", tar_gz_fullfn, "%s" % found_shasum)
if found_shasum != expected_shasum: if found_shasum != expected_shasum:
fail('Error: SHA-256 checksum', found_shasum, 'of downloaded file does not match expected checksum', expected_shasum) fail('Error: SHA-256 checksum ' + found_shasum + ' of downloaded file does not match expected checksum ' + expected_shasum)
print("[ok] Checksum of", tar_gz_fullfn, "matches expected value.") print("[ok] Checksum of", tar_gz_fullfn, "matches expected value.")
# Proceed with extraction of the prebuilt go. # Proceed with extraction of the prebuilt go.
@ -119,7 +178,7 @@ def install_go():
tar.extractall(pwd_path) tar.extractall(pwd_path)
tar.close() tar.close()
# Add (...).tar/go/bin" to the PATH. # Add "go/bin" to the PATH.
go_bin_path = pwd_path + os.path.sep + 'go' + os.path.sep + 'bin' go_bin_path = pwd_path + os.path.sep + 'go' + os.path.sep + 'bin'
print('Adding to PATH:', go_bin_path) print('Adding to PATH:', go_bin_path)
os.environ["PATH"] += os.pathsep + go_bin_path os.environ["PATH"] += os.pathsep + go_bin_path
@ -130,9 +189,13 @@ def install_go():
def install_ndk(): def install_ndk():
import os import os
import zipfile import zipfile
import urllib
import hashlib import hashlib
if sys.version_info[0] >= 3:
from urllib.request import urlretrieve
else:
from urllib import urlretrieve
# Consts. # Consts.
pwd_path = os.path.dirname(os.path.realpath(__file__)) pwd_path = os.path.dirname(os.path.realpath(__file__))
if sys.platform == 'win32': if sys.platform == 'win32':
@ -148,7 +211,7 @@ def install_ndk():
url_base_name = os.path.basename(url) url_base_name = os.path.basename(url)
if not os.path.isfile(zip_fullfn): if not os.path.isfile(zip_fullfn):
print('Downloading NDK to:', zip_fullfn) print('Downloading NDK to:', zip_fullfn)
zip_fullfn = urllib.urlretrieve(url, zip_fullfn)[0] zip_fullfn = urlretrieve(url, zip_fullfn)[0]
print('Downloaded NDK to:', zip_fullfn) print('Downloaded NDK to:', zip_fullfn)
# Verfiy SHA-1 checksum of downloaded files. # Verfiy SHA-1 checksum of downloaded files.
@ -157,7 +220,7 @@ def install_ndk():
found_shasum = hashlib.sha1(contents).hexdigest() found_shasum = hashlib.sha1(contents).hexdigest()
print("SHA-1:", zip_fullfn, "%s" % found_shasum) print("SHA-1:", zip_fullfn, "%s" % found_shasum)
if found_shasum != expected_shasum: if found_shasum != expected_shasum:
fail('Error: SHA-1 checksum', found_shasum, 'of downloaded file does not match expected checksum', expected_shasum) fail('Error: SHA-256 checksum ' + found_shasum + ' of downloaded file does not match expected checksum ' + expected_shasum)
print("[ok] Checksum of", zip_fullfn, "matches expected value.") print("[ok] Checksum of", zip_fullfn, "matches expected value.")
# Proceed with extraction of the NDK if necessary. # Proceed with extraction of the NDK if necessary.
@ -196,6 +259,17 @@ go_build_dir = os.path.join(build_dir, 'go-packages')
syncthing_dir = os.path.join(module_dir, 'src', 'github.com', 'syncthing', 'syncthing') syncthing_dir = os.path.join(module_dir, 'src', 'github.com', 'syncthing', 'syncthing')
min_sdk = get_min_sdk(project_dir) min_sdk = get_min_sdk(project_dir)
# Check if git is available.
git_bin = which("git");
if not git_bin:
print('Warning: git is not available on the PATH.')
install_git();
# Retry: Check if git is available.
git_bin = which("git");
if not git_bin:
fail('Error: git is not available on the PATH.')
print('git_bin=\'' + git_bin + '\'')
# Check if go is available. # Check if go is available.
go_bin = which("go"); go_bin = which("go");
if not go_bin: if not go_bin:
@ -205,7 +279,7 @@ if not go_bin:
go_bin = which("go"); go_bin = which("go");
if not go_bin: if not go_bin:
fail('Error: go is not available on the PATH.') fail('Error: go is not available on the PATH.')
print ('go_bin=\'' + go_bin + '\'') print('go_bin=\'' + go_bin + '\'')
# Check if ANDROID_NDK_HOME variable is set. # Check if ANDROID_NDK_HOME variable is set.
if not os.environ.get('ANDROID_NDK_HOME', ''): if not os.environ.get('ANDROID_NDK_HOME', ''):
@ -214,10 +288,10 @@ if not os.environ.get('ANDROID_NDK_HOME', ''):
# Retry: Check if ANDROID_NDK_HOME variable is set. # Retry: Check if ANDROID_NDK_HOME variable is set.
if not os.environ.get('ANDROID_NDK_HOME', ''): if not os.environ.get('ANDROID_NDK_HOME', ''):
fail('Error: ANDROID_NDK_HOME environment variable not defined') fail('Error: ANDROID_NDK_HOME environment variable not defined')
print ('ANDROID_NDK_HOME=\'' + os.environ.get('ANDROID_NDK_HOME', '') + '\'') print('ANDROID_NDK_HOME=\'' + os.environ.get('ANDROID_NDK_HOME', '') + '\'')
# Make sure all tags are available for git describe # Make sure all tags are available for git describe
# https://github.com/syncthing/syncthing-android/issues/872 print('Invoking git fetch ...')
subprocess.check_call([ subprocess.check_call([
'git', 'git',
'-C', '-C',
@ -226,6 +300,16 @@ subprocess.check_call([
'--tags' '--tags'
]) ])
print('Invoking git describe ...')
syncthingVersion = subprocess.check_output([
git_bin,
'-C',
syncthing_dir,
'describe',
'--always'
]).strip();
syncthingVersion = syncthingVersion.decode().replace("rc", "preview");
for target in BUILD_TARGETS: for target in BUILD_TARGETS:
target_min_sdk = str(target.get('min_sdk', min_sdk)) target_min_sdk = str(target.get('min_sdk', min_sdk))
print('Building for', target['arch']) print('Building for', target['arch'])
@ -261,14 +345,6 @@ for target in BUILD_TARGETS:
'CC': os.path.join(standalone_ndk_dir, 'bin', target['cc']) 'CC': os.path.join(standalone_ndk_dir, 'bin', target['cc'])
}) })
syncthingVersion = subprocess.check_output([
'git',
'-C',
syncthing_dir,
'describe',
'--always'
]).strip();
syncthingVersion = syncthingVersion.replace("rc", "preview");
print('Building syncthing version', syncthingVersion); print('Building syncthing version', syncthingVersion);
subprocess.check_call([ subprocess.check_call([
go_bin, 'run', 'build.go', '-goos', 'android', '-goarch', target['goarch'], go_bin, 'run', 'build.go', '-goos', 'android', '-goarch', target['goarch'],

View file

@ -10,7 +10,8 @@ task buildNative(type: Exec) {
*/ */
task cleanNative(type: Delete) { task cleanNative(type: Delete) {
delete "$projectDir/../app/src/main/jniLibs/" delete "$projectDir/../app/src/main/jniLibs/"
delete "android-ndk-r16b" delete "android-ndk-r18"
delete "gobuild" delete "gobuild"
delete "go" delete "go"
delete "mingit"
} }