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:
parent
1f3abb127b
commit
7188f0a923
4 changed files with 108 additions and 19 deletions
6
.gitignore
vendored
6
.gitignore
vendored
|
@ -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/
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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'],
|
||||||
|
|
|
@ -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"
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue