diff options
| author | Christoph Reiter <reiter.christoph@gmail.com> | 2018-07-19 09:15:30 +0200 | 
|---|---|---|
| committer | Jussi Pakkanen <jpakkane@gmail.com> | 2018-07-27 18:10:13 +0300 | 
| commit | 6b9fdfe67b88f37310e7455997ef2664bf88e58f (patch) | |
| tree | c0c59ba7ae8c92eb92f2e10bd65c044cea592f2b /mesonbuild/modules/python.py | |
| parent | 941d2c273ae8f43f9346480e095a7ebaadb76295 (diff) | |
| download | meson-6b9fdfe67b88f37310e7455997ef2664bf88e58f.tar.gz | |
python.find_installation: only try to find python with the py launcher if it isn't in PATH
Meson tries to find the interpreter path through the "py" launcher on Windows in all
cases which breaks if meson is run under MSYS2 and an official CPython is installed as well.
MSYS2 Python doesn't install a py launcher which results in meson finding the system one instead
even though python2/python3 is in PATH.
Always check if the interpreter name is in PATH before falling back to checking the py launcher.
Diffstat (limited to 'mesonbuild/modules/python.py')
| -rw-r--r-- | mesonbuild/modules/python.py | 7 | 
1 files changed, 5 insertions, 2 deletions
| diff --git a/mesonbuild/modules/python.py b/mesonbuild/modules/python.py index 9a90fe962..1195d8a95 100644 --- a/mesonbuild/modules/python.py +++ b/mesonbuild/modules/python.py @@ -470,11 +470,14 @@ class PythonModule(ExtensionModule):              mlog.log("Using meson's python {}".format(mesonlib.python_command))              python = ExternalProgram('python3', mesonlib.python_command, silent=True)          else: -            if mesonlib.is_windows(): +            python = ExternalProgram(name_or_path, silent = True) + +            if not python.found() and mesonlib.is_windows():                  pythonpath = self._get_win_pythonpath(name_or_path)                  if pythonpath is not None:                      name_or_path = pythonpath -            python = ExternalProgram(name_or_path, silent = True) +                    python = ExternalProgram(name_or_path, silent = True) +              # Last ditch effort, python2 or python3 can be named python              # on various platforms, let's not give up just yet, if an executable              # named python is available and has a compatible version, let's use | 
