[arch-projects] [dbscripts] [PATCH v2 3/5] db-update: replace external find command with bash globbing
Eli Schwartz
eschwartz at archlinux.org
Mon Feb 19 20:11:43 UTC 2018
Don't bother emitting errors. bash doesn't show globbing errors if it
cannot read a directory to try globbing there. And the former code never
aborted on errors anyway, as without `set -o pipefail` the sort command
swallowed the return code.
Signed-off-by: Eli Schwartz <eschwartz at archlinux.org>
---
v2: use mapfile as suggested by Luke, rather than running in_array in
a loop.
db-functions | 4 ++++
db-update | 11 ++++++++---
2 files changed, 12 insertions(+), 3 deletions(-)
diff --git a/db-functions b/db-functions
index e8eb2bc..394c7a2 100644
--- a/db-functions
+++ b/db-functions
@@ -2,6 +2,10 @@
. /usr/share/makepkg/util.sh
+# global shell options for enhanced bash scripting
+shopt -s globstar nullglob
+
+
# Some PKGBUILDs need CARCH to be set
CARCH="x86_64"
diff --git a/db-update b/db-update
index a8d885a..db12df8 100755
--- a/db-update
+++ b/db-update
@@ -9,9 +9,14 @@ if (( $# >= 1 )); then
fi
# Find repos with packages to release
-if ! staging_repos=($(find "${STAGING}" -mindepth 1 -type f -name "*${PKGEXTS}" -printf '%h\n' | sort -u)); then
- die "Could not read %s" "$STAGING"
-fi
+mapfile -t -d '' staging_repos < <(
+ for f in "${STAGING}"/**/*${PKGEXTS}; do
+ f="${f%/*}"
+ if [[ -d $f ]]; then
+ printf '%s\0' "$f"
+ fi
+ done | sort -uz
+)
repos=()
for staging_repo in ${staging_repos[@]##*/}; do
--
2.16.2
More information about the arch-projects
mailing list