view patches/icedtea-use-system-tzdata.patch @ 1730:c3605faebe92

Backport tzdata support from 1.8 (--with-tzdata-dir). 2009-12-22 Andrew John Hughes <ahughes@redhat.com> Backport --with-tzdata-dir option from IcedTea6. * Makefile.am: (icedtea.stamp): Copy tz.properties when TZDATA_DIR is specified. (icedtea-debug.stamp): Likewise. Add missing -debug suffix. * acinclude.m4: (CHECK_WITH_TZDATA_DIR): Allow a directory containing timezone data to be specified. Defaults to /usr/share/javazi. * configure.ac: Call CHECK_WITH_TZDATA_DIR. * patches/icedtea-use-system-tzdata.patch: New version which uses configurable datadir. As in IcedTea7. * patches/security/icedtea-6824265.patch: Revert to original version from Sun. * tz.properties.in: Input file for tzdata directory setting.
author Andrew John Hughes <ahughes@redhat.com>
date Wed, 02 Jun 2010 16:59:01 +0100
parents b3106a2e4455
children
line wrap: on
line source

# HG changeset patch
# User andrew
# Date 1257348405 0
# Node ID d03acee39d3b283dbfe972ce9398ea1ce9cdd3fc
# Parent  922421b1938a44633d22fd2a5a1e376a99bb9090
6593486: (tz) RFE: support user-defined directory path to time zone data files
Summary: Allow the timezone data directory to be changed by setting sun.timezone.dir

diff -r 922421b1938a -r d03acee39d3b src/share/classes/sun/util/calendar/ZoneInfoFile.java
--- openjdk.orig/jdk/src/share/classes/sun/util/calendar/ZoneInfoFile.java	Wed Nov 04 12:22:35 2009 +0000
+++ openjdk/jdk/src/share/classes/sun/util/calendar/ZoneInfoFile.java	Wed Nov 04 15:26:45 2009 +0000
@@ -25,10 +25,12 @@
 
 package sun.util.calendar;
 
+import  java.io.BufferedInputStream;
 import  java.io.File;
 import  java.io.FileInputStream;
 import  java.io.FileNotFoundException;
 import  java.io.IOException;
+import  java.io.InputStream;
 import  java.lang.ref.SoftReference;
 import  java.security.AccessController;
 import  java.security.PrivilegedAction;
@@ -38,6 +40,7 @@
 import  java.util.HashMap;
 import  java.util.List;
 import  java.util.Map;
+import  java.util.Properties;
 
 /**
  * <code>ZoneInfoFile</code> reads Zone information files in the
@@ -473,17 +476,52 @@
     private static Map<String, ZoneInfo> zoneInfoObjects = null;
 
     private static final String ziDir;
+
     static {
-        String zi = (String) AccessController.doPrivileged(
-                         new sun.security.action.GetPropertyAction("java.home"))
-                    + File.separator + "lib" + File.separator + "zi";
+        final String homeDir =
+            AccessController.doPrivileged(
+             new sun.security.action.GetPropertyAction("java.home"));
+        if (homeDir == null) {
+            throw new Error("java.home is not set");
+        }
+        String zi = homeDir + File.separator + "lib" +
+            File.separator + "zi";
         try {
+            String otherDir = getZoneInfoDir(homeDir);
+            if (otherDir != null)
+                zi = otherDir;
             zi = new File(zi).getCanonicalPath();
         } catch (Exception e) {
         }
         ziDir = zi;
     }
 
+    private static String getZoneInfoDir(final String homeDir) {
+        try {
+            return AccessController.doPrivileged
+                (new PrivilegedExceptionAction<String>() {
+                    public String run() throws IOException {
+                        File f = new File(homeDir + File.separator + "lib" +
+                                          File.separator + "tz.properties");
+                        InputStream in = new FileInputStream(f);
+                        BufferedInputStream bin = new BufferedInputStream(in);
+                        Properties props = new Properties();
+                        props.load(bin);
+                        bin.close();
+                        String dir = props.getProperty("sun.zoneinfo.dir");
+                        if (dir == null)
+                            return null;
+                        File zim = new File(dir, "ZoneInfoMappings");
+                        if (zim.exists())
+                            return dir;
+                        return null;
+                    }
+                });
+        } catch (PrivilegedActionException e) {
+            return null;
+        }
+    }
+
     /**
      * Converts the given time zone ID to a platform dependent path
      * name. For example, "America/Los_Angeles" is converted to
@@ -1032,8 +1070,8 @@
         byte[] buffer = null;
 
         try {
-            buffer = (byte[]) AccessController.doPrivileged(new PrivilegedExceptionAction() {
-                public Object run() throws IOException {
+            buffer = AccessController.doPrivileged(new PrivilegedExceptionAction<byte[]>() {
+                public byte[] run() throws IOException {
                     File file = new File(ziDir, fileName);
                     if (!file.exists() || !file.isFile()) {
                         return null;