From 87e15df48e356862adaa2cb376e461e7e7d7c058 Mon Sep 17 00:00:00 2001 From: hakkiplaten Date: Fri, 7 Oct 2016 21:25:54 +0200 Subject: [PATCH 1/2] Convert has_lib.sh to sh so it also works on BSD OSes Passes http://www.shellcheck.net/ Ref. #754 --- util/has_lib.sh | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/util/has_lib.sh b/util/has_lib.sh index 31ef129..6be2cf9 100755 --- a/util/has_lib.sh +++ b/util/has_lib.sh @@ -1,18 +1,19 @@ -#!/bin/bash +#!/bin/sh has_ldconfig() { hash ldconfig 2>/dev/null } has_system_lib() { - local regex="lib$1.+(so|dylib)" + regex="lib$1.+(so|dylib)" # Add /sbin to path as ldconfig is located there on some systems - e.g. Debian # (and it still can be used by unprivileged users): PATH="$PATH:/sbin" export PATH - # Try using ldconfig on linux systems - if $(has_ldconfig); then + + # Try using ldconfig on Linux systems + if has_ldconfig; then for _ in $(ldconfig -p 2>/dev/null | grep -E "$regex"); do return 0 done @@ -20,7 +21,7 @@ has_system_lib() { # Try just checking common library locations for dir in /lib /usr/lib /usr/local/lib /opt/local/lib /usr/lib/x86_64-linux-gnu /usr/lib/i386-linux-gnu; do - test -d $dir && ls $dir | grep -E "$regex" && return 0 + test -d "$dir" && echo "$dir"/* | grep -E "$regex" && return 0 done return 1 @@ -52,7 +53,7 @@ case "$1" in result=$? ;; *) - >&2 echo "Unknown library: $1" + echo "Unknown library: $1" exit 1 esac From 038daf6710731faa9421d93af8241e4e6eeadca7 Mon Sep 17 00:00:00 2001 From: hakkiplaten Date: Sat, 8 Oct 2016 22:54:45 +0200 Subject: [PATCH 2/2] Add back print to stderr in has_lib.sh --- util/has_lib.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/util/has_lib.sh b/util/has_lib.sh index 6be2cf9..75e216c 100755 --- a/util/has_lib.sh +++ b/util/has_lib.sh @@ -53,7 +53,7 @@ case "$1" in result=$? ;; *) - echo "Unknown library: $1" + >&2 echo "Unknown library: $1" exit 1 esac