Makes the timestamp in the properties files header reproducible when SOURCE_DATE_EPOC...
authorEmmanuel Bourg <ebourg@apache.org>
Sat, 16 Sep 2023 11:35:34 +0000 (12:35 +0100)
committerMatthias Klose <doko@ubuntu.com>
Sat, 16 Sep 2023 11:35:34 +0000 (12:35 +0100)
Forwarded: no

Gbp-Pq: Name reproducible-properties-timestamp.diff

src/java.base/share/classes/java/util/Properties.java

index 21b2982b82c86fa8b40aa25b82c05fbbf18b9311..9e466b9fba70aef43f96f659f7c5885927717e81 100644 (file)
@@ -903,7 +903,7 @@ public class Properties extends Hashtable<Object,Object> {
         if (comments != null) {
             writeComments(bw, comments);
         }
-        bw.write("#" + new Date().toString());
+        bw.write("#" + getFormattedTimestamp());
         bw.newLine();
         synchronized (this) {
             for (Map.Entry<Object, Object> e : entrySet()) {
@@ -1555,4 +1555,22 @@ public class Properties extends Hashtable<Object,Object> {
         }
         this.map = map;
     }
+
+    /**
+     * Returns a formatted timestamp to be used in the properties file header.
+     * The date used is the current date, unless the SOURCE_DATE_EPOCH
+     * environment variable is specified. In this case the format used is
+     * locale and timezone insensitive to ensure the output is reproducible.
+     */
+    private String getFormattedTimestamp() {
+        if (System.getenv("SOURCE_DATE_EPOCH") == null) {
+            return new Date().toString();
+        } else {
+            // Use the SOURCE_DATE_EPOCH timestamp and make the format locale/timezone insensitive
+            java.text.SimpleDateFormat fmt = new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss z", java.util.Locale.ENGLISH);
+            fmt.setTimeZone(java.util.TimeZone.getTimeZone("UTC"));
+            Date date = new Date(1000 * Long.parseLong(System.getenv("SOURCE_DATE_EPOCH")));
+            return fmt.format(date);
+        }
+    }
 }