mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
Minor cleanup of mach and bootstrap script
This commit is contained in:
parent
f83fe9e39b
commit
b579841183
2 changed files with 32 additions and 39 deletions
3
mach
3
mach
|
@ -12,11 +12,10 @@
|
||||||
from __future__ import print_function, unicode_literals
|
from __future__ import print_function, unicode_literals
|
||||||
|
|
||||||
import os
|
import os
|
||||||
from os import path
|
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
def main(args):
|
def main(args):
|
||||||
topdir = path.abspath(path.dirname(sys.argv[0]))
|
topdir = os.path.abspath(os.path.dirname(sys.argv[0]))
|
||||||
sys.path.insert(0, os.path.join(topdir, "python"))
|
sys.path.insert(0, os.path.join(topdir, "python"))
|
||||||
import mach_bootstrap
|
import mach_bootstrap
|
||||||
mach = mach_bootstrap.bootstrap(topdir)
|
mach = mach_bootstrap.bootstrap(topdir)
|
||||||
|
|
|
@ -6,9 +6,9 @@ from __future__ import print_function, unicode_literals
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import platform
|
import platform
|
||||||
import subprocess
|
|
||||||
import sys
|
import sys
|
||||||
from distutils.spawn import find_executable
|
from distutils.spawn import find_executable
|
||||||
|
from subprocess import PIPE, Popen
|
||||||
|
|
||||||
SEARCH_PATHS = [
|
SEARCH_PATHS = [
|
||||||
os.path.join("python", "tidy"),
|
os.path.join("python", "tidy"),
|
||||||
|
@ -26,7 +26,6 @@ MACH_MODULES = [
|
||||||
os.path.join('python', 'servo', 'devenv_commands.py'),
|
os.path.join('python', 'servo', 'devenv_commands.py'),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
CATEGORIES = {
|
CATEGORIES = {
|
||||||
'bootstrap': {
|
'bootstrap': {
|
||||||
'short': 'Bootstrap Commands',
|
'short': 'Bootstrap Commands',
|
||||||
|
@ -76,8 +75,13 @@ CATEGORIES = {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Possible names of executables
|
||||||
|
PYTHON_NAMES = ["python-2.7", "python2.7", "python2", "python"]
|
||||||
|
VIRTUALENV_NAMES = ["virtualenv-2.7", "virtualenv2.7", "virtualenv2", "virtualenv"]
|
||||||
|
PIP_NAMES = ["pip-2.7", "pip2.7", "pip2", "pip"]
|
||||||
|
|
||||||
def _get_exec(names, is_valid_path=lambda _path: True):
|
|
||||||
|
def _get_exec_path(names, is_valid_path=lambda _path: True):
|
||||||
for name in names:
|
for name in names:
|
||||||
path = find_executable(name)
|
path = find_executable(name)
|
||||||
if path and is_valid_path(path):
|
if path and is_valid_path(path):
|
||||||
|
@ -87,45 +91,37 @@ def _get_exec(names, is_valid_path=lambda _path: True):
|
||||||
|
|
||||||
def _get_virtualenv_script_dir():
|
def _get_virtualenv_script_dir():
|
||||||
# Virtualenv calls its scripts folder "bin" on linux/OSX/MSYS64 but "Scripts" on Windows
|
# Virtualenv calls its scripts folder "bin" on linux/OSX/MSYS64 but "Scripts" on Windows
|
||||||
if os.name == "nt" and os.path.sep != "/":
|
if os.name == "nt" and os.sep != "/":
|
||||||
return "Scripts"
|
return "Scripts"
|
||||||
return "bin"
|
return "bin"
|
||||||
|
|
||||||
|
|
||||||
# Possible names of executables, sorted from most to least specific
|
|
||||||
PYTHON_NAMES = ["python-2.7", "python2.7", "python2", "python"]
|
|
||||||
VIRTUALENV_NAMES = ["virtualenv-2.7", "virtualenv2.7", "virtualenv2", "virtualenv"]
|
|
||||||
PIP_NAMES = ["pip-2.7", "pip2.7", "pip2", "pip"]
|
|
||||||
|
|
||||||
|
|
||||||
def _activate_virtualenv(topdir):
|
def _activate_virtualenv(topdir):
|
||||||
virtualenv_path = os.path.join(topdir, "python", "_virtualenv")
|
virtualenv_path = os.path.join(topdir, "python", "_virtualenv")
|
||||||
check_exec_path = lambda path: path.startswith(virtualenv_path)
|
check_exec_path = lambda path: path.startswith(virtualenv_path)
|
||||||
python = _get_exec(PYTHON_NAMES)
|
python = _get_exec_path(PYTHON_NAMES) # If there was no python, mach wouldn't have run at all!
|
||||||
if python is None:
|
if not python:
|
||||||
sys.exit("Python is not installed. Please install it prior to running mach.")
|
sys.exit('Failed to find python executable for starting virtualenv.')
|
||||||
|
|
||||||
script_dir = _get_virtualenv_script_dir()
|
script_dir = _get_virtualenv_script_dir()
|
||||||
activate_path = os.path.join(virtualenv_path, script_dir, "activate_this.py")
|
activate_path = os.path.join(virtualenv_path, script_dir, "activate_this.py")
|
||||||
if not (os.path.exists(virtualenv_path) and os.path.exists(activate_path)):
|
if not (os.path.exists(virtualenv_path) and os.path.exists(activate_path)):
|
||||||
virtualenv = _get_exec(VIRTUALENV_NAMES)
|
virtualenv = _get_exec_path(VIRTUALENV_NAMES)
|
||||||
if virtualenv is None:
|
if not virtualenv:
|
||||||
sys.exit("Python virtualenv is not installed. Please install it prior to running mach.")
|
sys.exit("Python virtualenv is not installed. Please install it prior to running mach.")
|
||||||
|
|
||||||
process = subprocess.Popen(
|
process = Popen([virtualenv, "-p", python, virtualenv_path], stdout=PIPE, stderr=PIPE)
|
||||||
[virtualenv, "-p", python, virtualenv_path],
|
|
||||||
stdout=subprocess.PIPE,
|
|
||||||
stderr=subprocess.PIPE)
|
|
||||||
process.wait()
|
process.wait()
|
||||||
if process.returncode:
|
if process.returncode:
|
||||||
sys.exit("Python virtualenv failed to execute properly: {}"
|
out, err = process.communicate()
|
||||||
.format(process.communicate()[1]))
|
print('Python virtualenv failed to execute properly:')
|
||||||
|
sys.exit('Output: %s\nError: %s' % (out, err))
|
||||||
|
|
||||||
execfile(activate_path, dict(__file__=activate_path))
|
execfile(activate_path, dict(__file__=activate_path))
|
||||||
|
|
||||||
python = _get_exec(PYTHON_NAMES, is_valid_path=check_exec_path)
|
python = _get_exec_path(PYTHON_NAMES, is_valid_path=check_exec_path)
|
||||||
if python is None:
|
if not python:
|
||||||
sys.exit("Python virtualenv failed to activate.")
|
sys.exit("Python executable in virtualenv failed to activate.")
|
||||||
|
|
||||||
# TODO: Right now, we iteratively install all the requirements by invoking
|
# TODO: Right now, we iteratively install all the requirements by invoking
|
||||||
# `pip install` each time. If it were the case that there were conflicting
|
# `pip install` each time. If it were the case that there were conflicting
|
||||||
|
@ -139,28 +135,28 @@ def _activate_virtualenv(topdir):
|
||||||
os.path.join("tests", "wpt", "harness", "requirements_firefox.txt"),
|
os.path.join("tests", "wpt", "harness", "requirements_firefox.txt"),
|
||||||
os.path.join("tests", "wpt", "harness", "requirements_servo.txt"),
|
os.path.join("tests", "wpt", "harness", "requirements_servo.txt"),
|
||||||
]
|
]
|
||||||
|
|
||||||
for req_rel_path in requirements_paths:
|
for req_rel_path in requirements_paths:
|
||||||
req_path = os.path.join(topdir, req_rel_path)
|
req_path = os.path.join(topdir, req_rel_path)
|
||||||
marker_file = req_rel_path.replace(os.path.sep, '-')
|
marker_file = req_rel_path.replace(os.path.sep, '-')
|
||||||
marker_path = os.path.join(virtualenv_path, marker_file)
|
marker_path = os.path.join(virtualenv_path, marker_file)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
if os.path.getmtime(req_path) + 10 < os.path.getmtime(marker_path):
|
if os.path.getmtime(req_path) + 10 < os.path.getmtime(marker_path):
|
||||||
continue
|
continue
|
||||||
except OSError:
|
except OSError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
pip = _get_exec(PIP_NAMES, is_valid_path=check_exec_path)
|
pip = _get_exec_path(PIP_NAMES, is_valid_path=check_exec_path)
|
||||||
if pip is None:
|
if not pip:
|
||||||
sys.exit("Python pip is not installed. Please install it prior to running mach.")
|
sys.exit("Python pip is either not installed or not found in virtualenv.")
|
||||||
|
|
||||||
process = subprocess.Popen(
|
process = Popen([pip, "install", "-q", "-r", req_path], stdout=PIPE, stderr=PIPE)
|
||||||
[pip, "install", "-q", "-r", req_path],
|
|
||||||
stdout=subprocess.PIPE,
|
|
||||||
stderr=subprocess.PIPE)
|
|
||||||
process.wait()
|
process.wait()
|
||||||
if process.returncode:
|
if process.returncode:
|
||||||
sys.exit("Pip failed to execute properly: {}"
|
out, err = process.communicate()
|
||||||
.format(process.communicate()[1]))
|
print('Pip failed to execute properly:')
|
||||||
|
sys.exit('Output: %s\nError: %s' % (out, err))
|
||||||
|
|
||||||
open(marker_path, 'w').close()
|
open(marker_path, 'w').close()
|
||||||
|
|
||||||
|
@ -200,8 +196,7 @@ def bootstrap(topdir):
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
# Ensure we are running Python 2.7+. We put this check here so we generate a
|
# Ensure we are running Python 2.7+. We put this check here so we generate a
|
||||||
# user-friendly error message rather than a cryptic stack trace on module
|
# user-friendly error message rather than a cryptic stack trace on module import.
|
||||||
# import.
|
|
||||||
if not (3, 0) > sys.version_info >= (2, 7):
|
if not (3, 0) > sys.version_info >= (2, 7):
|
||||||
print('Python 2.7 or above (but not Python 3) is required to run mach.')
|
print('Python 2.7 or above (but not Python 3) is required to run mach.')
|
||||||
print('You are running Python', platform.python_version())
|
print('You are running Python', platform.python_version())
|
||||||
|
@ -222,8 +217,7 @@ def bootstrap(topdir):
|
||||||
mach.populate_context_handler = populate_context
|
mach.populate_context_handler = populate_context
|
||||||
|
|
||||||
for category, meta in CATEGORIES.items():
|
for category, meta in CATEGORIES.items():
|
||||||
mach.define_category(category, meta['short'], meta['long'],
|
mach.define_category(category, meta['short'], meta['long'], meta['priority'])
|
||||||
meta['priority'])
|
|
||||||
|
|
||||||
for path in MACH_MODULES:
|
for path in MACH_MODULES:
|
||||||
mach.load_commands_from_file(os.path.join(topdir, path))
|
mach.load_commands_from_file(os.path.join(topdir, path))
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue