Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/mono.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormonojenkins <jo.shields+jenkins@xamarin.com>2020-09-04 21:56:21 +0300
committerGitHub <noreply@github.com>2020-09-04 21:56:21 +0300
commitabfd341464b32d5cd914c5f3ffde6c8cd8dc10ca (patch)
tree394c9b2a3c9011f77597729619212aa34e71222f
parent32c0b1aaf9e9351aaff6f028787a525dac94036a (diff)
[Android] Enable access to up-to-date tzdata on Android 10+ (#20350)
Context: https://source.android.com/devices/architecture/modular-system/runtime#time-zone-data-interactions Context: https://source.android.com/devices/tech/config/timezone-rules#timezone-apex Maybe Fixes: https://github.com/xamarin/xamarin-android/issues/5080 Add support to read ICANN timezone data from two new locations found on devices running Android 10+. The data in the previously searched location still exists but it's most likely out of date. On Android 10+ tzdata updates will be derived via an APEX TimeData package update, whose data directory this commit sets as the first location to be searched. This commit potentially fixes the Xamarin.Android issue mentioned above. "Potentially" because I can't be sure this is what's causing it since I'm unable to reproduce the issue locally. However, out-of-date tz database seems to be the most probable cause. Co-authored-by: Marek Habersack <grendel@twistedcode.net>
-rw-r--r--mcs/class/corlib/System/TimeZoneInfo.Android.cs26
1 files changed, 26 insertions, 0 deletions
diff --git a/mcs/class/corlib/System/TimeZoneInfo.Android.cs b/mcs/class/corlib/System/TimeZoneInfo.Android.cs
index fa9f73a4dc6..792a9fe2bc3 100644
--- a/mcs/class/corlib/System/TimeZoneInfo.Android.cs
+++ b/mcs/class/corlib/System/TimeZoneInfo.Android.cs
@@ -58,10 +58,16 @@ namespace System {
* https://android.googlesource.com/platform/libcore/+/master/luni/src/main/java/libcore/util/ZoneInfoDB.java
*
* This is needed in order to read Android v4.3 tzdata files.
+ *
+ * Android 10+ moved the up-to-date tzdata location to a module updatable via the Google Play Store and the
+ * database location changed (https://source.android.com/devices/architecture/modular-system/runtime#time-zone-data-interactions)
+ * The older locations still exist (at least the `/system/usr/share/zoneinfo` one) but they won't be updated.
*/
sealed class AndroidTzData : IAndroidTimeZoneDB {
internal static readonly string[] Paths = new string[]{
+ GetApexTimeDataRoot () + "/etc/tz/tzdata", // Android 10+, TimeData module where the updates land
+ GetApexRuntimeRoot () + "/etc/tz/tzdata", // Android 10+, Fallback location if the above isn't found or corrupted
Environment.GetEnvironmentVariable ("ANDROID_DATA") + "/misc/zoneinfo/tzdata",
Environment.GetEnvironmentVariable ("ANDROID_ROOT") + "/usr/share/zoneinfo/tzdata",
};
@@ -98,6 +104,26 @@ namespace System {
get {return zoneTab;}
}
+ static string GetApexTimeDataRoot ()
+ {
+ string ret = Environment.GetEnvironmentVariable ("ANDROID_TZDATA_ROOT");
+ if (!String.IsNullOrEmpty (ret)) {
+ return ret;
+ }
+
+ return "/apex/com.android.tzdata";
+ }
+
+ static string GetApexRuntimeRoot ()
+ {
+ string ret = Environment.GetEnvironmentVariable ("ANDROID_RUNTIME_ROOT");
+ if (!String.IsNullOrEmpty (ret)) {
+ return ret;
+ }
+
+ return "/apex/com.android.runtime";
+ }
+
bool LoadData (string path)
{
if (!File.Exists (path))