|
|
|
# Copyright 2012-2016 The Meson development team
|
|
|
|
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import os.path
|
|
|
|
|
|
|
|
from . import mesonlib
|
|
|
|
from . import mlog
|
|
|
|
from .mesonlib import MesonException
|
|
|
|
from .environment import detect_msys2_arch
|
|
|
|
|
|
|
|
def run_script_command(args):
|
|
|
|
cmdname = args[0]
|
|
|
|
cmdargs = args[1:]
|
|
|
|
if cmdname == 'exe':
|
|
|
|
import mesonbuild.scripts.meson_exe as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'cleantrees':
|
|
|
|
import mesonbuild.scripts.cleantrees as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'commandrunner':
|
|
|
|
import mesonbuild.scripts.commandrunner as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'delsuffix':
|
|
|
|
import mesonbuild.scripts.delwithsuffix as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'dirchanger':
|
|
|
|
import mesonbuild.scripts.dirchanger as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'gtkdoc':
|
|
|
|
import mesonbuild.scripts.gtkdochelper as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'msgfmthelper':
|
|
|
|
import mesonbuild.scripts.msgfmthelper as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'hotdoc':
|
|
|
|
import mesonbuild.scripts.hotdochelper as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'regencheck':
|
|
|
|
import mesonbuild.scripts.regen_checker as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'symbolextractor':
|
|
|
|
import mesonbuild.scripts.symbolextractor as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'scanbuild':
|
|
|
|
import mesonbuild.scripts.scanbuild as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'vcstagger':
|
|
|
|
import mesonbuild.scripts.vcstagger as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'gettext':
|
|
|
|
import mesonbuild.scripts.gettext as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'yelphelper':
|
|
|
|
import mesonbuild.scripts.yelphelper as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'uninstall':
|
|
|
|
import mesonbuild.scripts.uninstall as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'dist':
|
|
|
|
import mesonbuild.scripts.dist as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
elif cmdname == 'coverage':
|
|
|
|
import mesonbuild.scripts.coverage as abc
|
|
|
|
cmdfunc = abc.run
|
|
|
|
else:
|
|
|
|
raise MesonException('Unknown internal command {}.'.format(cmdname))
|
|
|
|
return cmdfunc(cmdargs)
|
|
|
|
|
Set the meson command to use when we know what it is
Instead of using fragile guessing to figure out how to invoke meson,
set the value when meson is run. Also rework how we pass of
meson_script_launcher to regenchecker.py -- it wasn't even being used
With this change, we only need to guess the meson path when running
the tests, and in that case:
1. If MESON_EXE is set in the env, we know how to run meson
for project tests.
2. MESON_EXE is not set, which means we run the configure in-process
for project tests and need to guess what meson to run, so either
- meson.py is found next to run_tests.py, or
- meson, meson.py, or meson.exe is in PATH
Otherwise, you can invoke meson in the following ways:
1. meson is installed, and mesonbuild is available in PYTHONPATH:
- meson, meson.py, meson.exe from PATH
- python3 -m mesonbuild.mesonmain
- python3 /path/to/meson.py
- meson is a shell wrapper to meson.real
2. meson is not installed, and is run from git:
- Absolute path to meson.py
- Relative path to meson.py
- Symlink to meson.py
All these are tested in test_meson_commands.py, except meson.exe since
that involves building the meson msi and installing it.
7 years ago
|
|
|
def run(original_args, mainfile):
|
|
|
|
if sys.version_info < (3, 5):
|
|
|
|
print('Meson works correctly only with python 3.5+.')
|
|
|
|
print('You have python %s.' % sys.version)
|
|
|
|
print('Please update your environment')
|
|
|
|
return 1
|
|
|
|
# https://github.com/mesonbuild/meson/issues/3653
|
|
|
|
if sys.platform.lower() == 'msys':
|
|
|
|
mlog.error('This python3 seems to be msys/python on MSYS2 Windows, which is known to have path semantics incompatible with Meson')
|
|
|
|
msys2_arch = detect_msys2_arch()
|
|
|
|
if msys2_arch:
|
|
|
|
mlog.error('Please install and use mingw-w64-i686-python3 and/or mingw-w64-x86_64-python3 with Pacman')
|
|
|
|
else:
|
|
|
|
mlog.error('Please download and use Python as detailed at: https://mesonbuild.com/Getting-meson.html')
|
|
|
|
return 2
|
|
|
|
|
Set the meson command to use when we know what it is
Instead of using fragile guessing to figure out how to invoke meson,
set the value when meson is run. Also rework how we pass of
meson_script_launcher to regenchecker.py -- it wasn't even being used
With this change, we only need to guess the meson path when running
the tests, and in that case:
1. If MESON_EXE is set in the env, we know how to run meson
for project tests.
2. MESON_EXE is not set, which means we run the configure in-process
for project tests and need to guess what meson to run, so either
- meson.py is found next to run_tests.py, or
- meson, meson.py, or meson.exe is in PATH
Otherwise, you can invoke meson in the following ways:
1. meson is installed, and mesonbuild is available in PYTHONPATH:
- meson, meson.py, meson.exe from PATH
- python3 -m mesonbuild.mesonmain
- python3 /path/to/meson.py
- meson is a shell wrapper to meson.real
2. meson is not installed, and is run from git:
- Absolute path to meson.py
- Relative path to meson.py
- Symlink to meson.py
All these are tested in test_meson_commands.py, except meson.exe since
that involves building the meson msi and installing it.
7 years ago
|
|
|
# Set the meson command that will be used to run scripts and so on
|
|
|
|
mesonlib.set_meson_command(mainfile)
|
|
|
|
|
|
|
|
args = original_args[:]
|
|
|
|
|
|
|
|
# Special handling of internal commands called from backends, they don't
|
|
|
|
# need to go through argparse.
|
|
|
|
if len(args) >= 2 and args[0] == '--internal':
|
|
|
|
if args[1] == 'regenerate':
|
|
|
|
# Rewrite "meson --internal regenerate" command line to
|
|
|
|
# "meson --reconfigure"
|
|
|
|
args = ['--reconfigure'] + args[2:]
|
|
|
|
else:
|
|
|
|
script = args[1]
|
|
|
|
try:
|
|
|
|
sys.exit(run_script_command(args[1:]))
|
|
|
|
except MesonException as e:
|
|
|
|
mlog.error('\nError in {} helper script:'.format(script))
|
|
|
|
mlog.exception(e)
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
if len(args) > 0:
|
|
|
|
# First check if we want to run a subcommand.
|
|
|
|
cmd_name = args[0]
|
|
|
|
remaining_args = args[1:]
|
|
|
|
# "help" is a special case: Since printing of the help may be
|
|
|
|
# delegated to a subcommand, we edit cmd_name before executing
|
|
|
|
# the rest of the logic here.
|
|
|
|
if cmd_name == 'help':
|
|
|
|
remaining_args += ['--help']
|
|
|
|
args = remaining_args
|
|
|
|
cmd_name = args[0]
|
|
|
|
if cmd_name == 'test':
|
|
|
|
from . import mtest
|
|
|
|
return mtest.run(remaining_args)
|
|
|
|
elif cmd_name == 'install':
|
|
|
|
from . import minstall
|
|
|
|
return minstall.run(remaining_args)
|
|
|
|
elif cmd_name == 'introspect':
|
|
|
|
from . import mintro
|
|
|
|
return mintro.run(remaining_args)
|
|
|
|
elif cmd_name == 'rewrite':
|
|
|
|
from . import rewriter
|
|
|
|
return rewriter.run(remaining_args)
|
|
|
|
elif cmd_name == 'configure':
|
|
|
|
try:
|
|
|
|
from . import mconf
|
|
|
|
return mconf.run(remaining_args)
|
|
|
|
except MesonException as e:
|
|
|
|
mlog.exception(e)
|
|
|
|
sys.exit(1)
|
|
|
|
elif cmd_name == 'wrap':
|
|
|
|
from .wrap import wraptool
|
|
|
|
return wraptool.run(remaining_args)
|
|
|
|
elif cmd_name == 'init':
|
|
|
|
from . import minit
|
|
|
|
return minit.run(remaining_args)
|
|
|
|
elif cmd_name == 'runpython':
|
|
|
|
import runpy
|
|
|
|
script_file = remaining_args[0]
|
|
|
|
sys.argv[1:] = remaining_args[1:]
|
|
|
|
runpy.run_path(script_file, run_name='__main__')
|
|
|
|
sys.exit(0)
|
|
|
|
else:
|
|
|
|
# If cmd_name is not a known command, assume user wants to run the
|
|
|
|
# setup command.
|
|
|
|
from . import msetup
|
|
|
|
if cmd_name != 'setup':
|
|
|
|
remaining_args = args
|
|
|
|
return msetup.run(remaining_args)
|
|
|
|
|
|
|
|
return 0
|
Set the meson command to use when we know what it is
Instead of using fragile guessing to figure out how to invoke meson,
set the value when meson is run. Also rework how we pass of
meson_script_launcher to regenchecker.py -- it wasn't even being used
With this change, we only need to guess the meson path when running
the tests, and in that case:
1. If MESON_EXE is set in the env, we know how to run meson
for project tests.
2. MESON_EXE is not set, which means we run the configure in-process
for project tests and need to guess what meson to run, so either
- meson.py is found next to run_tests.py, or
- meson, meson.py, or meson.exe is in PATH
Otherwise, you can invoke meson in the following ways:
1. meson is installed, and mesonbuild is available in PYTHONPATH:
- meson, meson.py, meson.exe from PATH
- python3 -m mesonbuild.mesonmain
- python3 /path/to/meson.py
- meson is a shell wrapper to meson.real
2. meson is not installed, and is run from git:
- Absolute path to meson.py
- Relative path to meson.py
- Symlink to meson.py
All these are tested in test_meson_commands.py, except meson.exe since
that involves building the meson msi and installing it.
7 years ago
|
|
|
|
|
|
|
def main():
|
|
|
|
# Always resolve the command path so Ninja can find it for regen, tests, etc.
|
|
|
|
if 'meson.exe' in sys.executable:
|
|
|
|
assert(os.path.isabs(sys.executable))
|
|
|
|
launcher = sys.executable
|
|
|
|
else:
|
|
|
|
launcher = os.path.realpath(sys.argv[0])
|
Set the meson command to use when we know what it is
Instead of using fragile guessing to figure out how to invoke meson,
set the value when meson is run. Also rework how we pass of
meson_script_launcher to regenchecker.py -- it wasn't even being used
With this change, we only need to guess the meson path when running
the tests, and in that case:
1. If MESON_EXE is set in the env, we know how to run meson
for project tests.
2. MESON_EXE is not set, which means we run the configure in-process
for project tests and need to guess what meson to run, so either
- meson.py is found next to run_tests.py, or
- meson, meson.py, or meson.exe is in PATH
Otherwise, you can invoke meson in the following ways:
1. meson is installed, and mesonbuild is available in PYTHONPATH:
- meson, meson.py, meson.exe from PATH
- python3 -m mesonbuild.mesonmain
- python3 /path/to/meson.py
- meson is a shell wrapper to meson.real
2. meson is not installed, and is run from git:
- Absolute path to meson.py
- Relative path to meson.py
- Symlink to meson.py
All these are tested in test_meson_commands.py, except meson.exe since
that involves building the meson msi and installing it.
7 years ago
|
|
|
return run(sys.argv[1:], launcher)
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
sys.exit(main())
|