1
0
Fork 0

Make it buildable in 2022 (#41)

* Bump up to android-28, gradle 7.2

* updated gradle 2.2.1 -> 7.3.3

* readjusted API Level versions to support Mocor5 devices (hopefully)

* no longer using the deprecated notification.setLatestEventInfo()

* updated permissions list for compatibility with Android 9+

Co-authored-by: Ratmir Karabut <rkarabut@gmail.com>
This commit is contained in:
Dimo Karaivanov 2022-06-14 03:39:56 +03:00 committed by GitHub
parent a352deca43
commit 0a81e6845f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 35 additions and 70 deletions

3
.gitignore vendored
View file

@ -32,4 +32,5 @@ proguard/
#Other #Other
assets/dict.properties assets/dict.properties
t9build.properties t9build.properties
*.keystore

View file

@ -4,7 +4,7 @@
android:versionCode="4" android:versionCode="4"
android:versionName="git" > android:versionName="git" >
<uses-sdk android:minSdkVersion="8" /> <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-configuration <uses-configuration
android:reqFiveWayNav="true" android:reqFiveWayNav="true"

View file

@ -1,16 +1,21 @@
import groovy.swing.SwingBuilder
buildscript { buildscript {
repositories { repositories {
mavenCentral() mavenCentral()
google()
} }
dependencies { dependencies {
classpath 'com.android.tools.build:gradle:1.5.0' classpath 'com.android.tools.build:gradle:7.2.1'
} }
} }
apply plugin: 'android' apply plugin: 'android'
dependencies { dependencies {
compile fileTree(dir: 'libs', include: '*.jar') implementation "androidx.core:core:1.5.0"
}
repositories {
mavenCentral()
google()
} }
def execThing ( String cmdStr ) { def execThing ( String cmdStr ) {
@ -74,8 +79,8 @@ def computeVersionNumber = { ->
} }
android { android {
compileSdkVersion 8 compileSdkVersion 30
buildToolsVersion "19.1" buildToolsVersion "32.0.0"
sourceSets { sourceSets {
main { main {
@ -88,9 +93,6 @@ android {
assets.srcDirs = ['assets'] assets.srcDirs = ['assets']
} }
// Move the tests to tests/java, tests/res, etc...
instrumentTest.setRoot('tests')
// Move the build types to build-types/<type> // Move the build types to build-types/<type>
// For instance, build-types/debug/java, build-types/debug/AndroidManifest.xml, ... // For instance, build-types/debug/java, build-types/debug/AndroidManifest.xml, ...
// This moves them out of them default location under src/<type>/... which would // This moves them out of them default location under src/<type>/... which would
@ -99,10 +101,11 @@ android {
// by a similar customization. // by a similar customization.
debug.setRoot('build-types/debug') debug.setRoot('build-types/debug')
release.setRoot('build-types/release') release.setRoot('build-types/release')
} }
defaultConfig { defaultConfig {
minSdkVersion 19
targetSdk 30
versionCode computeVersionNumber() versionCode computeVersionNumber()
versionName computeVersionName() versionName computeVersionName()
} }
@ -111,23 +114,15 @@ android {
signingConfigs { signingConfigs {
release { release {
storeFile file(System.getenv("KEYSTORE")) storeFile file(System.getenv("KEYSTORE"))
storePassword '' storePassword System.getenv("KEYSTORE_PASS")
keyAlias System.getenv("KEYALIAS") keyAlias System.getenv("KEYALIAS")
keyPassword '' keyPassword System.getenv("KEYALIAS_PASS")
} }
} }
buildTypes { buildTypes {
release { release {
signingConfig android.signingConfigs.release signingConfig android.signingConfigs.release
// http://stackoverflow.com/a/24650026
applicationVariants.all { variant ->
variant.outputs.each { output ->
output.outputFile = new File(output.outputFile.parent,
output.outputFile.name.replace("-release", "-" + android.defaultConfig.versionName)
)
}
}
} }
} }
} }
@ -149,44 +144,3 @@ task getDictSizes {
preBuild.dependsOn getDictSizes preBuild.dependsOn getDictSizes
preBuild.mustRunAfter getDictSizes preBuild.mustRunAfter getDictSizes
// https://www.timroes.de/2014/01/19/using-password-prompts-with-gradle-build-files/
def getPass(String msg) {
def pass = ''
if(System.console() == null) {
new SwingBuilder().edt {
dialog(modal: true, // Otherwise the build will continue running before you closed the dialog
title: 'Enter password', // Dialog title
alwaysOnTop: true, // pretty much what the name says
resizable: false, // Don't allow the user to resize the dialog
locationRelativeTo: null, // Place dialog in center of the screen
pack: true, // We need to pack the dialog (so it will take the size of it's children)
show: true // Let's show it
) {
vbox { // Put everything below each other
label(text: msg)
input = passwordField()
button(defaultButton: true, text: 'OK', actionPerformed: {
pass = new String(input.password); // Set pass variable to value of input field
dispose(); // Close dialog
})
} // vbox end
} // dialog end
} // edt end
} else {
pass = System.console().readPassword("\nPlease enter key passphrase: ")
pass = new String(pass)
}
if(pass.size() <= 0) {
throw new InvalidUserDataException("You must enter a password to proceed.")
}
return pass
}
gradle.taskGraph.whenReady { taskGraph ->
if(taskGraph.hasTask(':assembleRelease')) {
android.signingConfigs.release.storePassword = getPass("Please enter Key Store passphrase:")
android.signingConfigs.release.keyPassword = getPass("Please enter Key passphrase:")
} // end if has task
} // end whenReady

1
gradle.properties Normal file
View file

@ -0,0 +1 @@
android.useAndroidX=true

View file

@ -3,4 +3,4 @@ distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-2.2.1-all.zip distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.3-all.zip

View file

@ -11,4 +11,4 @@
#proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt #proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt
# Project target. # Project target.
target=android-10 target=android-30

View file

@ -2,6 +2,7 @@ package org.nyanya.android.traditionalt9;
import android.app.IntentService; import android.app.IntentService;
import android.app.Notification; import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent; import android.app.PendingIntent;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
@ -49,17 +50,25 @@ public class DBUpdateService extends IntentService {
return; return;
} }
Log.d("T9DBUpdate.onHandle", "Update pass check."); Log.d("T9DBUpdate.onHandle", "Update pass check.");
// do real things // do real things
Notification notification = new Notification(R.drawable.ime_en_lang_lower, getText(R.string.updating_database_title),
System.currentTimeMillis());
Intent notificationIntent = new Intent(this, DBUpdateService.class); Intent notificationIntent = new Intent(this, DBUpdateService.class);
PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, notificationIntent, 0); PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, notificationIntent, 0);
notification.setLatestEventInfo(this, getText(R.string.updating_database_title),
getText(R.string.updating_database), pendingIntent); NotificationManager notificationManager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
Notification.Builder nBuilder = new Notification.Builder(this);
Notification notification = nBuilder
.setContentIntent(pendingIntent)
.setContentTitle(getText(R.string.updating_database_title))
.setContentText(getText(R.string.updating_database))
.setSmallIcon(R.drawable.ime_en_lang_lower)
.getNotification();
notificationManager.notify(UPDATING_NOTIFICATION_ID, notification);
startForeground(UPDATING_NOTIFICATION_ID, notification); startForeground(UPDATING_NOTIFICATION_ID, notification);
//put this in a thread //put this in a thread
mHandler.post(new DisplayToast(this, getText(R.string.updating_database))); mHandler.post(new DisplayToast(this, getText(R.string.updating_database)));