* [PATCH v2 1/2] buildhistory: simplify buildhistory_list_files()
@ 2019-01-09 20:30 Jacob Kroon
2019-01-09 20:30 ` [PATCH v2 2/2] buildhistory: support generating sha256 checksums of regular files Jacob Kroon
0 siblings, 1 reply; 3+ messages in thread
From: Jacob Kroon @ 2019-01-09 20:30 UTC (permalink / raw)
To: openembedded-core
Avoid duplicating shell code for the two cases, fakeroot/non-fakeroot.
Signed-off-by: Jacob Kroon <jacob.kroon@gmail.com>
---
meta/classes/buildhistory.bbclass | 10 ++++++----
1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/meta/classes/buildhistory.bbclass b/meta/classes/buildhistory.bbclass
index d1f3e6aa82..33eb1b00f6 100644
--- a/meta/classes/buildhistory.bbclass
+++ b/meta/classes/buildhistory.bbclass
@@ -519,12 +519,14 @@ buildhistory_get_sdk_installed_target() {
buildhistory_list_files() {
# List the files in the specified directory, but exclude date/time etc.
- # This awk script is somewhat messy, but handles where the size is not printed for device files under pseudo
+ # This is somewhat messy, but handles where the size is not printed for device files under pseudo
+ ( cd $1
+ find_cmd='find . ! -path . -printf "%M %-10u %-10g %10s %p -> %l\n"'
if [ "$3" = "fakeroot" ] ; then
- ( cd $1 && ${FAKEROOTENV} ${FAKEROOTCMD} find . ! -path . -printf "%M %-10u %-10g %10s %p -> %l\n" | sort -k5 | sed 's/ * -> $//' > $2 )
+ eval ${FAKEROOTENV} ${FAKEROOTCMD} $find_cmd
else
- ( cd $1 && find . ! -path . -printf "%M %-10u %-10g %10s %p -> %l\n" | sort -k5 | sed 's/ * -> $//' > $2 )
- fi
+ eval $find_cmd
+ fi | sort -k5 | sed 's/ * -> $//' > $2 )
}
buildhistory_list_pkg_files() {
--
2.11.0
^ permalink raw reply related [flat|nested] 3+ messages in thread* [PATCH v2 2/2] buildhistory: support generating sha256 checksums of regular files
2019-01-09 20:30 [PATCH v2 1/2] buildhistory: simplify buildhistory_list_files() Jacob Kroon
@ 2019-01-09 20:30 ` Jacob Kroon
2019-01-12 19:35 ` Jacob Kroon
0 siblings, 1 reply; 3+ messages in thread
From: Jacob Kroon @ 2019-01-09 20:30 UTC (permalink / raw)
To: openembedded-core
Introduce 'sha256' in BUILDHISTORY_FEATURES and enable it by default
when doing reproducible builds.
When enabled this will additionally create:
files-in-package-sha256.txt
files-in-image-sha256.txt
files-in-sdk-sha256.txt
containing the sha256 checksums of regular files.
Signed-off-by: Jacob Kroon <jacob.kroon@gmail.com>
---
meta/classes/buildhistory.bbclass | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
Changes in v2:
* Switch to sha256
* Let find only build the arguments and execute sha256sum once
* Use single quotes in inline python code
diff --git a/meta/classes/buildhistory.bbclass b/meta/classes/buildhistory.bbclass
index 33eb1b00f6..84f85da0bd 100644
--- a/meta/classes/buildhistory.bbclass
+++ b/meta/classes/buildhistory.bbclass
@@ -7,7 +7,8 @@
# Copyright (C) 2007-2011 Koen Kooi <koen@openembedded.org>
#
-BUILDHISTORY_FEATURES ?= "image package sdk"
+BUILDHISTORY_FEATURES ?= "image package sdk \
+ ${@ 'sha256' if bb.utils.to_boolean(d.getVar('BUILD_REPRODUCIBLE_BINARIES')) else ''}"
BUILDHISTORY_DIR ?= "${TOPDIR}/buildhistory"
BUILDHISTORY_DIR_IMAGE = "${BUILDHISTORY_DIR}/images/${MACHINE_ARCH}/${TCLIBC}/${IMAGE_BASENAME}"
BUILDHISTORY_DIR_PACKAGE = "${BUILDHISTORY_DIR}/packages/${MULTIMACH_TARGET_SYS}/${PN}"
@@ -526,7 +527,12 @@ buildhistory_list_files() {
eval ${FAKEROOTENV} ${FAKEROOTCMD} $find_cmd
else
eval $find_cmd
- fi | sort -k5 | sed 's/ * -> $//' > $2 )
+ fi | sort -k5 | sed 's/ * -> $//' > $2
+ if [ "${@bb.utils.contains('BUILDHISTORY_FEATURES', 'sha256', '1', '0', d)}" = "1" ] ; then
+ sha256filename=$(echo $2 | sed 's/\.txt$/-sha256.txt/')
+ find -type f -exec sha256sum {} + | sort -k2 > $sha256filename
+ [ -s $sha256filename ] || rm $sha256filename # remove result if empty
+ fi )
}
buildhistory_list_pkg_files() {
--
2.11.0
^ permalink raw reply related [flat|nested] 3+ messages in thread* Re: [PATCH v2 2/2] buildhistory: support generating sha256 checksums of regular files
2019-01-09 20:30 ` [PATCH v2 2/2] buildhistory: support generating sha256 checksums of regular files Jacob Kroon
@ 2019-01-12 19:35 ` Jacob Kroon
0 siblings, 0 replies; 3+ messages in thread
From: Jacob Kroon @ 2019-01-12 19:35 UTC (permalink / raw)
To: openembedded-core
On Wed, Jan 9, 2019 at 9:31 PM Jacob Kroon <jacob.kroon@gmail.com> wrote:
>
> Introduce 'sha256' in BUILDHISTORY_FEATURES and enable it by default
> when doing reproducible builds.
>
> When enabled this will additionally create:
>
> files-in-package-sha256.txt
> files-in-image-sha256.txt
> files-in-sdk-sha256.txt
>
> containing the sha256 checksums of regular files.
>
> Signed-off-by: Jacob Kroon <jacob.kroon@gmail.com>
> ---
> meta/classes/buildhistory.bbclass | 10 ++++++++--
> 1 file changed, 8 insertions(+), 2 deletions(-)
>
> Changes in v2:
> * Switch to sha256
> * Let find only build the arguments and execute sha256sum once
> * Use single quotes in inline python code
>
> diff --git a/meta/classes/buildhistory.bbclass b/meta/classes/buildhistory.bbclass
> index 33eb1b00f6..84f85da0bd 100644
> --- a/meta/classes/buildhistory.bbclass
> +++ b/meta/classes/buildhistory.bbclass
> @@ -7,7 +7,8 @@
> # Copyright (C) 2007-2011 Koen Kooi <koen@openembedded.org>
> #
>
> -BUILDHISTORY_FEATURES ?= "image package sdk"
> +BUILDHISTORY_FEATURES ?= "image package sdk \
> + ${@ 'sha256' if bb.utils.to_boolean(d.getVar('BUILD_REPRODUCIBLE_BINARIES')) else ''}"
> BUILDHISTORY_DIR ?= "${TOPDIR}/buildhistory"
> BUILDHISTORY_DIR_IMAGE = "${BUILDHISTORY_DIR}/images/${MACHINE_ARCH}/${TCLIBC}/${IMAGE_BASENAME}"
> BUILDHISTORY_DIR_PACKAGE = "${BUILDHISTORY_DIR}/packages/${MULTIMACH_TARGET_SYS}/${PN}"
> @@ -526,7 +527,12 @@ buildhistory_list_files() {
> eval ${FAKEROOTENV} ${FAKEROOTCMD} $find_cmd
> else
> eval $find_cmd
> - fi | sort -k5 | sed 's/ * -> $//' > $2 )
> + fi | sort -k5 | sed 's/ * -> $//' > $2
> + if [ "${@bb.utils.contains('BUILDHISTORY_FEATURES', 'sha256', '1', '0', d)}" = "1" ] ; then
> + sha256filename=$(echo $2 | sed 's/\.txt$/-sha256.txt/')
> + find -type f -exec sha256sum {} + | sort -k2 > $sha256filename
> + [ -s $sha256filename ] || rm $sha256filename # remove result if empty
> + fi )
> }
>
> buildhistory_list_pkg_files() {
> --
> 2.11.0
Ignore this patch, I completely missed the "task"
BUILDHISTORY_FEATURE, which seems to do this already.
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2019-01-12 19:35 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-01-09 20:30 [PATCH v2 1/2] buildhistory: simplify buildhistory_list_files() Jacob Kroon
2019-01-09 20:30 ` [PATCH v2 2/2] buildhistory: support generating sha256 checksums of regular files Jacob Kroon
2019-01-12 19:35 ` Jacob Kroon
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox