Script 'mail_helper' called by obssrc
Hello community,

here is the log from the commit of package maven for openSUSE:Factory checked 
in at 2023-09-06 18:56:48
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/maven (Old)
 and      /work/SRC/openSUSE:Factory/.maven.new.1766 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "maven"

Wed Sep  6 18:56:48 2023 rev:18 rq:1108981 version:3.9.2

Changes:
--------
--- /work/SRC/openSUSE:Factory/maven/maven.changes      2023-06-20 
16:48:36.579452038 +0200
+++ /work/SRC/openSUSE:Factory/.maven.new.1766/maven.changes    2023-09-06 
18:58:31.724276213 +0200
@@ -1,0 +2,7 @@
+Mon Sep  4 15:13:23 UTC 2023 - Fridrich Strba <fst...@suse.com>
+
+- Added patch:
+  * 0005-Reproducible-maven.build.timestamp.patch
+    + debian patch to make maven builds more reproducible
+
+-------------------------------------------------------------------

New:
----
  0005-Reproducible-maven.build.timestamp.patch

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ maven.spec ++++++
--- /var/tmp/diff_new_pack.JZSgva/_old  2023-09-06 18:58:33.268331256 +0200
+++ /var/tmp/diff_new_pack.JZSgva/_new  2023-09-06 18:58:33.272331398 +0200
@@ -37,6 +37,7 @@
 Patch2:         0002-Invoke-logback-via-reflection.patch
 Patch3:         0003-Remove-dependency-on-powermock.patch
 Patch4:         0004-Fix-build-with-qdox-2.0.1.patch
+Patch5:         0005-Reproducible-maven.build.timestamp.patch
 BuildRequires:  ant
 BuildRequires:  aopalliance
 BuildRequires:  apache-commons-cli
@@ -182,6 +183,7 @@
 %patch2 -p1
 %patch3 -p1
 %patch4 -p1
+%patch5 -p1
 
 # not really used during build, but a precaution
 find -name '*.jar' -not -path '*/test/*' -delete

++++++ 0005-Reproducible-maven.build.timestamp.patch ++++++
>From 599dc0284287da5d48f578f5fe90b84dd4e0e485 Mon Sep 17 00:00:00 2001
From: Emmanuel Bourg <ebo...@apache.org>
Date: Mon, 4 Sep 2023 17:10:19 +0200
Subject: [PATCH 5/5] Reproducible maven.build.timestamp

Set the maven.build.timestamp variable to the date defined by
the SOURCE_DATE_EPOCH environment variable to make the Maven
builds reproducible.
---
 .../interpolation/BuildTimestampValueSource.java       | 10 +++++++++-
 .../maven/model/interpolation/MavenBuildTimestamp.java | 10 +++++++++-
 2 files changed, 18 insertions(+), 2 deletions(-)

diff --git 
a/maven-compat/src/main/java/org/apache/maven/project/interpolation/BuildTimestampValueSource.java
 
b/maven-compat/src/main/java/org/apache/maven/project/interpolation/BuildTimestampValueSource.java
index f2af8036a..9e0db2cb0 100644
--- 
a/maven-compat/src/main/java/org/apache/maven/project/interpolation/BuildTimestampValueSource.java
+++ 
b/maven-compat/src/main/java/org/apache/maven/project/interpolation/BuildTimestampValueSource.java
@@ -44,7 +44,15 @@ public BuildTimestampValueSource(Date startTime, String 
format) {
     public Object getValue(String expression) {
         if ("build.timestamp".equals(expression) || 
"maven.build.timestamp".equals(expression)) {
             if (formattedDate == null && startTime != null) {
-                formattedDate = new SimpleDateFormat(format).format(startTime);
+                if ( System.getenv( "SOURCE_DATE_EPOCH" ) == null ) {
+                    formattedDate = new SimpleDateFormat( format ).format( 
startTime );
+                } else {
+                    // Use the SOURCE_DATE_EPOCH timestamp and make the format 
locale insensitive
+                    SimpleDateFormat fmt = new SimpleDateFormat( format, 
java.util.Locale.ENGLISH );
+                    fmt.setTimeZone( java.util.TimeZone.getTimeZone( "UTC" ) );
+                    Date date = new Date( 1000 * Long.parseLong( 
System.getenv( "SOURCE_DATE_EPOCH" ) ) );
+                    formattedDate = fmt.format( date );
+                }
             }
 
             return formattedDate;
diff --git 
a/maven-model-builder/src/main/java/org/apache/maven/model/interpolation/MavenBuildTimestamp.java
 
b/maven-model-builder/src/main/java/org/apache/maven/model/interpolation/MavenBuildTimestamp.java
index e1721334f..2ea2ce381 100644
--- 
a/maven-model-builder/src/main/java/org/apache/maven/model/interpolation/MavenBuildTimestamp.java
+++ 
b/maven-model-builder/src/main/java/org/apache/maven/model/interpolation/MavenBuildTimestamp.java
@@ -21,6 +21,7 @@
 import java.text.SimpleDateFormat;
 import java.util.Date;
 import java.util.GregorianCalendar;
+import java.util.Locale;
 import java.util.Properties;
 import java.util.TimeZone;
 
@@ -56,7 +57,14 @@ public MavenBuildTimestamp(Date time, String 
timestampFormat) {
         if (time == null) {
             time = new Date();
         }
-        SimpleDateFormat dateFormat = new SimpleDateFormat(timestampFormat);
+
+        Locale locale = Locale.getDefault();
+        if ( System.getenv( "SOURCE_DATE_EPOCH" ) != null ) {
+            time = new Date( 1000 * Long.parseLong( System.getenv( 
"SOURCE_DATE_EPOCH" ) ) );
+            locale = Locale.ENGLISH;
+        }
+
+        SimpleDateFormat dateFormat = new SimpleDateFormat( timestampFormat, 
locale );
         dateFormat.setCalendar(new GregorianCalendar());
         dateFormat.setTimeZone(DEFAULT_BUILD_TIME_ZONE);
         formattedTimestamp = dateFormat.format(time);
-- 
2.42.0

Reply via email to