From ecf5b22ecb9c6c47c487d192c4b5d3aef6fd84a6 Mon Sep 17 00:00:00 2001 From: Kenneth Hoste Date: Wed, 26 Jun 2024 08:30:36 +0200 Subject: [PATCH] try to determine common prefix for paths in tarball after filtering out */init/* paths --- scripts/automated_ingestion/eessitarball.py | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/scripts/automated_ingestion/eessitarball.py b/scripts/automated_ingestion/eessitarball.py index 4283eb65..d3118500 100644 --- a/scripts/automated_ingestion/eessitarball.py +++ b/scripts/automated_ingestion/eessitarball.py @@ -95,7 +95,15 @@ def get_contents_overview(self): else: tar_members_desc = 'Summarized overview of the contents of the tarball:' - prefix = os.path.commonprefix(paths) + # determine prefix after filtering out '/init' subdirectory, + # to get actual prefix for specific CPU target (like '2023.06/software/linux/aarch64/neoverse_v1') + init_subdir = os.path.join('*', 'init') + non_init_paths = sorted([p for p in paths if not any(x.match(init_subdir) for x in PurePosixPath(p).parents)]) + if non_init_paths: + prefix = os.path.commonprefix(non_init_paths) + else: + prefix = os.path.commonprefix(paths) + # TODO: this only works for software tarballs, how to handle compat layer tarballs? swdirs = [ # all directory names with the pattern: /software// m.path