mirror of
https://github.com/etesync/android
synced 2025-01-22 21:51:04 +00:00
Improve time-zone detection in VEVENTs
This commit is contained in:
parent
001b445222
commit
08789bbb2c
@ -50,6 +50,8 @@ import net.fortuna.ical4j.util.CompatibilityHints;
|
|||||||
import net.fortuna.ical4j.util.SimpleHostInfo;
|
import net.fortuna.ical4j.util.SimpleHostInfo;
|
||||||
import net.fortuna.ical4j.util.UidGenerator;
|
import net.fortuna.ical4j.util.UidGenerator;
|
||||||
|
|
||||||
|
import org.apache.commons.lang.StringUtils;
|
||||||
|
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
@ -348,28 +350,32 @@ public class Event extends Resource {
|
|||||||
if (tzID == null)
|
if (tzID == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
String localTZ = Time.TIMEZONE_UTC;
|
String localTZ = null;
|
||||||
boolean foundMatch = false;
|
String availableTZs[] = SimpleTimeZone.getAvailableIDs();
|
||||||
String availableTZs[] = SimpleTimeZone.getAvailableIDs();
|
|
||||||
|
|
||||||
// Try to find an exact match
|
// first, try to find an exact match (case insensitive)
|
||||||
for (String availableTZ : availableTZs) {
|
for (String availableTZ : availableTZs)
|
||||||
if (tzID.equals(availableTZ)) {
|
if (tzID.equalsIgnoreCase(availableTZ)) {
|
||||||
localTZ = availableTZ;
|
localTZ = availableTZ;
|
||||||
foundMatch = true;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// if that doesn't work, try to find something else that matches
|
||||||
|
if (localTZ == null) {
|
||||||
|
Log.w(TAG, "Coulnd't find time zone with matching identifiers, trying to guess");
|
||||||
|
for (String availableTZ : availableTZs)
|
||||||
|
if (StringUtils.indexOfIgnoreCase(tzID, availableTZ) != -1) {
|
||||||
|
localTZ = availableTZ;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!foundMatch) {
|
// if that doesn't work, use UTC as fallback
|
||||||
// Try to find something else that matches
|
if (localTZ == null) {
|
||||||
for (String availableTZ : availableTZs) {
|
Log.e(TAG, "Couldn't identify time zone, using UTC as fallback");
|
||||||
if (tzID.indexOf(availableTZ, 0) != -1) {
|
localTZ = Time.TIMEZONE_UTC;
|
||||||
localTZ = availableTZ;
|
}
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Log.d(TAG, "Assuming time zone " + localTZ + " for " + tzID);
|
Log.d(TAG, "Assuming time zone " + localTZ + " for " + tzID);
|
||||||
date.setTimeZone(tzRegistry.getTimeZone(localTZ));
|
date.setTimeZone(tzRegistry.getTimeZone(localTZ));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user