aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2016-01-31 23:29:07 +0000
committerFelix Fietkau <nbd@openwrt.org>2016-01-31 23:29:07 +0000
commit82522dbaee8cd5f94267ebf465e36d594e4d2d7a (patch)
tree55e38cbaf9c180aa794549777d4f640315bbdf87
parent2f14514a12f708fecbe786e028fb9e3c542907da (diff)
downloadupstream-82522dbaee8cd5f94267ebf465e36d594e4d2d7a.tar.gz
upstream-82522dbaee8cd5f94267ebf465e36d594e4d2d7a.tar.bz2
upstream-82522dbaee8cd5f94267ebf465e36d594e4d2d7a.zip
build: introduce SOURCE_DATE_EPOCH variable
SOURCE_DATE_EPOCH is the date of the last modified file using git/svn as date source. See https://reproducible-builds.org/specs/source-date-epoch/ Signed-off-by: Alexander Couzens <lynxis@fe80.eu> Signed-off-by: Felix Fietkau <nbd@openwrt.org> SVN-Revision: 48584
-rw-r--r--include/toplevel.mk1
-rwxr-xr-xscripts/get_source_date_epoch.sh31
2 files changed, 32 insertions, 0 deletions
diff --git a/include/toplevel.mk b/include/toplevel.mk
index 0cba07c6e6..97093021ba 100644
--- a/include/toplevel.mk
+++ b/include/toplevel.mk
@@ -24,6 +24,7 @@ export RELEASE
export REVISION
export GIT_CONFIG_PARAMETERS='core.autocrlf=false'
export MAKE_JOBSERVER=$(filter --jobserver%,$(MAKEFLAGS))
+export SOURCE_DATE_EPOCH:=$(shell $(TOPDIR)/scripts/get_source_date_epoch.sh)
# prevent perforce from messing with the patch utility
unexport P4PORT P4USER P4CONFIG P4CLIENT
diff --git a/scripts/get_source_date_epoch.sh b/scripts/get_source_date_epoch.sh
new file mode 100755
index 0000000000..b8efb761d0
--- /dev/null
+++ b/scripts/get_source_date_epoch.sh
@@ -0,0 +1,31 @@
+#!/usr/bin/env bash
+export LANG=C
+export LC_ALL=C
+[ -n "$TOPDIR" ] && cd $TOPDIR
+
+try_version() {
+ [ -f version.date ] || return 1
+ SOURCE_DATE_EPOCH="$(cat version.date)"
+ [ -n "$SOURCE_DATE_EPOCH" ]
+}
+
+try_svn() {
+ [ -d .svn ] || return 1
+ SOURCE_DATE_EPOCH="$(./scripts/portable_date.sh "$(svn info --show-item last-changed-date)" +%s)"
+ [ -n "$SOURCE_DATE_EPOCH" ]
+}
+
+try_git() {
+ [ -e .git ] || return 1
+ SOURCE_DATE_EPOCH="$(git log -1 --format=format:%ct)"
+ [ -n "$SOURCE_DATE_EPOCH" ]
+}
+
+try_hg() {
+ [ -d .hg ] || return 1
+ SOURCE_DATE_EPOCH=""
+ [ -n "$SOURCE_DATE_EPOCH" ]
+}
+
+try_version || try_svn || try_git || try_hg || SOURCE_DATE_EPOCH=""
+echo "$SOURCE_DATE_EPOCH"