[Reproducible-builds] [pdftex] Please make the CreationDate, ModDate and ID field deterministic

Maria Valentina Marin marivalenm at gmail.com
Wed Aug 12 11:08:35 UTC 2015


Hi,

On 07/14/2015 12:39 AM, Karl Berry wrote:
> Thanh is away for ~3 weeks.  He will review both the SOURCE_DATE_EPOCH
> patch (which I suspect will be fine) and Nicolas's other comments when
> he's back.

In addition to my patch to honour $SOURCE_DATE_EPOCH please find
attached an additional patch which uses UTC in the printed timestamps to
also make the timezone reproducible.

I have patched the function makepdftime to use gmtime if
$SOURCE_DATE_EPOCH is set. Otherwise the old behaviour will be kept.

I have tested the patch in our autobuilders against 4 Debian packages
that use pdflatex and these become reproducible.

Cheers,
akira

-------------- next part --------------
Description: Use gmtime instead of localtime to produce timezone independent output if SOURCE_DATE_EPOCH is set

--- a/texk/web2c/lib/texmfmp.c
+++ b/texk/web2c/lib/texmfmp.c
@@ -2876,7 +2876,7 @@ char start_time_str[TIME_STR_SIZE];
 static char time_str[TIME_STR_SIZE];
     /* minimum size for time_str is 24: "D:YYYYmmddHHMMSS+HH'MM'" */
 
-static void makepdftime(time_t t, char *time_str)
+static void makepdftime(time_t t, char *time_str, int utc)
 {
 
     struct tm lt, gmt;
@@ -2884,7 +2884,12 @@ static void makepdftime(time_t t, char *
     int i, off, off_hours, off_mins;
 
     /* get the time */
-    lt = *localtime(&t);
+    if (utc){
+        lt = *gmtime(&t);
+    }
+    else {
+        lt = *localtime(&t);
+    }
     size = strftime(time_str, TIME_STR_SIZE, "D:%Y%m%d%H%M%S", &lt);
     /* expected format: "YYYYmmddHHMMSS" */
     if (size == 0) {
@@ -2958,11 +2963,12 @@ void initstarttime(void)
 			uexit(EXIT_FAILURE);
 		}
 		start_time = epoch;
+		makepdftime(start_time, start_time_str, 1);
 	}
 	else {
 		start_time = time((time_t *) NULL);
+		makepdftime(start_time, start_time_str, 0);
 	}
-        makepdftime(start_time, start_time_str);
     }
 }
 
@@ -3049,7 +3055,7 @@ void getfilemoddate(integer s)
     if (stat(file_name, &file_data) == 0) {
         size_t len;
 
-        makepdftime(file_data.st_mtime, time_str);
+        makepdftime(file_data.st_mtime, time_str, 0);
         len = strlen(time_str);
         if ((unsigned) (poolptr + len) >= (unsigned) (poolsize)) {
             poolptr = poolsize;

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: OpenPGP digital signature
URL: <http://lists.alioth.debian.org/pipermail/reproducible-builds/attachments/20150812/2082a9e9/attachment.sig>


More information about the Reproducible-builds mailing list