From mboxrd@z Thu Jan 1 00:00:00 1970 Return-path: MIME-Version: 1.0 References: In-Reply-To: From: Jon Ringle Date: Mon, 20 Apr 2020 14:16:30 -0400 Message-ID: Subject: Re: [ptxdist] reproducible timestamps in ipkg package List-Id: PTXdist Development Mailing List List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: ptxdist@pengutronix.de Content-Type: multipart/mixed; boundary="===============0739011928==" Errors-To: ptxdist-bounces@pengutronix.de Sender: "ptxdist" To: ptxdist@pengutronix.com --===============0739011928== Content-Type: multipart/alternative; boundary="0000000000009d87d005a3bce659" --0000000000009d87d005a3bce659 Content-Type: text/plain; charset="UTF-8" On Mon, Apr 20, 2020 at 12:28 PM Jon Ringle wrote: > I am having an issue where the timestamps for the files in the ipkg have > the current timestamp instead of the reproducible timestamp coming from > SOURCE_DATE_EPOCH. > I added a debug log message to ptxd_install_fixup_timestamps() found in > scripts/lib/ptxd_make_xpkg_pkg.sh to show the timestamp being used: > > ptxd_install_fixup_timestamps() { > local timestamp="@${SOURCE_DATE_EPOCH}" > local touch_args > if touch --help | grep -q -- --no-dereference &> /dev/null; then > touch_args="--no-dereference" > fi > > echo "ptxd_install_fixup_timestamps ${timestamp} ($(date > --date=${timestamp}))" > find "${1}" -print0 | xargs -0 touch ${touch_args} -c -d "${timestamp}" > } > > I am currently using ptxdist-2019.11.0, and I get the expected result when > directly printing SOURCE_DATE_EPOCH: > $ ptxdist print SOURCE_DATE_EPOCH > 1572566400 > $ date --date=@$(ptxdist print SOURCE_DATE_EPOCH) > Fri Nov 1 00:00:00 UTC 2019 > > However, the debug output I added to ptxd_install_fixup_timestamps() > produces this output that corresponds to the current datetime: > ptxd_install_fixup_timestamps @1587399767 (Mon Apr 20 16:22:47 UTC 2020) > > Ok... I found that this behavior is being caused by this code in ptxd_make_world_init(): # # check if we shall use a local work-in-progress tree instead # of the configured URL. # # If a link in local_src/