libtool-patches
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: FYI [PATCH] libtool: minimise forks per invocation under bash.


From: Stefano Lattarini
Subject: Re: FYI [PATCH] libtool: minimise forks per invocation under bash.
Date: Sun, 18 Dec 2011 11:19:19 +0100
User-agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.2.24) Gecko/20111114 Icedove/3.1.16

On 12/18/2011 11:07 AM, Gary V. Vaughan wrote:
Hi Stefano,

On 18 Dec 2011, at 17:02, Stefano Lattarini wrote:

On 12/18/2011 10:52 AM, Stefano Lattarini wrote:
On 12/18/2011 06:15 AM, Gary V. Vaughan wrote:
+# We should try to minimise forks, especially on Windows where they are
+# unreasonably slow, so skip the feature probes when bash is being used:
+if test set = "${BASH_VERSION+set}"; then
+    : ${lt_HAVE_ARITH_OP="yes"}
+    : ${lt_HAVE_XSI_OPS="yes"}
+    # The += operator was introduced in bash 3.1
+    test -z "$lt_HAVE_PLUSEQ_OP" \
+&&   test 3000 -lt "$((${BASH_VERSINFO[0]}*1000 + ${BASH_VERSINFO[1]}))" \
+&&   lt_HAVE_PLUSEQ_OP=yes
+fi
This will likely break with dash 0.5.2:

  $ cat foo.sh
  #!/bin/sh
  if test set = "${BASH_VERSION+set}"; then
    : ${lt_HAVE_ARITH_OP="yes"}
    : ${lt_HAVE_XSI_OPS="yes"}
    # The += operator was introduced in bash 3.1
    test -z "$lt_HAVE_PLUSEQ_OP" \
&&  test 3000 -lt "$((${BASH_VERSINFO[0]}*1000 + ${BASH_VERSINFO[1]}))" \
&&  lt_HAVE_PLUSEQ_OP=yes
  fi
  $ dash foo.sh
  foo.sh: 7: Syntax error: Bad substitution
Update: the same happens with NetBSD 5.1 /bin/sh (which is probably
an ash-derivative).
Thanks for the report.

Unfortunately, I'm out of ideas on how to portably detect the bash version 
without
spending a fork, in which case it seems easiest to spend that fork actually 
testing
for += support rather than poking at the bash version.

Can anyone think of something better than just removing the whole 
lt_HAVE_PLUSEQ_OP
clause from the patch quoted above, and letting the shell figure it by itself 
later
on?
Adding an extra eval seems to do the trick:

eval 'test 3000 -lt "$((${BASH_VERSINFO[0]}*1000 + ${BASH_VERSINFO[1]}))"'

Of course, a comment about why this eval is needed would be definitely
warranted.

Or, to be even safer, you could directly poke at $BASH_VERSION instead:

  case $BASH_VERSION in
    [12].*|3.0.*) ;;
    *) lt_HAVE_PLUSEQ_OP=yes;;
  esac

Regards,
  Stefano




reply via email to

[Prev in Thread] Current Thread [Next in Thread]