- #!/bin/bash
-
in_path()
-
{
-
cmd=$1
-
path=$2
-
retval=1
-
oldIFS=$IFS
-
IFS=":"
-
for directory in $path
-
do
-
if [ -x $directory/$cmd ]; then
-
retval=0
-
fi
-
done
-
IFS=$oldIFS
-
return $retval
-
}
-
checkForCmdInPath()
-
{
-
var=$1
-
if [ "$var" != "" ];then
-
if [ "${var%${var#?}}" = "/" ]; then
-
if [ ! -x $var ]; then
-
return 1
-
fi
-
elif ! in_path $var $PATH ; then
-
return 2
-
fi
-
fi
-
return 0
-
}
-
if [ $# -ne 1 ] ; then
-
echo "Usage: $0 command" >&2; exit 1
-
fi
-
checkForCmdInPath "$1"
-
case $? in
-
0) echo "$1 found in PATH" ;;
-
1) echo "$1 not found or not executable" ;;
-
2) echo "$1 not found in PATH" ;;
-
esac
- exit 0
这个例子的作用是判断一个文件是不是在你的环境变量PATH中,如果在,这个文件是不是具有可执行的权限。
这个脚本,我觉得需要3点要学习的地方。
1.关于if的判断,这个我在网上找了一篇文章,在这篇的前一篇就可以找到。
2.关于重定向“>&2”
>&2 就是将结果的标准输出重定向到标准错误输出当中。有人对&这个不太理解,这个符号可以理解为“The same as”,“和...一样”的意思,所以这句话的意思就是,将标准输出重定向到和标准错误输出一样。如果这条命令当中,之前有定义标准错误输出到一个文件的话,那么这个输出也将会到这个文件当中。
有人也许会问,为什么不去掉“&”这个符号呢?加上不就多次一举么?呵呵,如果去掉“&”的话,"2"在这里就会被当作一个文件来处理了。
3.有关POSIX variable slicing method of ${var%${var#?}}
为了理解这个符号的话,我们需要看两个符号
${var#pattern}和${var%pattern}
先看${var#pattern},这个的意思是说,在var变量中,从做往右开始,去掉pattern开始的那一部分,如果匹配不到,就返回var。
${var%pattern},这个的意思时说,在var变量中,从右往左开始,去掉匹配到pattern开始的那一部分,如果匹配不到,就返回var。
例如:
- [goodryb@152 scripts]$ a=abcdefghigk
-
[goodryb@152 scripts]$ echo ${a%higk}
-
abcdefg
-
[goodryb@152 scripts]$ echo ${a%hig}
-
abcdefghigk
-
[goodryb@152 scripts]$ echo ${a#abc}
-
defghigk
-
[goodryb@152 scripts]$ echo ${a#bad}
-
abcdefghigk
- [goodryb@152 scripts]$