scripts: Improve `bundle-status-go.sh` so that it can bundle Android package as well (#2539)
Signed-off-by: Oskar Thoren <ot@oskarthoren.com>
This commit is contained in:
parent
87dc4ead85
commit
0d83aeda8d
|
@ -78,6 +78,7 @@ re-natal
|
||||||
|
|
||||||
# Status
|
# Status
|
||||||
Statusgo.framework
|
Statusgo.framework
|
||||||
|
status-go-local.aar
|
||||||
status-dev-cli
|
status-dev-cli
|
||||||
|
|
||||||
#ios
|
#ios
|
||||||
|
|
|
@ -18,6 +18,7 @@ allprojects {
|
||||||
mavenLocal()
|
mavenLocal()
|
||||||
jcenter()
|
jcenter()
|
||||||
maven { url "$rootDir/../node_modules/react-native/android" }
|
maven { url "$rootDir/../node_modules/react-native/android" }
|
||||||
|
maven { url "$rootDir/../modules/react-native-status/android/libs" }
|
||||||
// for geth
|
// for geth
|
||||||
flatDir { dirs 'libs' }
|
flatDir { dirs 'libs' }
|
||||||
maven { url "http://139.162.11.12:8081/artifactory/libs-release-local" }
|
maven { url "http://139.162.11.12:8081/artifactory/libs-release-local" }
|
||||||
|
|
|
@ -17,5 +17,16 @@ dependencies {
|
||||||
compile 'com.instabug.library:instabug:3+'
|
compile 'com.instabug.library:instabug:3+'
|
||||||
compile 'com.github.ericwlange:AndroidJSCore:3.0.1'
|
compile 'com.github.ericwlange:AndroidJSCore:3.0.1'
|
||||||
compile 'status-im:function:0.0.1'
|
compile 'status-im:function:0.0.1'
|
||||||
compile(group: 'status-im', name: 'status-go', version: 'develop-gb7fb51d9', ext: 'aar')
|
|
||||||
|
String statusGoVersion = 'develop-gb7fb51d9'
|
||||||
|
final String statusGoGroup = 'status-im', statusGoName = 'status-go'
|
||||||
|
|
||||||
|
// Check if the local status-go jar exists, and compile against that if it does
|
||||||
|
final String localStatusLibOutputDir = "${rootDir}/../modules/react-native-status/android/libs", localVersion = 'local'
|
||||||
|
if ( new File("${localStatusLibOutputDir}/${statusGoGroup}/${statusGoName}/${localVersion}/${statusGoName}-${localVersion}.aar").exists() ) {
|
||||||
|
// Use the local version
|
||||||
|
statusGoVersion = localVersion
|
||||||
|
}
|
||||||
|
|
||||||
|
compile(group: statusGoGroup, name: statusGoName, version: statusGoVersion, ext: 'aar')
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,7 @@ case $TARGET in
|
||||||
;;
|
;;
|
||||||
prod)
|
prod)
|
||||||
STORE_FILE=$(property_gradle 'STATUS_RELEASE_STORE_FILE')
|
STORE_FILE=$(property_gradle 'STATUS_RELEASE_STORE_FILE')
|
||||||
[[ ! -e "${STORE_FILE/#\~/$HOME}" ]] && echo "Please generate keystore first using ./generate-kesytore.sh" && exit 0
|
[[ ! -e "${STORE_FILE/#\~/$HOME}" ]] && echo "Please generate keystore first using ./generate-keystore.sh" && exit 0
|
||||||
lein do clean, with-profile prod cljsbuild once android && ./android/gradlew ${GRADLE_PROPERTIES} assembleRelease
|
lein do clean, with-profile prod cljsbuild once android && ./android/gradlew ${GRADLE_PROPERTIES} assembleRelease
|
||||||
cecho "Generated @b@blueandroid/app/build/outputs/apk/app-release.apk"
|
cecho "Generated @b@blueandroid/app/build/outputs/apk/app-release.apk"
|
||||||
echo
|
echo
|
||||||
|
|
|
@ -1,16 +1,36 @@
|
||||||
#!/usr/bin/env sh
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
set -euf pipefail
|
if [ -z $STATUS_GO_HOME ] ; then
|
||||||
|
echo "Please define STATUS_GO_HOME"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ -z $STATUS_REACT_HOME ] ; then
|
||||||
|
echo "Please define STATUS_REACT_HOME"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ $# -eq 0 ]; then
|
||||||
|
echo "Please specify platforms to bundle as discrete arguments (ios, android)"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
# TODO Clean up with require STATUS_GO_HOME and STATUS_REACT_HOME
|
set -euf
|
||||||
|
|
||||||
echo "[Assumes status-go is in sibling directory]"
|
for platform in "$@"; do
|
||||||
echo "[Warning: iOS only for now]"
|
case $platform in
|
||||||
|
ios | android)
|
||||||
|
echo "Bundling $platform platform"
|
||||||
|
|
||||||
cd ..
|
cd $STATUS_GO_HOME
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Undefined platform $platform"
|
||||||
|
exit 1
|
||||||
|
esac
|
||||||
|
|
||||||
|
case $platform in
|
||||||
|
ios)
|
||||||
# Build status-go artifact for iOS:
|
# Build status-go artifact for iOS:
|
||||||
(cd status-go && make statusgo-ios-simulator)
|
make statusgo-ios-simulator
|
||||||
|
|
||||||
# You should see iOS framework cross compilation done. This builds the following artifact:
|
# You should see iOS framework cross compilation done. This builds the following artifact:
|
||||||
#
|
#
|
||||||
|
@ -28,10 +48,10 @@ cd ..
|
||||||
# Instead we are going to manually overwrite it.
|
# Instead we are going to manually overwrite it.
|
||||||
|
|
||||||
# For Xcode to pick up the new version, remove the whole framework first:
|
# For Xcode to pick up the new version, remove the whole framework first:
|
||||||
rm -r status-react/modules/react-native-status/ios/RCTStatus/Statusgo.framework/ || true
|
rm -r $STATUS_REACT_HOME/modules/react-native-status/ios/RCTStatus/Statusgo.framework/ || true
|
||||||
|
|
||||||
# Then copy over framework:
|
# Then copy over framework:
|
||||||
cp -R status-go/build/bin/statusgo-ios-9.3-framework/Statusgo.framework status-react/modules/react-native-status/ios/RCTStatus/Statusgo.framework
|
cp -R $STATUS_GO_HOME/build/bin/statusgo-ios-9.3-framework/Statusgo.framework $STATUS_REACT_HOME/modules/react-native-status/ios/RCTStatus/Statusgo.framework
|
||||||
|
|
||||||
# In Xcode, clean and build. If you have any scripts to do this, make sure that
|
# In Xcode, clean and build. If you have any scripts to do this, make sure that
|
||||||
# you don't accidentally run the mvn step to undo your manual install.
|
# you don't accidentally run the mvn step to undo your manual install.
|
||||||
|
@ -44,3 +64,22 @@ cd -
|
||||||
|
|
||||||
echo "[Done]"
|
echo "[Done]"
|
||||||
echo "[You can now build in Xcode]"
|
echo "[You can now build in Xcode]"
|
||||||
|
;;
|
||||||
|
android)
|
||||||
|
# Build status-go artifact for Android:
|
||||||
|
make statusgo-android
|
||||||
|
|
||||||
|
target=$STATUS_REACT_HOME/modules/react-native-status/android/libs/status-im/status-go/local
|
||||||
|
[ -d $target ] || mkdir -p $target
|
||||||
|
# Copy over framework:
|
||||||
|
cp -R $STATUS_GO_HOME/build/bin/statusgo-android-16.aar $target/status-go-local.aar
|
||||||
|
|
||||||
|
# It might also be a good idea to print something custom so you can easily tell
|
||||||
|
# the difference between an old and new version of status-go.
|
||||||
|
|
||||||
|
cd -
|
||||||
|
|
||||||
|
echo "[Done]"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
Loading…
Reference in New Issue