summaryrefslogtreecommitdiff
path: root/include/lib.sh
diff options
context:
space:
mode:
Diffstat (limited to 'include/lib.sh')
-rw-r--r--include/lib.sh24
1 files changed, 12 insertions, 12 deletions
diff --git a/include/lib.sh b/include/lib.sh
index a125181b..99e59a1a 100644
--- a/include/lib.sh
+++ b/include/lib.sh
@@ -140,26 +140,27 @@ chkvars()
# e.g. coreboot is multi-tree, so 1
singletree()
{
- ( fx_ "exit 1" "config/$1/"*/ -type f -name "target.cfg" ) || return 1
+ ( fx_ "exit 1" find "config/$1/"*/ -type f -name "target.cfg" ) || \
+ return 1
}
-fe_()
+findpath()
{
- find_ex "x_" "$@"
+ [ $# -gt 0 ] || err "findpath: No arguments provided"
+ while [ $# -gt 0 ]; do
+ found="`readlink -f "$1" 2>/dev/null`" || return 1; :
+ [ -n "$found" ] || found="`realpath "$1" 2>/dev/null`" || \
+ return 1; :
+ printf "%s\n" "$found"
+ shift 1
+ done
}
fx_()
{
- find_ex "" "$@"
-}
-
-find_ex()
-{
- xmsg="$1" && shift 1
fd="`mktemp`" && x_ rm -f "$fd" && x_ touch "$fd"
xx="$1" && shift 1
- $xmsg find "$@" 2>/dev/null | sort 1>"$fd" 2>/dev/null || \
- err "!find $(echo "$@") > \"$fd\""
+ "$@" 2>/dev/null | sort 1>"$fd" 2>/dev/null || err "FATAL: !sort fx_"
dx_ "$xx" "$fd" || break
x_ rm -f "$fd"
}
@@ -179,7 +180,6 @@ x_()
err()
{
- set -u -e
[ $# -lt 1 ] || printf "ERROR %s: %s\n" "$0" "$1" 1>&2 || :
exit 1
}