aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/mesonlib.py
diff options
context:
space:
mode:
authorXavier Claessens <xavier.claessens@collabora.com>2018-09-18 11:57:15 -0400
committerXavier Claessens <xavier.claessens@collabora.com>2018-10-04 09:39:26 -0400
commit246d5d86f5b6fe8c3680ab2fc1c52d6c55cffa0c (patch)
treedc2f7bba7fa7f995c3eca32f71154391b70be6f7 /mesonbuild/mesonlib.py
parent65cb7b02410ca24e61985940e193dc7c5c6f5d8c (diff)
downloadmeson-246d5d86f5b6fe8c3680ab2fc1c52d6c55cffa0c.zip
meson-246d5d86f5b6fe8c3680ab2fc1c52d6c55cffa0c.tar.gz
meson-246d5d86f5b6fe8c3680ab2fc1c52d6c55cffa0c.tar.bz2
Move set_meson_command() to mesonlib
Diffstat (limited to 'mesonbuild/mesonlib.py')
-rw-r--r--mesonbuild/mesonlib.py17
1 files changed, 17 insertions, 0 deletions
diff --git a/mesonbuild/mesonlib.py b/mesonbuild/mesonlib.py
index 8648a0d..33900b6 100644
--- a/mesonbuild/mesonlib.py
+++ b/mesonbuild/mesonlib.py
@@ -48,6 +48,23 @@ else:
python_command = [sys.executable]
meson_command = None
+def set_meson_command(mainfile):
+ global python_command
+ global meson_command
+ # On UNIX-like systems `meson` is a Python script
+ # On Windows `meson` and `meson.exe` are wrapper exes
+ if not mainfile.endswith('.py'):
+ meson_command = [mainfile]
+ elif os.path.isabs(mainfile) and mainfile.endswith('mesonmain.py'):
+ # Can't actually run meson with an absolute path to mesonmain.py, it must be run as -m mesonbuild.mesonmain
+ meson_command = python_command + ['-m', 'mesonbuild.mesonmain']
+ else:
+ # Either run uninstalled, or full path to meson-script.py
+ meson_command = python_command + [mainfile]
+ # We print this value for unit tests.
+ if 'MESON_COMMAND_TESTS' in os.environ:
+ mlog.log('meson_command is {!r}'.format(meson_command))
+
def is_ascii_string(astring):
try:
if isinstance(astring, str):