diff options
author | The Android Open Source Project <initial-contribution@android.com> | 2009-03-03 19:31:44 -0800 |
---|---|---|
committer | The Android Open Source Project <initial-contribution@android.com> | 2009-03-03 19:31:44 -0800 |
commit | 9066cfe9886ac131c34d59ed0e2d287b0e3c0087 (patch) | |
tree | d88beb88001f2482911e3d28e43833b50e4b4e97 /core/java/android/util/TimeUtils.java | |
parent | d83a98f4ce9cfa908f5c54bbd70f03eec07e7553 (diff) | |
download | frameworks_base-9066cfe9886ac131c34d59ed0e2d287b0e3c0087.zip frameworks_base-9066cfe9886ac131c34d59ed0e2d287b0e3c0087.tar.gz frameworks_base-9066cfe9886ac131c34d59ed0e2d287b0e3c0087.tar.bz2 |
auto import from //depot/cupcake/@135843
Diffstat (limited to 'core/java/android/util/TimeUtils.java')
-rw-r--r-- | core/java/android/util/TimeUtils.java | 133 |
1 files changed, 133 insertions, 0 deletions
diff --git a/core/java/android/util/TimeUtils.java b/core/java/android/util/TimeUtils.java new file mode 100644 index 0000000..0fc70d5 --- /dev/null +++ b/core/java/android/util/TimeUtils.java @@ -0,0 +1,133 @@ +/* + * Copyright (C) 2006 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package android.util; + +import android.content.res.Resources; +import android.content.res.XmlResourceParser; + +import org.apache.harmony.luni.internal.util.ZoneInfoDB; +import org.xmlpull.v1.XmlPullParser; +import org.xmlpull.v1.XmlPullParserException; + +import java.io.IOException; +import java.util.TimeZone; +import java.util.Date; + +import com.android.internal.util.XmlUtils; + +/** + * A class containing utility methods related to time zones. + */ +public class TimeUtils { + private static final String TAG = "TimeUtils"; + + /** + * Tries to return a time zone that would have had the specified offset + * and DST value at the specified moment in the specified country. + * Returns null if no suitable zone could be found. + */ + public static TimeZone getTimeZone(int offset, boolean dst, long when, String country) { + if (country == null) { + return null; + } + + TimeZone best = null; + + Resources r = Resources.getSystem(); + XmlResourceParser parser = r.getXml(com.android.internal.R.xml.time_zones_by_country); + Date d = new Date(when); + + TimeZone current = TimeZone.getDefault(); + String currentName = current.getID(); + int currentOffset = current.getOffset(when); + boolean currentDst = current.inDaylightTime(d); + + try { + XmlUtils.beginDocument(parser, "timezones"); + + while (true) { + XmlUtils.nextElement(parser); + + String element = parser.getName(); + if (element == null || !(element.equals("timezone"))) { + break; + } + + String code = parser.getAttributeValue(null, "code"); + + if (country.equals(code)) { + if (parser.next() == XmlPullParser.TEXT) { + String maybe = parser.getText(); + + // If the current time zone is from the right country + // and meets the other known properties, keep it + // instead of changing to another one. + + if (maybe.equals(currentName)) { + if (currentOffset == offset && currentDst == dst) { + return current; + } + } + + // Otherwise, take the first zone from the right + // country that has the correct current offset and DST. + // (Keep iterating instead of returning in case we + // haven't encountered the current time zone yet.) + + if (best == null) { + TimeZone tz = TimeZone.getTimeZone(maybe); + + if (tz.getOffset(when) == offset && + tz.inDaylightTime(d) == dst) { + best = tz; + } + } + } + } + } + } catch (XmlPullParserException e) { + Log.e(TAG, "Got exception while getting preferred time zone.", e); + } catch (IOException e) { + Log.e(TAG, "Got exception while getting preferred time zone.", e); + } finally { + parser.close(); + } + + return best; + } + + /** + * Returns a String indicating the version of the time zone database currently + * in use. The format of the string is dependent on the underlying time zone + * database implementation, but will typically contain the year in which the database + * was updated plus a letter from a to z indicating changes made within that year. + * + * <p>Time zone database updates should be expected to occur periodically due to + * political and legal changes that cannot be anticipated in advance. Therefore, + * when computing the UTC time for a future event, applications should be aware that + * the results may differ following a time zone database update. This method allows + * applications to detect that a database change has occurred, and to recalculate any + * cached times accordingly. + * + * <p>The time zone database may be assumed to change only when the device runtime + * is restarted. Therefore, it is not necessary to re-query the database version + * during the lifetime of an activity. + */ + public static String getTimeZoneDatabaseVersion() { + return ZoneInfoDB.getVersion(); + } +} |