* [PATCH v2 1/4] conf: Enable bbappends
2024-02-16 14:10 [PATCH v2 0/4] Fix SRC_URI:remove ignoring Anton Mikanovich
@ 2024-02-16 14:10 ` Anton Mikanovich
2024-02-16 14:10 ` [PATCH v2 2/4] meta-test: Add examples of SRC_URI overrides usage Anton Mikanovich
` (4 subsequent siblings)
5 siblings, 0 replies; 9+ messages in thread
From: Anton Mikanovich @ 2024-02-16 14:10 UTC (permalink / raw)
To: isar-users; +Cc: Anton Mikanovich
Enable usage of bbappend files in all the layers.
Signed-off-by: Anton Mikanovich <amikan@ilbers.de>
---
meta-isar/conf/layer.conf | 2 +-
meta-test/conf/layer.conf | 2 +-
meta/conf/layer.conf | 2 +-
3 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/meta-isar/conf/layer.conf b/meta-isar/conf/layer.conf
index dec2658f..2209b18b 100644
--- a/meta-isar/conf/layer.conf
+++ b/meta-isar/conf/layer.conf
@@ -5,7 +5,7 @@
BBPATH .= ":${LAYERDIR}"
# We have recipes-* directories, add to BBFILES
-BBFILES += "${LAYERDIR}/recipes-*/*/*.bb"
+BBFILES += "${LAYERDIR}/recipes-*/*/*.bb ${LAYERDIR}/recipes-*/*/*.bbappend"
BBFILE_COLLECTIONS += "isar"
BBFILE_PATTERN_isar = "^${LAYERDIR}/"
diff --git a/meta-test/conf/layer.conf b/meta-test/conf/layer.conf
index 07b5c77d..0f15119d 100644
--- a/meta-test/conf/layer.conf
+++ b/meta-test/conf/layer.conf
@@ -5,7 +5,7 @@
BBPATH .= ":${LAYERDIR}"
# We have recipes-* directories, add to BBFILES
-BBFILES += "${LAYERDIR}/recipes-*/*/*.bb"
+BBFILES += "${LAYERDIR}/recipes-*/*/*.bb ${LAYERDIR}/recipes-*/*/*.bbappend"
BBFILE_COLLECTIONS += "test"
BBFILE_PATTERN_test = "^${LAYERDIR}/"
diff --git a/meta/conf/layer.conf b/meta/conf/layer.conf
index a38ab97d..b622ce69 100644
--- a/meta/conf/layer.conf
+++ b/meta/conf/layer.conf
@@ -5,7 +5,7 @@
BBPATH .= ":${LAYERDIR}"
# We have recipes-* directories, add to BBFILES
-BBFILES += "${LAYERDIR}/recipes-*/*/*.bb"
+BBFILES += "${LAYERDIR}/recipes-*/*/*.bb ${LAYERDIR}/recipes-*/*/*.bbappend"
BBFILE_COLLECTIONS += "core"
BBFILE_PATTERN_core = "^${LAYERDIR}/"
--
2.34.1
^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH v2 2/4] meta-test: Add examples of SRC_URI overrides usage
2024-02-16 14:10 [PATCH v2 0/4] Fix SRC_URI:remove ignoring Anton Mikanovich
2024-02-16 14:10 ` [PATCH v2 1/4] conf: Enable bbappends Anton Mikanovich
@ 2024-02-16 14:10 ` Anton Mikanovich
2024-02-16 14:10 ` [PATCH v2 3/4] dpkg-base: Fix SRC_URI:remove ignoring Anton Mikanovich
` (3 subsequent siblings)
5 siblings, 0 replies; 9+ messages in thread
From: Anton Mikanovich @ 2024-02-16 14:10 UTC (permalink / raw)
To: isar-users; +Cc: Anton Mikanovich
To check SRC_URI variable manipulations add some append and remove
override examples.
Signed-off-by: Anton Mikanovich <amikan@ilbers.de>
---
meta-test/recipes-app/hello-isar/hello-isar.bbappend | 9 +++++++++
1 file changed, 9 insertions(+)
create mode 100644 meta-test/recipes-app/hello-isar/hello-isar.bbappend
diff --git a/meta-test/recipes-app/hello-isar/hello-isar.bbappend b/meta-test/recipes-app/hello-isar/hello-isar.bbappend
new file mode 100644
index 00000000..d567599f
--- /dev/null
+++ b/meta-test/recipes-app/hello-isar/hello-isar.bbappend
@@ -0,0 +1,9 @@
+# Examples for SRC_URI parser testing
+SRC_URI += " \
+ file://nonexist-file \
+"
+SRC_URI:append = " \
+ git://nonexist-git \
+"
+SRC_URI:remove = "file://nonexist-file"
+SRC_URI:remove = "git://nonexist-git"
--
2.34.1
^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH v2 3/4] dpkg-base: Fix SRC_URI:remove ignoring
2024-02-16 14:10 [PATCH v2 0/4] Fix SRC_URI:remove ignoring Anton Mikanovich
2024-02-16 14:10 ` [PATCH v2 1/4] conf: Enable bbappends Anton Mikanovich
2024-02-16 14:10 ` [PATCH v2 2/4] meta-test: Add examples of SRC_URI overrides usage Anton Mikanovich
@ 2024-02-16 14:10 ` Anton Mikanovich
2024-02-16 14:10 ` [PATCH v2 4/4] multiarch: " Anton Mikanovich
` (2 subsequent siblings)
5 siblings, 0 replies; 9+ messages in thread
From: Anton Mikanovich @ 2024-02-16 14:10 UTC (permalink / raw)
To: isar-users; +Cc: Anton Mikanovich
Current SRC_APT filling code results in losing SRC_URI:remove values.
Remove setting SRC_URI value in prior to remove apt:// items with
additional variables.
Signed-off-by: Anton Mikanovich <amikan@ilbers.de>
---
meta/classes/dpkg-base.bbclass | 5 +----
1 file changed, 1 insertion(+), 4 deletions(-)
diff --git a/meta/classes/dpkg-base.bbclass b/meta/classes/dpkg-base.bbclass
index a8263046..5f88c805 100644
--- a/meta/classes/dpkg-base.bbclass
+++ b/meta/classes/dpkg-base.bbclass
@@ -87,15 +87,12 @@ python() {
src_uri = (d.getVar('SRC_URI', False) or "").split()
prefix = "apt://"
- new_src_uri = []
src_apt = []
for u in src_uri:
if u.startswith(prefix):
src_apt.append(u[len(prefix) :])
- else:
- new_src_uri.append(u)
+ d.setVar('SRC_URI:remove', u)
- d.setVar('SRC_URI', ' '.join(new_src_uri))
d.prependVar('SRC_APT', ' '.join(src_apt))
if len(d.getVar('SRC_APT').strip()) > 0:
--
2.34.1
^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH v2 4/4] multiarch: Fix SRC_URI:remove ignoring
2024-02-16 14:10 [PATCH v2 0/4] Fix SRC_URI:remove ignoring Anton Mikanovich
` (2 preceding siblings ...)
2024-02-16 14:10 ` [PATCH v2 3/4] dpkg-base: Fix SRC_URI:remove ignoring Anton Mikanovich
@ 2024-02-16 14:10 ` Anton Mikanovich
2024-03-14 8:28 ` Schmidt, Adriaan
2024-02-19 18:19 ` [PATCH v2 0/4] " Jan Kiszka
2024-03-07 7:15 ` Uladzimir Bely
5 siblings, 1 reply; 9+ messages in thread
From: Anton Mikanovich @ 2024-02-16 14:10 UTC (permalink / raw)
To: isar-users; +Cc: Anton Mikanovich
Setting SRC_URI right after getVar with expand=False results in loosing
SRC_URI:remove values. Rebuild logic to use remove-append approach.
Signed-off-by: Anton Mikanovich <amikan@ilbers.de>
---
meta/classes/multiarch.bbclass | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/meta/classes/multiarch.bbclass b/meta/classes/multiarch.bbclass
index 48cec9ab..b3fc9441 100644
--- a/meta/classes/multiarch.bbclass
+++ b/meta/classes/multiarch.bbclass
@@ -49,8 +49,9 @@ python multiarch_virtclass_handler() {
vars = 'SRC_URI FILESPATH'.split()
for var in vars:
v = d.getVar(var, expand=False)
- if v is not None:
- d.setVar(var, v.replace('${PN}', '${BPN}'))
+ if v is not None and '${PN}' in v:
+ d.setVar(var + ':remove', v)
+ d.appendVar(var, v.replace('${PN}', '${BPN}'))
# When building compat/native, the corresponding suffix needs to be
# propagated to all bitbake dependency definitions.
--
2.34.1
^ permalink raw reply [flat|nested] 9+ messages in thread
* RE: [PATCH v2 4/4] multiarch: Fix SRC_URI:remove ignoring
2024-02-16 14:10 ` [PATCH v2 4/4] multiarch: " Anton Mikanovich
@ 2024-03-14 8:28 ` Schmidt, Adriaan
2024-03-14 8:44 ` Anton Mikanovich
0 siblings, 1 reply; 9+ messages in thread
From: Schmidt, Adriaan @ 2024-03-14 8:28 UTC (permalink / raw)
To: Anton Mikanovich, isar-users; +Cc: MOESSBAUER, Felix
Anton Mikanovich, Friday, February 16, 2024 3:11 PM:
> Setting SRC_URI right after getVar with expand=False results in loosing
> SRC_URI:remove values. Rebuild logic to use remove-append approach.
>
> Signed-off-by: Anton Mikanovich <amikan@ilbers.de>
> ---
> meta/classes/multiarch.bbclass | 5 +++--
> 1 file changed, 3 insertions(+), 2 deletions(-)
>
> diff --git a/meta/classes/multiarch.bbclass b/meta/classes/multiarch.bbclass
> index 48cec9ab..b3fc9441 100644
> --- a/meta/classes/multiarch.bbclass
> +++ b/meta/classes/multiarch.bbclass
> @@ -49,8 +49,9 @@ python multiarch_virtclass_handler() {
> vars = 'SRC_URI FILESPATH'.split()
> for var in vars:
> v = d.getVar(var, expand=False)
> - if v is not None:
> - d.setVar(var, v.replace('${PN}', '${BPN}'))
> + if v is not None and '${PN}' in v:
> + d.setVar(var + ':remove', v)
> + d.appendVar(var, v.replace('${PN}', '${BPN}'))
Hi Anton,
Just stumbled across this when using current next:
There is a space missing in the append:
d.appendVar(var, ' ' + v.replace('${PN}', '${BPN}'))
Also, setting variables "V:remove" (potentially multiple times) from
Python code smells a little funny. I'm not sure about Bitbake parsing,
and the order of execution-of-Python-blocks vs. variable-assignments vs.
expansions vs. :remove-operators, but I'm a worried that this might
be relying on some undocumented implementation details and only work
by accident.
But I admit that I didn't have a closer look at the actual problem
you're solving here, so I also don't have a good alternative proposal.
So for now, I'd suggest to just fix the missing space.
Thanks,
Adriaan
>
> # When building compat/native, the corresponding suffix needs to be
> # propagated to all bitbake dependency definitions.
> --
> 2.34.1
>
> --
> 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 on the web visit
> https://groups.google.com/d/msgid/isar-users/20240216141051.3490109-5-
> amikan%40ilbers.de.
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH v2 4/4] multiarch: Fix SRC_URI:remove ignoring
2024-03-14 8:28 ` Schmidt, Adriaan
@ 2024-03-14 8:44 ` Anton Mikanovich
0 siblings, 0 replies; 9+ messages in thread
From: Anton Mikanovich @ 2024-03-14 8:44 UTC (permalink / raw)
To: Schmidt, Adriaan, isar-users; +Cc: MOESSBAUER, Felix
14/03/2024 10:28, Schmidt, Adriaan wrote:
> Hi Anton,
>
> Just stumbled across this when using current next:
> There is a space missing in the append:
> d.appendVar(var, ' ' + v.replace('${PN}', '${BPN}'))
>
> Also, setting variables "V:remove" (potentially multiple times) from
> Python code smells a little funny. I'm not sure about Bitbake parsing,
> and the order of execution-of-Python-blocks vs. variable-assignments vs.
> expansions vs. :remove-operators, but I'm a worried that this might
> be relying on some undocumented implementation details and only work
> by accident.
> But I admit that I didn't have a closer look at the actual problem
> you're solving here, so I also don't have a good alternative proposal.
>
> So for now, I'd suggest to just fix the missing space.
>
> Thanks,
> Adriaan
Hello Adriaan,
Thanks for notice, I will send a fix for missing space.
I'm also not satisfied with ":remove" setting but don't see better solution.
In general, it's all about Bitbake ignoring :remove overrides during getVar
with expand=False (but taking care about :append overrides), which makes us
use such a hack.
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH v2 0/4] Fix SRC_URI:remove ignoring
2024-02-16 14:10 [PATCH v2 0/4] Fix SRC_URI:remove ignoring Anton Mikanovich
` (3 preceding siblings ...)
2024-02-16 14:10 ` [PATCH v2 4/4] multiarch: " Anton Mikanovich
@ 2024-02-19 18:19 ` Jan Kiszka
2024-03-07 7:15 ` Uladzimir Bely
5 siblings, 0 replies; 9+ messages in thread
From: Jan Kiszka @ 2024-02-19 18:19 UTC (permalink / raw)
To: Anton Mikanovich, isar-users
On 16.02.24 15:10, Anton Mikanovich wrote:
> SRC_URI:remove override now got lost due to manual SRC_URI manipulations.
> Add example for CI and few fixes to make this test case pass.
>
> Changes since v1:
> - Move test case to meta-test.
> - Fix leading space on append.
> - Improve wording.
>
> Anton Mikanovich (4):
> conf: Enable bbappends
> meta-test: Add examples of SRC_URI overrides usage
> dpkg-base: Fix SRC_URI:remove ignoring
> multiarch: Fix SRC_URI:remove ignoring
>
> meta-isar/conf/layer.conf | 2 +-
> meta-test/conf/layer.conf | 2 +-
> meta-test/recipes-app/hello-isar/hello-isar.bbappend | 9 +++++++++
> meta/classes/dpkg-base.bbclass | 5 +----
> meta/classes/multiarch.bbclass | 5 +++--
> meta/conf/layer.conf | 2 +-
> 6 files changed, 16 insertions(+), 9 deletions(-)
> create mode 100644 meta-test/recipes-app/hello-isar/hello-isar.bbappend
>
Good catch! That would have been nasty to understand in downstream layers.
Jan
--
Siemens AG, Technology
Linux Expert Center
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH v2 0/4] Fix SRC_URI:remove ignoring
2024-02-16 14:10 [PATCH v2 0/4] Fix SRC_URI:remove ignoring Anton Mikanovich
` (4 preceding siblings ...)
2024-02-19 18:19 ` [PATCH v2 0/4] " Jan Kiszka
@ 2024-03-07 7:15 ` Uladzimir Bely
5 siblings, 0 replies; 9+ messages in thread
From: Uladzimir Bely @ 2024-03-07 7:15 UTC (permalink / raw)
To: Anton Mikanovich, isar-users
On Fri, 2024-02-16 at 16:10 +0200, Anton Mikanovich wrote:
> SRC_URI:remove override now got lost due to manual SRC_URI
> manipulations.
> Add example for CI and few fixes to make this test case pass.
>
> Changes since v1:
> - Move test case to meta-test.
> - Fix leading space on append.
> - Improve wording.
>
> Anton Mikanovich (4):
> conf: Enable bbappends
> meta-test: Add examples of SRC_URI overrides usage
> dpkg-base: Fix SRC_URI:remove ignoring
> multiarch: Fix SRC_URI:remove ignoring
>
> meta-isar/conf/layer.conf | 2 +-
> meta-test/conf/layer.conf | 2 +-
> meta-test/recipes-app/hello-isar/hello-isar.bbappend | 9 +++++++++
> meta/classes/dpkg-base.bbclass | 5 +----
> meta/classes/multiarch.bbclass | 5 +++--
> meta/conf/layer.conf | 2 +-
> 6 files changed, 16 insertions(+), 9 deletions(-)
> create mode 100644 meta-test/recipes-app/hello-isar/hello-
> isar.bbappend
>
> --
> 2.34.1
>
Applied to next.
^ permalink raw reply [flat|nested] 9+ messages in thread