Hi Joshua, Two minor nits below.
On Mon, 2024-06-10 at 15:41 -0600, Joshua Watt wrote: > Downstream tasks may want to know what image files were written by > the > do_image family of tasks (e.g. SPDX) so have each task write out a > manifest file that describes the files it produced, then aggregate > them > in do_image_complete > > Signed-off-by: Joshua Watt <jpewhac...@gmail.com> > --- > meta/classes-recipe/image.bbclass | 61 > +++++++++++++++++++++++++++++++ > 1 file changed, 61 insertions(+) > > diff --git a/meta/classes-recipe/image.bbclass b/meta/classes- > recipe/image.bbclass > index 28be6c63623..122af2b0328 100644 > --- a/meta/classes-recipe/image.bbclass > +++ b/meta/classes-recipe/image.bbclass > @@ -88,6 +88,11 @@ PACKAGE_INSTALL_ATTEMPTONLY ?= > "${FEATURE_INSTALL_OPTIONAL}" > > IMGDEPLOYDIR = "${WORKDIR}/deploy-${PN}-image-complete" > > +IMGMANIFESTDIR = "${WORKDIR}/image-task-manifest" > + > +IMAGE_FILE_MANIFEST_DIR = "${WORKDIR}/deploy-image-file-manifest" > +IMAGE_FILE_MANIFEST = "${IMAGE_FILE_MANIFEST_DIR}/manifest.json" > + > # Images are generally built explicitly, do not need to be part of > world. > EXCLUDE_FROM_WORLD = "1" > > @@ -277,14 +282,31 @@ fakeroot python do_image () { > execute_pre_post_process(d, pre_process_cmds) > } > do_image[dirs] = "${TOPDIR}" > +do_image[cleandirs] = "${IMGMANIFESTDIR}" Should this be an append (i.e. +=) to avoid conflicting with recipes ? > addtask do_image after do_rootfs > > fakeroot python do_image_complete () { > from oe.utils import execute_pre_post_process > + from pathlib import Path > + import json > > post_process_cmds = d.getVar("IMAGE_POSTPROCESS_COMMAND") > > execute_pre_post_process(d, post_process_cmds) > + > + image_manifest_dir = Path(d.getVar('IMGMANIFESTDIR')) > + > + data = [] > + > + for taskname in bb.build.preceedtask("do_image_complete", False, > d): > + manifest_path = image_manifest_dir / (taskname + ".json") > + if not manifest_path.exists(): > + continue > + with manifest_path.open("r") as f: > + data.extend(json.load(f)) > + > + with open(d.getVar("IMAGE_FILE_MANIFEST"), "w") as f: > + json.dump(data, f) > } > do_image_complete[dirs] = "${TOPDIR}" > SSTATETASKS += "do_image_complete" > @@ -292,6 +314,8 @@ SSTATE_SKIP_CREATION:task-image-complete = '1' > do_image_complete[sstate-inputdirs] = "${IMGDEPLOYDIR}" > do_image_complete[sstate-outputdirs] = "${DEPLOY_DIR_IMAGE}" > do_image_complete[stamp-extra-info] = "${MACHINE_ARCH}" > +do_image_complete[sstate-plaindirs] = "${IMAGE_FILE_MANIFEST_DIR}" > +do_image_complete[dirs] = "${IMAGE_FILE_MANIFEST_DIR}" Same here... Thanks, Martin > addtask do_image_complete after do_image before do_build > python do_image_complete_setscene () { > sstate_setscene(d) > @@ -513,6 +537,8 @@ python () { > d.appendVarFlag(task, 'subimages', ' ' + ' > '.join(subimages)) > d.appendVarFlag(task, 'vardeps', ' ' + ' '.join(vardeps)) > d.appendVarFlag(task, 'vardepsexclude', ' DATETIME DATE ' + > ' '.join(vardepsexclude)) > + d.appendVarFlag(task, 'postfuncs', ' > write_image_file_manifest') > + d.appendVarFlag(task, 'dirs', ' ' + > d.getVar('IMGMANIFESTDIR')) > > bb.debug(2, "Adding task %s before %s, after %s" % (task, > 'do_image_complete', after)) > bb.build.addtask(task, 'do_image_complete', after, d) > @@ -610,6 +636,41 @@ python create_symlinks() { > bb.note("Skipping symlink, source does not exist: %s -> > %s" % (dst, src)) > } > > +python write_image_file_manifest() { > + import json > + from pathlib import Path > + > + taskname = d.getVar("BB_CURRENTTASK") > + image_deploy_dir = Path(d.getVar('IMGDEPLOYDIR')) > + image_manifest_dir = Path(d.getVar('IMGMANIFESTDIR')) > + manifest_path = image_manifest_dir / ("do_" + > d.getVar("BB_CURRENTTASK") + ".json") > + > + image_name = d.getVar("IMAGE_NAME") > + image_basename = d.getVar("IMAGE_BASENAME") > + machine = d.getVar("MACHINE") > + > + subimages = (d.getVarFlag("do_" + taskname, 'subimages', False) > or "").split() > + imagetype = d.getVarFlag("do_" + taskname, 'imagetype', False) > + > + data = { > + "taskname": taskname, > + "imagetype": imagetype, > + "images": [] > + } > + > + for type in subimages: > + image_filename = image_name + "." + type > + image_path = image_deploy_dir / image_filename > + if not image_path.exists(): > + continue > + data["images"].append({ > + "filename": image_filename, > + }) > + > + with manifest_path.open("w") as f: > + json.dump([data], f) > +} > + > MULTILIBRE_ALLOW_REP += "${base_bindir} ${base_sbindir} ${bindir} > ${sbindir} ${libexecdir} ${sysconfdir} ${nonarch_base_libdir}/udev > /lib/modules/[^/]*/modules.*" > MULTILIB_CHECK_FILE = "${WORKDIR}/multilib_check.py" > MULTILIB_TEMP_ROOTFS = "${WORKDIR}/multilib" > > >
-=-=-=-=-=-=-=-=-=-=-=- Links: You receive all messages sent to this group. View/Reply Online (#200495): https://lists.openembedded.org/g/openembedded-core/message/200495 Mute This Topic: https://lists.openembedded.org/mt/106602515/21656 Group Owner: openembedded-core+ow...@lists.openembedded.org Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [arch...@mail-archive.com] -=-=-=-=-=-=-=-=-=-=-=-