commit:     b5be6cf9e6ac618c9ba413192486dedede9da3e1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 25 06:16:42 2019 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jul 27 09:49:49 2019 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b5be6cf9

vcs-snapshot.eclass: Detect and report invalid directory structure

Detect when the archive does not contain a single top-level directory,
and abort in that case.  Otherwise, --strip-components would result
in unpredictable mess.

Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>

 eclass/vcs-snapshot.eclass | 17 +++++++++++++++--
 1 file changed, 15 insertions(+), 2 deletions(-)

diff --git a/eclass/vcs-snapshot.eclass b/eclass/vcs-snapshot.eclass
index 312e9a4611e..d3f7025fbb3 100644
--- a/eclass/vcs-snapshot.eclass
+++ b/eclass/vcs-snapshot.eclass
@@ -68,8 +68,21 @@ vcs-snapshot_src_unpack() {
 
                                debug-print "${FUNCNAME}: unpacking ${f} to 
${destdir}"
 
-                               # XXX: check whether the directory structure 
inside is
-                               # fine? i.e. if the tarball has actually a 
parent dir.
+                               local l topdirs=()
+                               while read -r l; do
+                                       topdirs+=( "${l}" )
+                               done < <(tar -t -f "${DISTDIR}/${f}" | cut -d/ 
-f1 | sort -u)
+                               if [[ ${#topdirs[@]} -gt 1 ]]; then
+                                       eerror "The archive ${f} contains 
multiple or no top directory."
+                                       eerror "It is impossible for 
vcs-snapshot to unpack this correctly."
+                                       eerror "Top directories found:"
+                                       local d
+                                       for d in "${topdirs[@]}"; do
+                                               eerror "    ${d}"
+                                       done
+                                       die "${FUNCNAME}: Invalid directory 
structure in archive ${f}"
+                               fi
+
                                mkdir "${destdir}" || die
                                # -o (--no-same-owner) to avoid restoring 
original owner
                                einfo "Unpacking ${f}"

Reply via email to