summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcclauss <cclauss@me.com>2019-02-01 14:51:37 +0100
committercclauss <cclauss@me.com>2019-09-02 09:06:38 +0200
commitd1433075f6d7efda5aa67f9caf883cfd9cff71f7 (patch)
tree89cd986f55b9071608e97d449a98008619eff906
parent94c944d0d57062401dd11eb108e7717b9dac62d2 (diff)
downloadnode-new-d1433075f6d7efda5aa67f9caf883cfd9cff71f7.tar.gz
build: find Python 3 or Python 2 in configure
-rwxr-xr-xconfigure36
1 files changed, 20 insertions, 16 deletions
diff --git a/configure b/configure
index 9156e13f7a..f8538b5ced 100755
--- a/configure
+++ b/configure
@@ -1,28 +1,32 @@
#!/bin/sh
-# Locate python2 interpreter and re-execute the script. Note that the
-# mix of single and double quotes is intentional, as is the fact that
-# the ] goes on a new line.
+# Locate an acceptable python interpreter and then re-execute the script.
+# Note that the mix of single and double quotes is intentional,
+# as is the fact that the ] goes on a new line.
_=[ 'exec' '/bin/sh' '-c' '''
+test ${TRAVIS} && exec python "$0" "$@" # workaround for pyenv on Travis CI
which python2.7 >/dev/null && exec python2.7 "$0" "$@"
-which python2 >/dev/null && exec python2 "$0" "$@"
+which python3.7 >/dev/null && exec python3.7 "$0" "$@"
+which python3.6 >/dev/null && exec python3.6 "$0" "$@"
+which python3.5 >/dev/null && exec python3.5 "$0" "$@"
exec python "$0" "$@"
''' "$0" "$@"
]
del _
import sys
-from distutils.spawn import find_executable as which
-if sys.version_info[:2] != (2, 7):
- sys.stderr.write('Please use Python 2.7')
+from distutils.spawn import find_executable
- python2 = which('python2') or which('python2.7')
-
- if python2:
- sys.stderr.write(':\n\n')
- sys.stderr.write(' ' + python2 + ' ' + ' '.join(sys.argv))
-
- sys.stderr.write('\n')
+print('Node configure: Found Python {0}.{1}.{2}...'.format(*sys.version_info))
+acceptable_pythons = ((2, 7), (3, 7), (3, 6), (3, 5))
+if sys.version_info[:2] in acceptable_pythons:
+ import configure
+else:
+ python_cmds = ['python{0}.{1}'.format(*vers) for vers in acceptable_pythons]
+ sys.stderr.write('Please use {0}.\n'.format(' or '.join(python_cmds)))
+ for python_cmd in python_cmds:
+ python_cmd_path = find_executable(python_cmd)
+ if python_cmd_path and 'pyenv/shims' not in python_cmd_path:
+ sys.stderr.write('\t{0} {1}\n'.format(python_cmd_path,
+ ' '.join(sys.argv[:1])))
sys.exit(1)
-
-import configure