On 2020-05-05 17:15, Severin Gehwolf wrote:
Hi,

Could I please get a review of this trivial change? Apparently using
the help builtin for determining whether or not a builtin is available
is not a good idea. A more portable way to do this is to use "command
-v" or "type". Thanks to Michael Zucchi for contributing this fix.

Bug: https://bugs.openjdk.java.net/browse/JDK-8243656
webrev: http://cr.openjdk.java.net/~sgehwolf/webrevs/JDK-8243656/02/webrev/
Hi Severin,

I missed commenting on this before you pushed it, but does this really work?! Did you try it on your system?

I just tested the following:
$ command -V ps
ps is /bin/ps
$ command -V fg
fg is a shell builtin
$ command -v ps
/bin/ps
$ echo  $?
0
$ command -v fg
fg
$ echo  $?
0

That is, it does not seem like "command -v" is making any difference in return value between builtins and external commands!

Also, even if it should do, this is not documented and I don't think it should be relied on -- as evident, it does not work on my system.

In contrast, the (builtin) command "type" seems to work fine, and is documented to work:

$ type -t ps
file
$ type -t fg
builtin

I recommend that use $(type -t) = builtin instead.

/Magnus


Testing: Local builds. jdk/submit.

Thoughts?

Thanks,
Severin


Reply via email to