D: [iurt_root_command] urpmi error: Too many levels of recursion in macro expansion. It is likely caused by recursive macro declaration. examining synthesis file [/home/pterjan/build/chroot_tmp/pterjan/chroot_cauldron.x86_64.0.20250622204829_6912/var/lib/urpmi/synthesis.hdlist.core_release.cz] examining synthesis file [/home/pterjan/build/chroot_tmp/pterjan/chroot_cauldron.x86_64.0.20250622204829_6912/var/lib/urpmi/synthesis.hdlist.core_updates.cz] examining synthesis file [/home/pterjan/build/chroot_tmp/pterjan/chroot_cauldron.x86_64.0.20250622204829_6912/var/lib/urpmi/synthesis.hdlist.core_updates_testing.cz] would install instead of upgrade package kernel-desktop-6.12.33-1.mga10-1-1.mga10.x86_64 would install instead of upgrade package kernel-desktop-devel-6.12.33-1.mga10-1-1.mga10.x86_64 would install instead of upgrade package kernel-server-6.12.33-1.mga10-1-1.mga10.x86_64 would install instead of upgrade package kernel-server-devel-6.12.33-1.mga10-1-1.mga10.x86_64 would install instead of upgrade package kernel-linus-6.6.87-1.mga10.x86_64 would install instead of upgrade package kernel-linus-devel-6.6.87-1.mga10.x86_64 opening rpmdb (root=/home/pterjan/build/chroot_tmp/pterjan/chroot_cauldron.x86_64.0.20250622204829_6912, write=) selecting rust-caps-0.5.5-2.mga10.src requiring crate(libc/default)[>= 0.2.0],crate(serde_json/default)[>= 1.0.0],crate(thiserror/default)[>= 1.0.0] for rust-caps-0.5.5-2.mga10.src chosen rust-serde_json+default-devel-1.0.139-1.mga10.noarch for crate(serde_json/default)[>= 1.0.0] selecting rust-serde_json+default-devel-1.0.139-1.mga10.noarch requiring crate(serde_json)[== 1.0.139],crate(serde_json/std)[== 1.0.139] for rust-serde_json+default-devel-1.0.139-1.mga10.noarch chosen rust-serde_json+std-devel-1.0.139-1.mga10.noarch for crate(serde_json/std)[== 1.0.139] selecting rust-serde_json+std-devel-1.0.139-1.mga10.noarch requiring crate(memchr/std)[>= 2.0.0],crate(serde/std)[>= 1.0.194],crate(serde_json)[== 1.0.139] for rust-serde_json+std-devel-1.0.139-1.mga10.noarch chosen rust-memchr+std-devel-2.7.4-1.mga10.noarch for crate(memchr/std)[>= 2.0.0] selecting rust-memchr+std-devel-2.7.4-1.mga10.noarch requiring crate(memchr)[== 2.7.4],crate(memchr/alloc)[== 2.7.4] for rust-memchr+std-devel-2.7.4-1.mga10.noarch chosen rust-memchr+alloc-devel-2.7.4-1.mga10.noarch for crate(memchr/alloc)[== 2.7.4] selecting rust-memchr+alloc-devel-2.7.4-1.mga10.noarch requiring crate(memchr)[== 2.7.4] for rust-memchr+alloc-devel-2.7.4-1.mga10.noarch chosen rust-memchr-devel-2.7.4-1.mga10.noarch for crate(memchr)[== 2.7.4] selecting rust-memchr-devel-2.7.4-1.mga10.noarch chosen rust-memchr-devel-2.7.4-1.mga10.noarch for crate(memchr)[== 2.7.4] chosen rust-serde_json-devel-1.0.139-1.mga10.noarch for crate(serde_json)[== 1.0.139] selecting rust-serde_json-devel-1.0.139-1.mga10.noarch requiring crate(itoa/default)[>= 1.0.0],crate(ryu/default)[>= 1.0.0],crate(serde)[>= 1.0.194] for rust-serde_json-devel-1.0.139-1.mga10.noarch chosen rust-itoa+default-devel-1.0.14-1.mga10.noarch for crate(itoa/default)[>= 1.0.0] selecting rust-itoa+default-devel-1.0.14-1.mga10.noarch requiring crate(itoa)[== 1.0.14] for rust-itoa+default-devel-1.0.14-1.mga10.noarch chosen rust-itoa-devel-1.0.14-1.mga10.noarch for crate(itoa)[== 1.0.14] selecting rust-itoa-devel-1.0.14-1.mga10.noarch chosen rust-ryu+default-devel-1.0.18-1.mga10.noarch for crate(ryu/default)[>= 1.0.0] selecting rust-ryu+default-devel-1.0.18-1.mga10.noarch requiring crate(ryu)[== 1.0.18] for rust-ryu+default-devel-1.0.18-1.mga10.noarch chosen rust-ryu-devel-1.0.18-1.mga10.noarch for crate(ryu)[== 1.0.18] selecting rust-ryu-devel-1.0.18-1.mga10.noarch chosen rust-serde-devel-1.0.217-1.mga10.noarch for crate(serde)[>= 1.0.194] selecting rust-serde-devel-1.0.217-1.mga10.noarch requiring crate(serde_derive/default)[== 1.0.217] for rust-serde-devel-1.0.217-1.mga10.noarch chosen rust-serde_derive+default-devel-1.0.217-1.mga10.noarch for crate(serde_derive/default)[== 1.0.217] selecting rust-serde_derive+default-devel-1.0.217-1.mga10.noarch requiring crate(serde_derive)[== 1.0.217] for rust-serde_derive+default-devel-1.0.217-1.mga10.noarch chosen rust-serde_derive-devel-1.0.217-1.mga10.noarch for crate(serde_derive)[== 1.0.217] selecting rust-serde_derive-devel-1.0.217-1.mga10.noarch chosen rust-serde+std-devel-1.0.217-1.mga10.noarch for crate(serde/std)[>= 1.0.194] selecting rust-serde+std-devel-1.0.217-1.mga10.noarch chosen rust-serde_json-devel-1.0.139-1.mga10.noarch for crate(serde_json)[== 1.0.139] chosen rust-libc+default-devel-0.2.174-1.mga10.noarch for crate(libc/default)[>= 0.2.0] selecting rust-libc+default-devel-0.2.174-1.mga10.noarch requiring crate(libc)[== 0.2.174],crate(libc/std)[== 0.2.174] for rust-libc+default-devel-0.2.174-1.mga10.noarch chosen rust-libc-devel-0.2.174-1.mga10.noarch for crate(libc)[== 0.2.174] selecting rust-libc-devel-0.2.174-1.mga10.noarch chosen rust-libc+std-devel-0.2.174-1.mga10.noarch for crate(libc/std)[== 0.2.174] selecting rust-libc+std-devel-0.2.174-1.mga10.noarch replacing crate(thiserror/default)[>= 1.0.0] with rust-thiserror+default-devel selecting rust-thiserror+default-devel-2.0.12-1.mga10.noarch requiring crate(thiserror)[== 2.0.12],crate(thiserror/std)[== 2.0.12] for rust-thiserror+default-devel-2.0.12-1.mga10.noarch chosen rust-thiserror-devel-2.0.12-1.mga10.noarch for crate(thiserror)[== 2.0.12] selecting rust-thiserror-devel-2.0.12-1.mga10.noarch requiring crate(thiserror-impl/default)[== 2.0.12] for rust-thiserror-devel-2.0.12-1.mga10.noarch chosen rust-thiserror-impl+default-devel-2.0.12-1.mga10.noarch for crate(thiserror-impl/default)[== 2.0.12] selecting rust-thiserror-impl+default-devel-2.0.12-1.mga10.noarch requiring crate(thiserror-impl)[== 2.0.12] for rust-thiserror-impl+default-devel-2.0.12-1.mga10.noarch chosen rust-thiserror-impl-devel-2.0.12-1.mga10.noarch for crate(thiserror-impl)[== 2.0.12] selecting rust-thiserror-impl-devel-2.0.12-1.mga10.noarch chosen rust-thiserror+std-devel-2.0.12-1.mga10.noarch for crate(thiserror/std)[== 2.0.12] selecting rust-thiserror+std-devel-2.0.12-1.mga10.noarch rust-caps is not in potential orphans opening rpmdb (root=/home/pterjan/build/chroot_tmp/pterjan/chroot_cauldron.x86_64.0.20250622204829_6912, write=) getting graph of dependencies for sorting sorting graph of dependencies rpms sorted by dependencies: rust-memchr-devel rust-memchr+alloc-devel rust-memchr+std-devel rust-itoa-devel rust-itoa+default-devel rust-ryu-devel rust-ryu+default-devel rust-serde_derive-devel rust-serde_derive+default-devel rust-serde-devel rust-serde+std-devel rust-serde_json-devel rust-serde_json+std-devel rust-serde_json+default-devel rust-libc-devel rust-libc+std-devel rust-libc+default-devel rust-thiserror-impl-devel rust-thiserror-impl+default-devel rust-thiserror-devel rust-thiserror+std-devel rust-thiserror+default-devel rust-caps selecting rust-memchr+std-devel-2.7.4-1.mga10.noarch requiring crate(memchr)[== 2.7.4],crate(memchr/alloc)[== 2.7.4] for rust-memchr+std-devel-2.7.4-1.mga10.noarch chosen rust-memchr+alloc-devel-2.7.4-1.mga10.noarch for crate(memchr/alloc)[== 2.7.4] selecting rust-memchr+alloc-devel-2.7.4-1.mga10.noarch requiring crate(memchr)[== 2.7.4] for rust-memchr+alloc-devel-2.7.4-1.mga10.noarch chosen rust-memchr-devel-2.7.4-1.mga10.noarch for crate(memchr)[== 2.7.4] selecting rust-memchr-devel-2.7.4-1.mga10.noarch chosen rust-memchr-devel-2.7.4-1.mga10.noarch for crate(memchr)[== 2.7.4] selecting rust-itoa+default-devel-1.0.14-1.mga10.noarch requiring crate(itoa)[== 1.0.14] for rust-itoa+default-devel-1.0.14-1.mga10.noarch chosen rust-itoa-devel-1.0.14-1.mga10.noarch for crate(itoa)[== 1.0.14] selecting rust-itoa-devel-1.0.14-1.mga10.noarch selecting rust-ryu-devel-1.0.18-1.mga10.noarch selecting rust-ryu+default-devel-1.0.18-1.mga10.noarch selecting rust-caps-0.5.5-2.mga10.src requiring crate(libc/default)[>= 0.2.0],crate(serde_json/default)[>= 1.0.0],crate(thiserror/default)[>= 1.0.0] for rust-caps-0.5.5-2.mga10.src chosen rust-serde_json+default-devel-1.0.139-1.mga10.noarch for crate(serde_json/default)[>= 1.0.0] selecting rust-serde_json+default-devel-1.0.139-1.mga10.noarch requiring crate(serde_json)[== 1.0.139],crate(serde_json/std)[== 1.0.139] for rust-serde_json+default-devel-1.0.139-1.mga10.noarch chosen rust-serde_json-devel-1.0.139-1.mga10.noarch for crate(serde_json)[== 1.0.139] selecting rust-serde_json-devel-1.0.139-1.mga10.noarch requiring crate(serde)[>= 1.0.194] for rust-serde_json-devel-1.0.139-1.mga10.noarch chosen rust-serde-devel-1.0.217-1.mga10.noarch for crate(serde)[>= 1.0.194] selecting rust-serde-devel-1.0.217-1.mga10.noarch requiring crate(serde_derive/default)[== 1.0.217] for rust-serde-devel-1.0.217-1.mga10.noarch chosen rust-serde_derive+default-devel-1.0.217-1.mga10.noarch for crate(serde_derive/default)[== 1.0.217] selecting rust-serde_derive+default-devel-1.0.217-1.mga10.noarch requiring crate(serde_derive)[== 1.0.217] for rust-serde_derive+default-devel-1.0.217-1.mga10.noarch chosen rust-serde_derive-devel-1.0.217-1.mga10.noarch for crate(serde_derive)[== 1.0.217] selecting rust-serde_derive-devel-1.0.217-1.mga10.noarch chosen rust-serde_json+std-devel-1.0.139-1.mga10.noarch for crate(serde_json/std)[== 1.0.139] selecting rust-serde_json+std-devel-1.0.139-1.mga10.noarch requiring crate(serde/std)[>= 1.0.194] for rust-serde_json+std-devel-1.0.139-1.mga10.noarch chosen rust-serde+std-devel-1.0.217-1.mga10.noarch for crate(serde/std)[>= 1.0.194] selecting rust-serde+std-devel-1.0.217-1.mga10.noarch chosen rust-libc+default-devel-0.2.174-1.mga10.noarch for crate(libc/default)[>= 0.2.0] selecting rust-libc+default-devel-0.2.174-1.mga10.noarch requiring crate(libc)[== 0.2.174],crate(libc/std)[== 0.2.174] for rust-libc+default-devel-0.2.174-1.mga10.noarch chosen rust-libc+std-devel-0.2.174-1.mga10.noarch for crate(libc/std)[== 0.2.174] selecting rust-libc+std-devel-0.2.174-1.mga10.noarch requiring crate(libc)[== 0.2.174] for rust-libc+std-devel-0.2.174-1.mga10.noarch chosen rust-libc-devel-0.2.174-1.mga10.noarch for crate(libc)[== 0.2.174] selecting rust-libc-devel-0.2.174-1.mga10.noarch chosen rust-libc-devel-0.2.174-1.mga10.noarch for crate(libc)[== 0.2.174] chosen rust-thiserror+default-devel-2.0.12-1.mga10.noarch for crate(thiserror/default)[>= 1.0.0] selecting rust-thiserror+default-devel-2.0.12-1.mga10.noarch requiring crate(thiserror)[== 2.0.12],crate(thiserror/std)[== 2.0.12] for rust-thiserror+default-devel-2.0.12-1.mga10.noarch chosen rust-thiserror-devel-2.0.12-1.mga10.noarch for crate(thiserror)[== 2.0.12] selecting rust-thiserror-devel-2.0.12-1.mga10.noarch requiring crate(thiserror-impl/default)[== 2.0.12] for rust-thiserror-devel-2.0.12-1.mga10.noarch chosen rust-thiserror-impl+default-devel-2.0.12-1.mga10.noarch for crate(thiserror-impl/default)[== 2.0.12] selecting rust-thiserror-impl+default-devel-2.0.12-1.mga10.noarch requiring crate(thiserror-impl)[== 2.0.12] for rust-thiserror-impl+default-devel-2.0.12-1.mga10.noarch chosen rust-thiserror-impl-devel-2.0.12-1.mga10.noarch for crate(thiserror-impl)[== 2.0.12] selecting rust-thiserror-impl-devel-2.0.12-1.mga10.noarch chosen rust-thiserror+std-devel-2.0.12-1.mga10.noarch for crate(thiserror/std)[== 2.0.12] selecting rust-thiserror+std-devel-2.0.12-1.mga10.noarch transaction valid: remove= update=rust-libc+std-devel,rust-serde_derive+default-devel,rust-thiserror-devel,rust-serde-devel,rust-libc+default-devel,rust-itoa-devel,rust-serde_json-devel,rust-thiserror-impl+default-devel,rust-thiserror+std-devel,rust-thiserror-impl-devel,rust-thiserror+default-devel,rust-libc-devel,rust-ryu-devel,rust-itoa+default-devel,rust-memchr+alloc-devel,rust-memchr-devel,rust-memchr+std-devel,rust-serde+std-devel,rust-serde_json+std-devel,rust-serde_derive-devel,rust-serde_json+default-devel,rust-caps,rust-ryu+default-devel scheduled sets of transactions: remove=0= update=23=rust-libc+std-devel,rust-serde_derive+default-devel,rust-thiserror-devel,rust-serde-devel,rust-libc+default-devel,rust-itoa-devel,rust-serde_json-devel,rust-thiserror-impl+default-devel,rust-thiserror+std-devel,rust-thiserror-impl-devel,rust-thiserror+default-devel,rust-libc-devel,rust-ryu-devel,rust-itoa+default-devel,rust-memchr+alloc-devel,rust-memchr-devel,rust-memchr+std-devel,rust-serde+std-devel,rust-serde_json+std-devel,rust-serde_derive-devel,rust-serde_json+default-devel,rust-caps,rust-ryu+default-devel chrooted db version used by librpm is at least as good as non-rooted one installing rust-memchr+alloc-devel-2.7.4-1.mga10.noarch.rpm rust-ryu-devel-1.0.18-1.mga10.noarch.rpm rust-itoa+default-devel-1.0.14-1.mga10.noarch.rpm rust-memchr-devel-2.7.4-1.mga10.noarch.rpm rust-memchr+std-devel-2.7.4-1.mga10.noarch.rpm rust-serde_json+std-devel-1.0.139-1.mga10.noarch.rpm rust-serde+std-devel-1.0.217-1.mga10.noarch.rpm rust-serde_json+default-devel-1.0.139-1.mga10.noarch.rpm rust-serde_derive-devel-1.0.217-1.mga10.noarch.rpm rust-ryu+default-devel-1.0.18-1.mga10.noarch.rpm rust-serde_derive+default-devel-1.0.217-1.mga10.noarch.rpm rust-libc+std-devel-0.2.174-1.mga10.noarch.rpm rust-libc+default-devel-0.2.174-1.mga10.noarch.rpm rust-itoa-devel-1.0.14-1.mga10.noarch.rpm rust-serde_json-devel-1.0.139-1.mga10.noarch.rpm rust-thiserror-devel-2.0.12-1.mga10.noarch.rpm rust-serde-devel-1.0.217-1.mga10.noarch.rpm rust-thiserror-impl+default-devel-2.0.12-1.mga10.noarch.rpm rust-thiserror+std-devel-2.0.12-1.mga10.noarch.rpm rust-libc-devel-0.2.174-1.mga10.noarch.rpm rust-thiserror-impl-devel-2.0.12-1.mga10.noarch.rpm rust-thiserror+default-devel-2.0.12-1.mga10.noarch.rpm from /distrib/cauldron/x86_64/media/core/release starting installing packages opening rpmdb (root=/home/pterjan/build/chroot_tmp/pterjan/chroot_cauldron.x86_64.0.20250622204829_6912, write=1) created transaction for installing on /home/pterjan/build/chroot_tmp/pterjan/chroot_cauldron.x86_64.0.20250622204829_6912 (remove=0, install=0, upgrade=22) trans: scheduling update of rust-memchr+alloc-devel-2.7.4-1.mga10.noarch (id=15562, file=/distrib/cauldron/x86_64/media/core/release/rust-memchr+alloc-devel-2.7.4-1.mga10.noarch.rpm) trans: scheduling update of rust-ryu-devel-1.0.18-1.mga10.noarch (id=21101, file=/distrib/cauldron/x86_64/media/core/release/rust-ryu-devel-1.0.18-1.mga10.noarch.rpm) trans: scheduling update of rust-itoa+default-devel-1.0.14-1.mga10.noarch (id=18367, file=/distrib/cauldron/x86_64/media/core/release/rust-itoa+default-devel-1.0.14-1.mga10.noarch.rpm) trans: scheduling update of rust-memchr-devel-2.7.4-1.mga10.noarch (id=15555, file=/distrib/cauldron/x86_64/media/core/release/rust-memchr-devel-2.7.4-1.mga10.noarch.rpm) trans: scheduling update of rust-memchr+std-devel-2.7.4-1.mga10.noarch (id=15559, file=/distrib/cauldron/x86_64/media/core/release/rust-memchr+std-devel-2.7.4-1.mga10.noarch.rpm) trans: scheduling update of rust-serde_json+std-devel-1.0.139-1.mga10.noarch (id=22122, file=/distrib/cauldron/x86_64/media/core/release/rust-serde_json+std-devel-1.0.139-1.mga10.noarch.rpm) trans: scheduling update of rust-serde+std-devel-1.0.217-1.mga10.noarch (id=21617, file=/distrib/cauldron/x86_64/media/core/release/rust-serde+std-devel-1.0.217-1.mga10.noarch.rpm) trans: scheduling update of rust-serde_json+default-devel-1.0.139-1.mga10.noarch (id=22120, file=/distrib/cauldron/x86_64/media/core/release/rust-serde_json+default-devel-1.0.139-1.mga10.noarch.rpm) trans: scheduling update of rust-serde_derive-devel-1.0.217-1.mga10.noarch (id=21599, file=/distrib/cauldron/x86_64/media/core/release/rust-serde_derive-devel-1.0.217-1.mga10.noarch.rpm) trans: scheduling update of rust-ryu+default-devel-1.0.18-1.mga10.noarch (id=21106, file=/distrib/cauldron/x86_64/media/core/release/rust-ryu+default-devel-1.0.18-1.mga10.noarch.rpm) trans: scheduling update of rust-serde_derive+default-devel-1.0.217-1.mga10.noarch (id=21598, file=/distrib/cauldron/x86_64/media/core/release/rust-serde_derive+default-devel-1.0.217-1.mga10.noarch.rpm) trans: scheduling update of rust-libc+std-devel-0.2.174-1.mga10.noarch (id=37051, file=/distrib/cauldron/x86_64/media/core/release/rust-libc+std-devel-0.2.174-1.mga10.noarch.rpm) trans: scheduling update of rust-libc+default-devel-0.2.174-1.mga10.noarch (id=37053, file=/distrib/cauldron/x86_64/media/core/release/rust-libc+default-devel-0.2.174-1.mga10.noarch.rpm) trans: scheduling update of rust-itoa-devel-1.0.14-1.mga10.noarch (id=18366, file=/distrib/cauldron/x86_64/media/core/release/rust-itoa-devel-1.0.14-1.mga10.noarch.rpm) trans: scheduling update of rust-serde_json-devel-1.0.139-1.mga10.noarch (id=22116, file=/distrib/cauldron/x86_64/media/core/release/rust-serde_json-devel-1.0.139-1.mga10.noarch.rpm) trans: scheduling update of rust-thiserror-devel-2.0.12-1.mga10.noarch (id=37082, file=/distrib/cauldron/x86_64/media/core/release/rust-thiserror-devel-2.0.12-1.mga10.noarch.rpm) trans: scheduling update of rust-serde-devel-1.0.217-1.mga10.noarch (id=21615, file=/distrib/cauldron/x86_64/media/core/release/rust-serde-devel-1.0.217-1.mga10.noarch.rpm) trans: scheduling update of rust-thiserror-impl+default-devel-2.0.12-1.mga10.noarch (id=37075, file=/distrib/cauldron/x86_64/media/core/release/rust-thiserror-impl+default-devel-2.0.12-1.mga10.noarch.rpm) trans: scheduling update of rust-thiserror+std-devel-2.0.12-1.mga10.noarch (id=37084, file=/distrib/cauldron/x86_64/media/core/release/rust-thiserror+std-devel-2.0.12-1.mga10.noarch.rpm) trans: scheduling update of rust-libc-devel-0.2.174-1.mga10.noarch (id=37050, file=/distrib/cauldron/x86_64/media/core/release/rust-libc-devel-0.2.174-1.mga10.noarch.rpm) trans: scheduling update of rust-thiserror-impl-devel-2.0.12-1.mga10.noarch (id=37074, file=/distrib/cauldron/x86_64/media/core/release/rust-thiserror-impl-devel-2.0.12-1.mga10.noarch.rpm) trans: scheduling update of rust-thiserror+default-devel-2.0.12-1.mga10.noarch (id=37083, file=/distrib/cauldron/x86_64/media/core/release/rust-thiserror+default-devel-2.0.12-1.mga10.noarch.rpm) Preparing... ############################################# 1/22: rust-memchr-devel ############################################# 2/22: rust-libc-devel ############################################# 3/22: rust-libc+std-devel ############################################# 4/22: rust-memchr+alloc-devel ############################################# 5/22: rust-memchr+std-devel ############################################# 6/22: rust-thiserror-impl-devel ############################################# 7/22: rust-thiserror-impl+default-devel ############################################# 8/22: rust-thiserror-devel ############################################# 9/22: rust-thiserror+std-devel ############################################# 10/22: rust-itoa-devel ############################################# 11/22: rust-itoa+default-devel ############################################# 12/22: rust-serde_derive-devel ############################################# 13/22: rust-serde_derive+default-devel ############################################# 14/22: rust-serde-devel ############################################# 15/22: rust-serde+std-devel ############################################# 16/22: rust-ryu-devel ############################################# 17/22: rust-ryu+default-devel ############################################# 18/22: rust-serde_json-devel ############################################# 19/22: rust-serde_json+std-devel ############################################# 20/22: rust-serde_json+default-devel ############################################# 21/22: rust-thiserror+default-devel ############################################# 22/22: rust-libc+default-devel ############################################# workaround bug in rpmlib by removing /home/pterjan/build/chroot_tmp/pterjan/chroot_cauldron.x86_64.0.20250622204829_6912/var/lib/rpm/__db* EXITING (pid=1107941) D: [iurt_root_command] Success!