pyodide/pyodide-build/pyodide_build/__main__.py

65 lines
1.9 KiB
Python
Executable File

#!/usr/bin/env python3
import argparse
import os
import sys
from . import buildall, buildpkg, mkpkg, serve
from .common import get_hostsitepackages, get_make_environment_vars, search_pyodide_root
def make_parser() -> argparse.ArgumentParser:
"""Create an argument parser with argparse"""
main_parser = argparse.ArgumentParser(prog="pyodide")
main_parser.description = "A command line interface (CLI) for pyodide_build"
subparsers = main_parser.add_subparsers(help="action")
for command_name, module in (
("buildpkg", buildpkg),
("buildall", buildall),
("serve", serve),
("mkpkg", mkpkg),
):
if "sphinx" in sys.modules and command_name in [
"buildpkg",
"buildall",
"pywasmcross",
]:
# Likely building documentation, skip private API
continue
parser = module.make_parser(subparsers.add_parser(command_name))
parser.set_defaults(func=module.main)
return main_parser
def main():
if not os.environ.get("__LOADED_PYODIDE_ENV"):
# If we are building docs, we don't need to know the PYODIDE_ROOT
if "sphinx" in sys.modules:
os.environ["PYODIDE_ROOT"] = ""
if "PYODIDE_ROOT" not in os.environ:
os.environ["PYODIDE_ROOT"] = str(search_pyodide_root(os.getcwd()))
os.environ.update(get_make_environment_vars())
hostsitepackages = get_hostsitepackages()
pythonpath = [
hostsitepackages,
]
os.environ["PYTHONPATH"] = ":".join(pythonpath)
os.environ["BASH_ENV"] = ""
os.environ["__LOADED_PYODIDE_ENV"] = "1"
main_parser = make_parser()
args = main_parser.parse_args()
if hasattr(args, "func"):
# run the selected action
args.func(args)
else:
main_parser.print_help()
if __name__ == "__main__":
main()