[Reproducible-commits] [doxygen] 01/02: Make doxygen produce reproducible output
Reiner Herrmann
reiner at reiner-h.de
Sat Feb 13 11:08:24 UTC 2016
This is an automated email from the git hooks/post-receive script.
deki-guest pushed a commit to branch pu/reproducible_builds
in repository doxygen.
commit 574396b00c0fa20a7427ee2e9ccb51ebaab6b1a5
Author: akira <marivalenm at gmail.com>
Date: Sun Jul 5 22:06:00 2015 +0200
Make doxygen produce reproducible output
- Honour $SOURCE_DATE_EPOCH
- Modified function to produce timezone independent timestamps using UTC
---
debian/changelog | 12 ++
...CE_DATE_EPOCH-environment-variable-for-re.patch | 150 +++++++++++++++++++++
...tion-to-produce-timezone-independent-timestamps | 13 ++
debian/patches/series | 2 +
4 files changed, 177 insertions(+)
diff --git a/debian/changelog b/debian/changelog
index 8db0f72..eb25291 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -1,3 +1,15 @@
+doxygen (1.8.11-1.0~reproducible1) UNRELEASED; urgency=low
+
+ [ akira ]
+ * Non-maintainer upload.
+ * Applied upstream commit
+ https://github.com/doxygen/doxygen/commit/b31266c1076c6284116f17241d9e8aa048f88e60
+ which honours $SOURCE_DATE_EPOCH
+ * Modified function QDateTime::setTime_t to produce timezone independent
+ timestamps by using UTC
+
+ -- Reiner Herrmann <reiner at reiner-h.de> Sat, 13 Feb 2016 11:57:57 +0100
+
doxygen (1.8.11-1) unstable; urgency=medium
* Upload to unstable.
diff --git a/debian/patches/0001-Honour-SOURCE_DATE_EPOCH-environment-variable-for-re.patch b/debian/patches/0001-Honour-SOURCE_DATE_EPOCH-environment-variable-for-re.patch
new file mode 100644
index 0000000..ce64aed
--- /dev/null
+++ b/debian/patches/0001-Honour-SOURCE_DATE_EPOCH-environment-variable-for-re.patch
@@ -0,0 +1,150 @@
+commit b31266c1076c6284116f17241d9e8aa048f88e60
+Author: Dimitri van Heesch <dimitri at stack.nl>
+Date: Sun Jul 19 12:12:39 2015 +0200
+
+ Bug 751984 - PATCH: Honour SOURCE_DATE_EPOCH environment variable for reproducible output
+
+--- a/qtools/qcstring.cpp
++++ b/qtools/qcstring.cpp
+@@ -460,6 +460,12 @@ ulong QCString::toULong(bool *ok) const
+ return s.toULong(ok);
+ }
+
++uint64 QCString::toUInt64(bool *ok) const
++{
++ QString s(data());
++ return s.toUInt64(ok);
++}
++
+ QCString &QCString::setNum(short n)
+ {
+ return setNum((long)n);
+--- a/qtools/qcstring.h
++++ b/qtools/qcstring.h
+@@ -288,6 +288,7 @@ public:
+ uint toUInt( bool *ok=0 ) const;
+ long toLong( bool *ok=0 ) const;
+ ulong toULong( bool *ok=0 ) const;
++ uint64 toUInt64( bool *ok=0 ) const;
+ QCString &setNum(short n);
+ QCString &setNum(ushort n);
+ QCString &setNum(int n);
+--- a/qtools/qstring.cpp
++++ b/qtools/qstring.cpp
+@@ -13935,6 +13935,60 @@ bye:
+ }
+
+ /*!
++ Returns the string converted to an <code>unsigned long</code>
++ value.
++
++ If \a ok is non-null, \a *ok is set to TRUE if there are no
++ conceivable errors, and FALSE if the string is not a number at all,
++ or if it has trailing garbage.
++*/
++
++uint64 QString::toUInt64( bool *ok, int base ) const
++{
++ const QChar *p = unicode();
++ uint64 val=0;
++ int l = length();
++ const uint64 max_mult = 1844674407370955161ULL; // ULLONG_MAX/10, rounded down
++ bool is_ok = FALSE;
++ if ( !p )
++ goto bye;
++ while ( l && p->isSpace() ) // skip leading space
++ l--,p++;
++ if ( *p == '+' )
++ l--,p++;
++
++ // NOTE: toULong() code is similar
++ if ( !l || !ok_in_base(*p,base) )
++ goto bye;
++ while ( l && ok_in_base(*p,base) ) {
++ l--;
++ uint dv;
++ if ( p->isDigit() ) {
++ dv = p->digitValue();
++ } else {
++ if ( *p >= 'a' && *p <= 'z' )
++ dv = *p - 'a' + 10;
++ else
++ dv = *p - 'A' + 10;
++ }
++ if ( val > max_mult || (val == max_mult && dv > (ULLONG_MAX%base)) )
++ goto bye;
++ val = base*val + dv;
++ p++;
++ }
++
++ while ( l && p->isSpace() ) // skip trailing space
++ l--,p++;
++ if ( !l )
++ is_ok = TRUE;
++bye:
++ if ( ok )
++ *ok = is_ok;
++ return is_ok ? val : 0;
++}
++
++
++/*!
+ Returns the string converted to a <code>short</code> value.
+
+ If \a ok is non-null, \a *ok is set to TRUE if there are no
+--- a/qtools/qstring.h
++++ b/qtools/qstring.h
+@@ -463,6 +463,7 @@ public:
+ uint toUInt( bool *ok=0, int base=10 ) const;
+ long toLong( bool *ok=0, int base=10 ) const;
+ ulong toULong( bool *ok=0, int base=10 ) const;
++ uint64 toUInt64( bool *ok=0, int base=10 ) const;
+ float toFloat( bool *ok=0 ) const;
+ double toDouble( bool *ok=0 ) const;
+
+--- a/src/util.cpp
++++ b/src/util.cpp
+@@ -18,6 +18,7 @@
+ #include <ctype.h>
+ #include <errno.h>
+ #include <math.h>
++#include <limits.h>
+
+ #include "md5.h"
+
+@@ -2461,6 +2462,35 @@ QCString fileToString(const char *name,b
+ QCString dateToString(bool includeTime)
+ {
+ QDateTime current = QDateTime::currentDateTime();
++ QCString sourceDateEpoch = portable_getenv("SOURCE_DATE_EPOCH");
++ if (!sourceDateEpoch.isEmpty())
++ {
++ bool ok;
++ uint64 epoch = sourceDateEpoch.toUInt64(&ok);
++ if (!ok)
++ {
++ static bool warnedOnce=FALSE;
++ if (!warnedOnce)
++ {
++ warn_uncond("Environment variable SOURCE_DATE_EPOCH does not contain a valid number; value is '%s'\n",
++ sourceDateEpoch.data());
++ warnedOnce=TRUE;
++ }
++ }
++ else if (epoch>UINT_MAX)
++ {
++ static bool warnedOnce=FALSE;
++ if (!warnedOnce)
++ {
++ warn_uncond("Environment variable SOURCE_DATA_EPOCH must have a value smaller than or equal to %llu; actual value %llu\n",UINT_MAX,epoch);
++ warnedOnce=TRUE;
++ }
++ }
++ else // all ok, replace current time with epoch value
++ {
++ current.setTime_t((ulong)epoch); // TODO: add support for 64bit epoch value
++ }
++ }
+ return theTranslator->trDateTime(current.date().year(),
+ current.date().month(),
+ current.date().day(),
diff --git a/debian/patches/Modified-function-to-produce-timezone-independent-timestamps b/debian/patches/Modified-function-to-produce-timezone-independent-timestamps
new file mode 100644
index 0000000..e36c01f
--- /dev/null
+++ b/debian/patches/Modified-function-to-produce-timezone-independent-timestamps
@@ -0,0 +1,13 @@
+Description: Modified function QDateTime::setTime_t to produce timezone independent timestamps by using UTC
+
+--- doxygen-1.8.9.1.orig/qtools/qdatetime.cpp
++++ doxygen-1.8.9.1/qtools/qdatetime.cpp
+@@ -1142,7 +1142,7 @@ QDateTime::QDateTime( const QDate &date,
+ void QDateTime::setTime_t( uint secsSince1Jan1970UTC )
+ {
+ time_t tmp = (time_t) secsSince1Jan1970UTC;
+- tm *tM = localtime( &tmp );
++ tm *tM = gmtime( &tmp );
+ if ( !tM ) {
+ tM = gmtime( &tmp );
+ if ( !tM ) {
diff --git a/debian/patches/series b/debian/patches/series
index dc487ba..750893d 100644
--- a/debian/patches/series
+++ b/debian/patches/series
@@ -9,3 +9,5 @@ no-timestamps.diff
no-rpath.diff
issue759241.diff
pyversion.diff
+0001-Honour-SOURCE_DATE_EPOCH-environment-variable-for-re.patch
+Modified-function-to-produce-timezone-independent-timestamps
--
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/reproducible/doxygen.git
More information about the Reproducible-commits
mailing list