public inbox for isar-users@googlegroups.com
 help / color / mirror / Atom feed
From: Uladzimir Bely <ubely@ilbers.de>
To: chris.larson@siemens.com, isar-users@googlegroups.com
Cc: Cedric Hombourger <cedric.hombourger@siemens.com>
Subject: Re: [PATCH 0/3] Add 'customization' package support
Date: Tue, 25 Mar 2025 19:55:55 +0300	[thread overview]
Message-ID: <c803fd2222c402dc168d6ca016f14692a1b8494f.camel@ilbers.de> (raw)
In-Reply-To: <20250311210939.4090-1-chris.larson@siemens.com>

On Tue, 2025-03-11 at 14:09 -0700, chris.larson via isar-users wrote:
> From: Christopher Larson <chris.larson@siemens.com>
> 
> A number of downstream layers have customization dpkg-raw recipes
> making use of
> template variables to support build-time settings: add the
> infrastructure to
> Isar to help uniformization of such recipes. Settings are often
> specific to a
> DISTRO, MACHINE or IMAGE: provide a mechanism to decorate (prefix or
> suffix)
> packages being constructed and pulled into the image. This helps use
> of
> customization packages in multiconfig builds but also with the
> deployment of
> binary package feeds for projects supporting multiple variants.
> 
> To create a customization package, a recipe must inherit the
> `dpkg-customization` bbclass. By default, images will inherit the
> `image-customizations` class, which will install the package for any
> customizations listed in `CUSTOMIZATIONS`.
> 
> To add variables to the customization package names, beyond the
> default DISTRO
> and MACHINE, add them to `CUSTOMIZATION_VARS` as variable references
> (`${DISTRO}`, `${MACHINE}`). By default, these variables are appended
> to the
> package name, but if they should be prefixed, add them to
> `CUSTOMIZATION_VARS_PREFIXED`. By default, the `DISTRO` and `MACHINE`
> variables
> are used, and the `DISTRO` is prefixed, while the `MACHINE` is
> suffixed.
> 
> To enable support for per-image changes, and per-image customization
> packages,
> add the image name to `CUSTOMIZATION_FOR_IMAGES`. In the
> customization package
> recipe, the `IMAGE` variable will be set to the image name, and the
> package name
> will be decorated with the image name. The `IMAGE` will also be added
> to the
> `OVERRIDES`, allowing for variable definitions like this in the
> customization
> recipe:
> 
>     HOSTNAME:isar-image-ci = "isar-ci"
> 
> When `CUSTOMIZATION_FOR_IMAGES` is defined, `${IMAGE}` will be
> implicitly added
> to `CUSTOMIZATION_VARS`, and the package will be decorated with the
> image name.
> 
> An example `hostname` customization recipe/package is provided, as is
> an
> initial unit test to verify the functionality of this customization.
> 
> Christopher Larson (3):
>   classes: add 'customization' package support
>   hostname-customization: add initial customization package
>   testsuite: add 'customizations' test
> 
>  meta/classes/customization-base.bbclass       | 21 +++++++++++
>  meta/classes/dpkg-customization.bbclass       | 37
> +++++++++++++++++++
>  meta/classes/image-customizations.bbclass     | 30 +++++++++++++++
>  meta/classes/image.bbclass                    |  1 +
>  .../customizations/hostname-customization.bb  | 11 ++++++
>  .../hostname-customization/postinst.tmpl      |  5 +++
>  testsuite/cibuilder.py                        |  9 +++++
>  testsuite/citest.py                           | 21 +++++++++++
>  8 files changed, 135 insertions(+)
>  create mode 100644 meta/classes/customization-base.bbclass
>  create mode 100644 meta/classes/dpkg-customization.bbclass
>  create mode 100644 meta/classes/image-customizations.bbclass
>  create mode 100644 meta/recipes-support/customizations/hostname-
> customization.bb
>  create mode 100644 meta/recipes-support/customizations/hostname-
> customization/postinst.tmpl
> 
> -- 
> 2.47.2

Applied to next, thanks.

-- 
Best regards,
Uladzimir.


-- 
You received this message because you are subscribed to the Google Groups "isar-users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to isar-users+unsubscribe@googlegroups.com.
To view this discussion visit https://groups.google.com/d/msgid/isar-users/c803fd2222c402dc168d6ca016f14692a1b8494f.camel%40ilbers.de.

      parent reply	other threads:[~2025-03-25 16:56 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-03-11 21:09 chris.larson via isar-users
2025-03-11 21:09 ` [PATCH 1/3] classes: add " chris.larson via isar-users
2025-03-11 21:09 ` [PATCH 2/3] hostname-customization: add initial customization package chris.larson via isar-users
2025-03-11 21:09 ` [PATCH 3/3] testsuite: add 'customizations' test chris.larson via isar-users
2025-03-25 16:55 ` Uladzimir Bely [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=c803fd2222c402dc168d6ca016f14692a1b8494f.camel@ilbers.de \
    --to=ubely@ilbers.de \
    --cc=cedric.hombourger@siemens.com \
    --cc=chris.larson@siemens.com \
    --cc=isar-users@googlegroups.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox