Find out if a command exists on POSIX system

梦想的初衷 提交于 2019-12-17 18:37:06

问题


I want to be able to tell if a command exists on any POSIX system from a shell script.

On Linux, I can do the following:

if which <command>; then
   ...snip...
fi

However, Solaris and MacOS which do not give an exit failure code when the command does not exist, they just print an error message to STDOUT.

Also, I recently discovered that the which command itself is not POSIX (see http://pubs.opengroup.org/onlinepubs/9699919799/idx/utilities.html)

Any ideas?


回答1:


command -v is a POSIX specified command that does what which does.

It is defined to to return >0 when the command is not found or an error occurs.




回答2:


POSIX does say, “If a command is not found, the exit status shall be 127.” So you could do

<command>
if [ "${?}" = 127 ]; then
   <handle not found>
fi

When writing shell scripts, it’s often permissible to require a bash shell (#!/bin/bash), because without arrays it’s pretty much impossible to handle arguments and/or filenames with spaces correctly. In that case, the bash builtin type -p is equivalent to which, and because it is builtin, it is portable.




回答3:


You could read the stdout/stderr of "which" into a variable or an array (using backticks) rather than checking for an exit code.

If the system does not have a "which" or "where" command, you could also grab the contents of the $PATH variable, then loop over all the directories and search for the given executable. That's essentially what which does (although it might use some caching/optimization of $PATH results).



来源:https://stackoverflow.com/questions/762631/find-out-if-a-command-exists-on-posix-system

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!