Github messages for voidlinux
 help / color / mirror / Atom feed
* [ISSUE] [RFC] set timestamps in a package only for files newer than commit date
@ 2021-08-22 20:57 tornaria
  2021-08-23 18:32 ` Chocimier
                   ` (4 more replies)
  0 siblings, 5 replies; 6+ messages in thread
From: tornaria @ 2021-08-22 20:57 UTC (permalink / raw)
  To: ml

[-- Attachment #1: Type: text/plain, Size: 1427 bytes --]

New issue by tornaria on void-packages repository

https://github.com/void-linux/void-packages/issues/32638

Description:
The hook `pre-pkg/90-set-timestamps.sh` touches all files in a pkg to set the mtimes to the commit date. When a package installs files verbatim from its source, it might make sense to keep the original timestamp. This could be acomplished by using find predicate `-newermt` as in:
```diff
--- a/common/hooks/pre-pkg/90-set-timestamps.sh
+++ b/common/hooks/pre-pkg/90-set-timestamps.sh
@@ -5,6 +5,6 @@ hook() {
        # If SOURCE_DATE_EPOCH is set, set mtimes to that timestamp.
        if [ -n "$SOURCE_DATE_EPOCH" ]; then
                msg_normal "$pkgver: setting mtimes to %s\n" "$(date --date "@$SOURCE_DATE_EPOCH")"
-               find $PKGDESTDIR -print0 | xargs -0 touch -h --date "@$SOURCE_DATE_EPOCH"
+               find $PKGDESTDIR -newermt "@$SOURCE_DATE_EPOCH" -print0 | xargs -0 touch -h --date "@$SOURCE_DATE_EPOCH"
        fi
 }
```

I am thinking on a package like `pari-elldata` which ships only data files from its source. The alternative I found is to set `XBPS_USE_BUILD_MTIME=no` in the template, but (a) that is only good for this pkg because I know all the files in the package have a deterministic timestamp and (b) xlint complains when using this variable.

Rationale: the timestamp of the original files in the source is more canonical than the commit date.

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2021-08-23 23:05 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-08-22 20:57 [ISSUE] [RFC] set timestamps in a package only for files newer than commit date tornaria
2021-08-23 18:32 ` Chocimier
2021-08-23 22:39 ` tornaria
2021-08-23 22:41 ` ericonr
2021-08-23 23:05 ` tornaria
2021-08-23 23:05 ` [ISSUE] [CLOSED] " tornaria

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).