Re: [gentoo-portage-dev] [PATCH] bin/estrip: avoid copying directories in FEATURES=installsources
On Sat, 17 Jul 2021 15:34:12 -0700 Zac Medico wrote: > On 7/17/21 12:59 PM, Sergei Trofimovich wrote: > > Initially problem is noticed on gcc-11 as a full ${WORKDIR} syncing > > into /usr/src/debug. It happens because `debug.sources` sometimes > > contains directory. For example on bash-5 it has: > > > > $ grep -zv '/<[^/>]*>$' debug.sources | LANG=C sort -z -u | sed -e > > 's/\x00/\n/g' > > bash-5.0/ > > bash-5.0/alias.c > > ... > > > > This causes syncing object files, config.log, final binaries > > and other unexpected data. The change avoids syncking paths > > that end with '/'. > > > > Signed-off-by: Sergei Trofimovich > > --- > > bin/estrip | 3 +++ > > 1 file changed, 3 insertions(+) > > > > diff --git a/bin/estrip b/bin/estrip > > index 7ef1ec35c..6cca0d04b 100755 > > --- a/bin/estrip > > +++ b/bin/estrip > > @@ -464,7 +464,10 @@ if [[ -s ${tmpdir}/debug.sources ]] && \ > > then > > __vecho "installsources: rsyncing source files" > > [[ -d ${D%/}/${prepstrip_sources_dir#/} ]] || mkdir -p > > "${D%/}/${prepstrip_sources_dir#/}" > > + # skip installation of ".../" (system headers? why inner slashes > > are forbidden?) > > + # skip syncing of ".../foo/" (complete directories) > > grep -zv '/<[^/>]*>$' "${tmpdir}"/debug.sources | \ > > + grep -zv '/$' | \ > > (cd "${WORKDIR}"; LANG=C sort -z -u | \ > > rsync -tL0 --chmod=ugo-st,a+r,go-w,Da+x,Fa-x --files-from=- > > "${WORKDIR}/" "${D%/}/${prepstrip_sources_dir#/}/" ) > > > > > > Looks good. Merged with both grep calls combined via grep -e. Thanks! > > https://gitweb.gentoo.org/proj/portage.git/commit/?id=e083c8bf20d8488d329e3dccd643c28429e6fe30 TIL 'grep -e'! Thank you! -- Sergei pgprH8NkjP86o.pgp Description: Цифровая подпись OpenPGP
Re: [gentoo-portage-dev] [PATCH] bin/estrip: avoid copying directories in FEATURES=installsources
On 7/17/21 12:59 PM, Sergei Trofimovich wrote: > Initially problem is noticed on gcc-11 as a full ${WORKDIR} syncing > into /usr/src/debug. It happens because `debug.sources` sometimes > contains directory. For example on bash-5 it has: > > $ grep -zv '/<[^/>]*>$' debug.sources | LANG=C sort -z -u | sed -e > 's/\x00/\n/g' > bash-5.0/ > bash-5.0/alias.c > ... > > This causes syncing object files, config.log, final binaries > and other unexpected data. The change avoids syncking paths > that end with '/'. > > Signed-off-by: Sergei Trofimovich > --- > bin/estrip | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/bin/estrip b/bin/estrip > index 7ef1ec35c..6cca0d04b 100755 > --- a/bin/estrip > +++ b/bin/estrip > @@ -464,7 +464,10 @@ if [[ -s ${tmpdir}/debug.sources ]] && \ > then > __vecho "installsources: rsyncing source files" > [[ -d ${D%/}/${prepstrip_sources_dir#/} ]] || mkdir -p > "${D%/}/${prepstrip_sources_dir#/}" > + # skip installation of ".../" (system headers? why inner slashes > are forbidden?) > + # skip syncing of ".../foo/" (complete directories) > grep -zv '/<[^/>]*>$' "${tmpdir}"/debug.sources | \ > + grep -zv '/$' | \ > (cd "${WORKDIR}"; LANG=C sort -z -u | \ > rsync -tL0 --chmod=ugo-st,a+r,go-w,Da+x,Fa-x --files-from=- > "${WORKDIR}/" "${D%/}/${prepstrip_sources_dir#/}/" ) > > Looks good. Merged with both grep calls combined via grep -e. Thanks! https://gitweb.gentoo.org/proj/portage.git/commit/?id=e083c8bf20d8488d329e3dccd643c28429e6fe30 -- Thanks, Zac OpenPGP_signature Description: OpenPGP digital signature
[gentoo-portage-dev] [PATCH] bin/estrip: avoid copying directories in FEATURES=installsources
Initially problem is noticed on gcc-11 as a full ${WORKDIR} syncing into /usr/src/debug. It happens because `debug.sources` sometimes contains directory. For example on bash-5 it has: $ grep -zv '/<[^/>]*>$' debug.sources | LANG=C sort -z -u | sed -e 's/\x00/\n/g' bash-5.0/ bash-5.0/alias.c ... This causes syncing object files, config.log, final binaries and other unexpected data. The change avoids syncking paths that end with '/'. Signed-off-by: Sergei Trofimovich --- bin/estrip | 3 +++ 1 file changed, 3 insertions(+) diff --git a/bin/estrip b/bin/estrip index 7ef1ec35c..6cca0d04b 100755 --- a/bin/estrip +++ b/bin/estrip @@ -464,7 +464,10 @@ if [[ -s ${tmpdir}/debug.sources ]] && \ then __vecho "installsources: rsyncing source files" [[ -d ${D%/}/${prepstrip_sources_dir#/} ]] || mkdir -p "${D%/}/${prepstrip_sources_dir#/}" + # skip installation of ".../" (system headers? why inner slashes are forbidden?) + # skip syncing of ".../foo/" (complete directories) grep -zv '/<[^/>]*>$' "${tmpdir}"/debug.sources | \ + grep -zv '/$' | \ (cd "${WORKDIR}"; LANG=C sort -z -u | \ rsync -tL0 --chmod=ugo-st,a+r,go-w,Da+x,Fa-x --files-from=- "${WORKDIR}/" "${D%/}/${prepstrip_sources_dir#/}/" ) -- 2.32.0