From f20d966f1b74b1db67a6d3367da1f7e71e76fe24 Mon Sep 17 00:00:00 2001 From: Marvin W Date: Mon, 21 Dec 2020 20:32:44 +0100 Subject: [PATCH] Mapbox: Add version stamp file to cached native library Fixes #1321 --- play-services-maps-core-mapbox/build.gradle | 1 + .../microg/gms/maps/mapbox/utils/MultiArchLoader.kt | 12 +++++++++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/play-services-maps-core-mapbox/build.gradle b/play-services-maps-core-mapbox/build.gradle index 8ae75a48..e60171ea 100644 --- a/play-services-maps-core-mapbox/build.gradle +++ b/play-services-maps-core-mapbox/build.gradle @@ -20,6 +20,7 @@ apply plugin: 'kotlin-android-extensions' dependencies { implementation project(':play-services-api') + implementation project(':play-services-base-core') implementation("com.mapbox.mapboxsdk:mapbox-android-sdk:9.2.1") { exclude group: 'com.mapbox.mapboxsdk', module: 'mapbox-android-accounts' } diff --git a/play-services-maps-core-mapbox/src/main/kotlin/org/microg/gms/maps/mapbox/utils/MultiArchLoader.kt b/play-services-maps-core-mapbox/src/main/kotlin/org/microg/gms/maps/mapbox/utils/MultiArchLoader.kt index 598860f0..9b7d1ca9 100644 --- a/play-services-maps-core-mapbox/src/main/kotlin/org/microg/gms/maps/mapbox/utils/MultiArchLoader.kt +++ b/play-services-maps-core-mapbox/src/main/kotlin/org/microg/gms/maps/mapbox/utils/MultiArchLoader.kt @@ -21,6 +21,8 @@ import android.content.Context import android.content.pm.ApplicationInfo import android.util.Log import com.mapbox.mapboxsdk.LibraryLoader +import org.microg.gms.common.Constants +import org.microg.gms.common.PackageUtils import java.io.* import java.util.zip.ZipFile @@ -36,9 +38,12 @@ class MultiArchLoader(private val mapContext: Context, private val appContext: C if (primaryCpuAbi != null) { val path = "lib/$primaryCpuAbi/lib$name.so" val cacheFile = File("${appContext.cacheDir.absolutePath}/.gmscore/$path") - cacheFile.parentFile.mkdirs() + cacheFile.parentFile?.mkdirs() + val cacheFileStamp = File("${appContext.cacheDir.absolutePath}/.gmscore/$path.stamp") + val cacheVersion = kotlin.runCatching { cacheFileStamp.readText().toInt() }.getOrNull() + val mapVersion = PackageUtils.versionCode(mapContext, Constants.GMS_PACKAGE_NAME) val apkFile = File(mapContext.packageCodePath) - if (!cacheFile.exists() || cacheFile.lastModified() < apkFile.lastModified()) { + if (!cacheFile.exists() || cacheVersion == null || cacheVersion != mapVersion) { val zipFile = ZipFile(apkFile) val entry = zipFile.getEntry(path) if (entry != null) { @@ -46,6 +51,7 @@ class MultiArchLoader(private val mapContext: Context, private val appContext: C } else { Log.d(TAG, "Can't load native library: $path does not exist in $apkFile") } + cacheFileStamp.writeText(mapVersion.toString()) } Log.d(TAG, "Loading $name from ${cacheFile.getPath()}") System.load(cacheFile.absolutePath) @@ -75,4 +81,4 @@ class MultiArchLoader(private val mapContext: Context, private val appContext: C private val TAG = "GmsMultiArchLoader" } -} \ No newline at end of file +}