USE=compile-locales has two errors: 1) Looks for locale.gen in the build tree where there is none. 2) Looks for locale sec in the host tree, which may be old or non existent. The patch the problem: --- a/sys-libs/glibc/glibc-2.32-r7.ebuild +++ b/sys-libs/glibc/glibc-2.32-r7.ebuild @@ -1198,9 +1198,10 @@ run_locale_gen() { if [[ "${root}" == "--inplace-glibc" ]] ; then inplace="--inplace-glibc" root="$2" + export I18NPATH="${ED}"/usr/share/i18n fi - local locale_list="${root}/etc/locale.gen" + local locale_list="${EROOT}/etc/locale.gen" pushd "${ED}"/$(get_libdir) >/dev/null
I think the intent looks reasonable. San you add a few more words why I18NPATH="${ED}"/usr/share/i18n is needed?
Like so? if [[ "${root}" == "--inplace-glibc" ]] ; then inplace="--inplace-glibc" root="$2" + # Use locale src in build tree + export I18NPATH="${ED}"/usr/share/i18n fi - local locale_list="${root}/etc/locale.gen" + # Always use hosts locale config + local locale_list="${EROOT}/etc/locale.gen" pushd "${ED}"/$(get_libdir) >/dev/null
This applies to all glibc ebuild's in Gentoo tree.
would be really nice if this could be fixed soonish.
ping?
(In reply to Sergei Trofimovich from comment #1) > I think the intent looks reasonable. San you add a few more words why > I18NPATH="${ED}"/usr/share/i18n is needed? Is something still unclear? as is now compile-locales is broken
(In reply to Joakim Tjernlund from comment #6) > (In reply to Sergei Trofimovich from comment #1) > > I think the intent looks reasonable. San you add a few more words why > > I18NPATH="${ED}"/usr/share/i18n is needed? > > Is something still unclear? Yes. What does not work without it? > as is now compile-locales is broken What does "broken" mean? That it builds all locales, or something else on top?
(In reply to Sergei Trofimovich from comment #7) > (In reply to Joakim Tjernlund from comment #6) > > (In reply to Sergei Trofimovich from comment #1) > > > I think the intent looks reasonable. San you add a few more words why > > > I18NPATH="${ED}"/usr/share/i18n is needed? > > > > Is something still unclear? > > Yes. What does not work without it? > > > as is now compile-locales is broken > > What does "broken" mean? That it builds all locales, or something else on > top? It uses the installed locale src in ROOT which probably is old.
Is this still unclear? I don't understand what if so.
1. On I18NPATH=: I'm trying to wrap my head around I18NPATH="${ED}"/usr/share/i18n. I see that localedata/Makefile also sets it for localedef call. I don't understand the actual effect. Looks like without it localedef will pick /usr/share/i18n/locales definitions instead. Should it be better placed into `local-gen` that already has --inplace-glibc flag? 2. On 'local locale_list="${EROOT}/etc/locale.gen"' a few points: 2a) https://dev.gentoo.org/~ulm/pms/head/pms.html says ${EROOT} is formally only available for pkg_*() functions. I believe USE=compile-locales will require it in src_install(). We will need a legal PMS workaround for it. 2b) What path should ebould use for 'USE=compile-locales ROOT=/foo emerge -v1 glibc'? /etc/locale.gen or /foo/etc/locale.gen?
(In reply to Sergei Trofimovich from comment #10) > 1. On I18NPATH=: I'm trying to wrap my head around > I18NPATH="${ED}"/usr/share/i18n. I see that localedata/Makefile also sets it > for localedef call. I don't understand the actual effect. Looks like without > it localedef will pick /usr/share/i18n/locales definitions instead. Yes, it is documented in man localedef > > Should it be better placed into `local-gen` that already has > --inplace-glibc flag? Not sure, but that would override a user setting I18NPATH too. > > 2. On 'local locale_list="${EROOT}/etc/locale.gen"' a few points: > > 2a) https://dev.gentoo.org/~ulm/pms/head/pms.html says ${EROOT} is > formally only available for pkg_*() functions. I believe USE=compile-locales > will require it in src_install(). We will need a legal PMS workaround for it. yes, USE=compile-locales runs in src_install() context. Maybe just / for compile-locales, can it be anything else when building ? > > 2b) What path should ebould use for 'USE=compile-locales ROOT=/foo emerge > -v1 glibc'? /etc/locale.gen or /foo/etc/locale.gen? Same as 2a, / I guess.
(In reply to Joakim Tjernlund from comment #11) > (In reply to Sergei Trofimovich from comment #10) > > > > > 2. On 'local locale_list="${EROOT}/etc/locale.gen"' a few points: > > > > 2a) https://dev.gentoo.org/~ulm/pms/head/pms.html says ${EROOT} is > > formally only available for pkg_*() functions. I believe USE=compile-locales > > will require it in src_install(). We will need a legal PMS workaround for it. > > yes, USE=compile-locales runs in src_install() context. Maybe just / for > compile-locales, can it be anything else when building ? > > > > > 2b) What path should ebould use for 'USE=compile-locales ROOT=/foo emerge > > -v1 glibc'? /etc/locale.gen or /foo/etc/locale.gen? > > Same as 2a, / I guess. Or one could use ESYSROOT, seems like a good fit?
ping ? I think ESYSROOT is best as it mimics the non comompile-locales case.
Could we please sort this out ASAP? glibc is after all an important system package
(In reply to Joakim Tjernlund from comment #13) > ping ? > > I think ESYSROOT is best as it mimics the non comompile-locales case. What if we just save EROOT in our own var(LOCALE_GEN_ROOT) in pkg_setup/pkg_pretend and use that? Something like this: --- glibc-2.33.ebuild 2021-06-13 18:54:12.655146226 +0200 +++ glibc-2.33.ebuild 2021-06-17 23:40:27.704909576 +0200 @@ -719,6 +719,7 @@ # All the checks... einfo "Checking general environment sanity." sanity_prechecks + LOCALE_GEN_ROOT="${EROOT}" } pkg_setup() { @@ -1175,9 +1176,10 @@ if [[ "${root}" == "--inplace-glibc" ]] ; then inplace="--inplace-glibc" root="$2" + export I18NPATH="${ED}"/usr/share/i18n fi - local locale_list="${root}/etc/locale.gen" + local locale_list="${LOCALE_GEN_ROOT}/etc/locale.gen" pushd "${ED}"/$(get_libdir) >/dev/null
Ping? w.r.t 2b) I think that is a matter for another bug, this fix will unbreak compile-locales so it works the same way as !compile-locales I really need to get this fixed so pretty please ... I can attach a proper patch if you prefer that?
Proper tested patch will help. Use of ${ESYSROOT} sounds reasonable.
(In reply to Sergei Trofimovich from comment #17) > Proper tested patch will help. Use of ${ESYSROOT} sounds reasonable. I do a proper patch, but why ESYSROOT ? I only suggested that because EROOT was not allowed to use inside src_install. Now I got a fix for that.
Created attachment 718281 [details, diff] fix USE=compile-locales Fixes the two problems mentioned in this bug.
(In reply to Joakim Tjernlund from comment #19) > Created attachment 718281 [details, diff] [details, diff] > fix USE=compile-locales > > Fixes the two problems mentioned in this bug. > --- a/sys-libs/glibc/glibc-2.33.ebuild > +++ b/sys-libs/glibc/glibc-2.33.ebuild > @@ -724,6 +724,7 @@ pkg_pretend() { > pkg_setup() { > # see bug 682570 > [[ -z ${BOOTSTRAP_RAP} ]] && python-any-r1_pkg_setup > + LOCALE_GEN_ROOT="${EROOT}" # For locale-gen later > } We should not use ${EROOT} indirectly in src_compile() phase just by storing the variable in pkg_*() phase. Using ${ESYSROOT} should be fine. > # src_unpack > @@ -1175,9 +1176,12 @@ run_locale_gen() { > if [[ "${root}" == "--inplace-glibc" ]] ; then > inplace="--inplace-glibc" > root="$2" > + # Use locale src in build tree > + export I18NPATH="${ED}"/usr/share/i18n `I18NPATH` belongs to locale-gen script. Also manpage for `localdef` says current directory is inspected. Do we run in a wrong directory? > fi > > - local locale_list="${root}/etc/locale.gen" > + # Always use hosts(EROOT) locale config > + local locale_list="${LOCALE_GEN_ROOT}/etc/locale.gen" I think it should just use local locale_list="${ESYSROOT}/etc/locale.gen" > pushd "${ED}"/$(get_libdir) >/dev/null
Never got this comment in my mailbox, strange ... (In reply to Sergei Trofimovich from comment #20) > (In reply to Joakim Tjernlund from comment #19) > > Created attachment 718281 [details, diff] [details, diff] [details, diff] > > fix USE=compile-locales > > > > Fixes the two problems mentioned in this bug. > > > --- a/sys-libs/glibc/glibc-2.33.ebuild > > +++ b/sys-libs/glibc/glibc-2.33.ebuild > > @@ -724,6 +724,7 @@ pkg_pretend() { > > pkg_setup() { > > # see bug 682570 > > [[ -z ${BOOTSTRAP_RAP} ]] && python-any-r1_pkg_setup > > + LOCALE_GEN_ROOT="${EROOT}" # For locale-gen later > > } > > We should not use ${EROOT} indirectly in src_compile() phase just by storing > the variable in pkg_*() phase. Using ${ESYSROOT} should be fine. OK, I will adjust to ${ESYSROOT} then > > > # src_unpack > > @@ -1175,9 +1176,12 @@ run_locale_gen() { > > if [[ "${root}" == "--inplace-glibc" ]] ; then > > inplace="--inplace-glibc" > > root="$2" > > + # Use locale src in build tree > > + export I18NPATH="${ED}"/usr/share/i18n > > `I18NPATH` belongs to locale-gen script. Also manpage for `localdef` says > current directory is inspected. Do we run in a wrong directory? Sort of, ebuild does pushd "${ED}"/$(get_libdir) >/dev/null to get at glibc libs. Specifying I18NPATH makes sure we use correct locale data regardless of where localedef is executed. > > > fi > > > > - local locale_list="${root}/etc/locale.gen" > > + # Always use hosts(EROOT) locale config > > + local locale_list="${LOCALE_GEN_ROOT}/etc/locale.gen" > > I think it should just use > > local locale_list="${ESYSROOT}/etc/locale.gen" Will do. > > > pushd "${ED}"/$(get_libdir) >/dev/null
Created attachment 720090 [details, diff] v2 fix USE=compile-locales built and tested: ocale-gen --inplace-glibc --jobs 8 --config /etc/locale.gen --destdir /var/tmp/portage/sys-libs/glibc-2.33/image/ * Building locales in DESTDIR '/var/tmp/portage/sys-libs/glibc-2.33/image/' * Generating 5 locales (this might take a while) with 8 jobs * (5/5) Generating C.UTF-8 ... [ ok ] * (3/5) Generating en_US.UTF-8 ... [ ok ] * (2/5) Generating en_GB.UTF-8 ... [ ok ] * (1/5) Generating en_DK.UTF-8 ... [ ok ] * (4/5) Generating sv_SE.UTF-8 ... [ ok ] * Generation complete * Adding locales to archive ...
Happy now?
OK this went around in a few cycles, but there's a misunderstanding here: compile-locales is intended to build *all* locales. If it doesn't do that then it's a bug...
(In reply to Andreas K. Hüttel from comment #24) > OK this went around in a few cycles, but there's a misunderstanding here: > > compile-locales is intended to build *all* locales. If it doesn't do that > then it's a bug... what? This is not how the code is structured/intended. There is a clear intention to build what is in locale.gen.
I think it's reasonable to provide a knob for USE=compile-locales to use only a subset of locales when needed. But it's a good point. There should be something distinguishing the intent to build all locales and to build defined set of them.
(In reply to Sergei Trofimovich from comment #26) > I think it's reasonable to provide a knob for USE=compile-locales to use > only a subset of locales when needed. > > But it's a good point. There should be something distinguishing the intent > to build all locales and to build defined set of them. (late reply, been away this week) I think this issue is snowballing into much more than it intended to fix. Can we just correct the problem at hand and discuss further tweaks in a separate bug?
(In reply to Joakim Tjernlund from comment #25) > (In reply to Andreas K. Hüttel from comment #24) > > OK this went around in a few cycles, but there's a misunderstanding here: > > > > compile-locales is intended to build *all* locales. If it doesn't do that > > then it's a bug... > > what? This is not how the code is structured/intended. There is a clear > intention to build what is in locale.gen. Other than savedconfig, I can't think of cases where a file outside of the portage configuration influences what's installed on disk like this. I think you might be a little presumptuous in claiming that there's clear intention one way or another. Andreas is the one that added USE=compile-locales support (at my request, for RelEng builds). I'm not really involved here, but if this package were my responsibility, I would be disinclined to put a lot of effort into this bug because I find the pings and questions like "Could we please sort this out ASAP?" very off-putting. I'd suggest writing and attaching a git formatted patch with a well written explanation in the commit message of: a) what the problem is, b) how the patch resolves it. As it is, participants in this bug are spending more time just trying to understand you than anything else.
(In reply to Matt Turner from comment #30) > (In reply to Joakim Tjernlund from comment #25) > > (In reply to Andreas K. Hüttel from comment #24) > > > OK this went around in a few cycles, but there's a misunderstanding here: > > > > > > compile-locales is intended to build *all* locales. If it doesn't do that > > > then it's a bug... > > > > what? This is not how the code is structured/intended. There is a clear > > intention to build what is in locale.gen. > > Other than savedconfig, I can't think of cases where a file outside of the > portage configuration influences what's installed on disk like this. > > I think you might be a little presumptuous in claiming that there's clear > intention one way or another. Andreas is the one that added I think code like this clearly spells intention: locale_list="${root}/etc/locale.gen > USE=compile-locales support (at my request, for RelEng builds). Then you should have some interest in getting this sorted, right? > > I'm not really involved here, but if this package were my responsibility, I > would be disinclined to put a lot of effort into this bug because I find the > pings and questions like "Could we please sort this out ASAP?" very > off-putting. Well, agreed that such things can be a bit annoying but at least there was almost a month between the last pings. > > I'd suggest writing and attaching a git formatted patch with a well written > explanation in the commit message of: a) what the problem is, b) how the > patch resolves it. As it is, participants in this bug are spending more time > just trying to understand you than anything else. I think I have already done that, before you commented. Please read the bug/patch in here. Anyhow, consider this my last "ping", cheers.