diff --git a/src/apk_defines.h b/src/apk_defines.h index f1b0f8d64a5e086e27686b5875ee847f8d55d1b7..371680281323efa5e035339e97bb3320ba2ddf80 100644 --- a/src/apk_defines.h +++ b/src/apk_defines.h @@ -177,6 +177,8 @@ static inline uint32_t get_unaligned32(const void *ptr) typedef void (*apk_progress_cb)(void *cb_ctx, size_t); +time_t apk_get_build_time(void); + void *apk_array_resize(void *array, size_t new_size, size_t elem_size); #define APK_ARRAY(array_type_name, elem_type_name) \ diff --git a/src/common.c b/src/common.c index 14a56a3aaafbf13f2474fcb9361ceb96976f6def..580e6d58ce290aeae7d1bc63689d098c313e85bc 100644 --- a/src/common.c +++ b/src/common.c @@ -40,3 +40,18 @@ void *apk_array_resize(void *array, size_t new_size, size_t elem_size) return tmp; } + +time_t apk_get_build_time(void) +{ + static int initialized = 0; + static time_t timestamp = 0; + char *source_date_epoch; + + if (initialized) return timestamp; + source_date_epoch = getenv("SOURCE_DATE_EPOCH"); + if (source_date_epoch && *source_date_epoch) + timestamp = strtoull(source_date_epoch, NULL, 10); + else timestamp = time(NULL); + initialized = 1; + return timestamp; +} diff --git a/src/io_archive.c b/src/io_archive.c index ccd512abdaf0b2dc7509c2f32536b36a9af91e35..bfa8efa6a9f6b8828dc3bca711b52ba8b1b8c619 100644 --- a/src/io_archive.c +++ b/src/io_archive.c @@ -291,7 +291,7 @@ int apk_tar_write_entry(struct apk_ostream *os, const struct apk_file_info *ae, PUT_OCTAL(buf.uid, ae->uid); PUT_OCTAL(buf.gid, ae->gid); PUT_OCTAL(buf.mode, ae->mode & 07777); - PUT_OCTAL(buf.mtime, ae->mtime ?: time(NULL)); + PUT_OCTAL(buf.mtime, ae->mtime ?: apk_get_build_time()); /* Checksum */ strcpy(buf.magic, "ustar ");