mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-13 18:56:36 +03:00
Merge pull request #5679 from svlandeg/fix/project-exp
This commit is contained in:
commit
3383d1c822
|
@ -88,7 +88,7 @@ def project_clone_cli(
|
||||||
|
|
||||||
@project_cli.command("init")
|
@project_cli.command("init")
|
||||||
def project_init_cli(
|
def project_init_cli(
|
||||||
path: Path = Arg(..., help="Path to cloned project", exists=True, file_okay=False),
|
path: Path = Arg(Path.cwd(), help="Path to cloned project. Defaults to current working directory.", exists=True, file_okay=False),
|
||||||
git: bool = Opt(False, "--git", "-G", help="Initialize project as a Git repo"),
|
git: bool = Opt(False, "--git", "-G", help="Initialize project as a Git repo"),
|
||||||
force: bool = Opt(False, "--force", "-F", help="Force initiziation"),
|
force: bool = Opt(False, "--force", "-F", help="Force initiziation"),
|
||||||
):
|
):
|
||||||
|
@ -104,7 +104,7 @@ def project_init_cli(
|
||||||
@project_cli.command("assets")
|
@project_cli.command("assets")
|
||||||
def project_assets_cli(
|
def project_assets_cli(
|
||||||
# fmt: off
|
# fmt: off
|
||||||
project_dir: Path = Arg(..., help="Path to cloned project", exists=True, file_okay=False),
|
project_dir: Path = Arg(Path.cwd(), help="Path to cloned project. Defaults to current working directory.", exists=True, file_okay=False),
|
||||||
# fmt: on
|
# fmt: on
|
||||||
):
|
):
|
||||||
"""Use DVC (Data Version Control) to fetch project assets. Assets are
|
"""Use DVC (Data Version Control) to fetch project assets. Assets are
|
||||||
|
@ -125,7 +125,7 @@ def project_assets_cli(
|
||||||
def project_run_all_cli(
|
def project_run_all_cli(
|
||||||
# fmt: off
|
# fmt: off
|
||||||
ctx: typer.Context,
|
ctx: typer.Context,
|
||||||
project_dir: Path = Arg(..., help="Location of project directory", exists=True, file_okay=False),
|
project_dir: Path = Arg(Path.cwd(), help="Location of project directory. Defaults to current working directory.", exists=True, file_okay=False),
|
||||||
show_help: bool = Opt(False, "--help", help="Show help message and available subcommands")
|
show_help: bool = Opt(False, "--help", help="Show help message and available subcommands")
|
||||||
# fmt: on
|
# fmt: on
|
||||||
):
|
):
|
||||||
|
@ -149,8 +149,8 @@ def project_run_all_cli(
|
||||||
def project_run_cli(
|
def project_run_cli(
|
||||||
# fmt: off
|
# fmt: off
|
||||||
ctx: typer.Context,
|
ctx: typer.Context,
|
||||||
project_dir: Path = Arg(..., help="Location of project directory", exists=True, file_okay=False),
|
|
||||||
subcommand: str = Arg(None, help="Name of command defined in project config"),
|
subcommand: str = Arg(None, help="Name of command defined in project config"),
|
||||||
|
project_dir: Path = Arg(Path.cwd(), help="Location of project directory. Defaults to current working directory.", exists=True, file_okay=False),
|
||||||
show_help: bool = Opt(False, "--help", help="Show help message and available subcommands")
|
show_help: bool = Opt(False, "--help", help="Show help message and available subcommands")
|
||||||
# fmt: on
|
# fmt: on
|
||||||
):
|
):
|
||||||
|
@ -173,8 +173,8 @@ def project_run_cli(
|
||||||
@project_cli.command("exec", hidden=True)
|
@project_cli.command("exec", hidden=True)
|
||||||
def project_exec_cli(
|
def project_exec_cli(
|
||||||
# fmt: off
|
# fmt: off
|
||||||
project_dir: Path = Arg(..., help="Location of project directory", exists=True, file_okay=False),
|
|
||||||
subcommand: str = Arg(..., help="Name of command defined in project config"),
|
subcommand: str = Arg(..., help="Name of command defined in project config"),
|
||||||
|
project_dir: Path = Arg(Path.cwd(), help="Location of project directory. Defaults to current working directory.", exists=True, file_okay=False),
|
||||||
# fmt: on
|
# fmt: on
|
||||||
):
|
):
|
||||||
"""Execute a command defined in the project config. This CLI command is
|
"""Execute a command defined in the project config. This CLI command is
|
||||||
|
@ -188,7 +188,7 @@ def project_exec_cli(
|
||||||
@project_cli.command("update-dvc")
|
@project_cli.command("update-dvc")
|
||||||
def project_update_dvc_cli(
|
def project_update_dvc_cli(
|
||||||
# fmt: off
|
# fmt: off
|
||||||
project_dir: Path = Arg(..., help="Location of project directory", exists=True, file_okay=False),
|
project_dir: Path = Arg(Path.cwd(), help="Location of project directory. Defaults to current working directory.", exists=True, file_okay=False),
|
||||||
verbose: bool = Opt(False, "--verbose", "-V", help="Print more info"),
|
verbose: bool = Opt(False, "--verbose", "-V", help="Print more info"),
|
||||||
force: bool = Opt(False, "--force", "-F", help="Force update DVC config"),
|
force: bool = Opt(False, "--force", "-F", help="Force update DVC config"),
|
||||||
# fmt: on
|
# fmt: on
|
||||||
|
@ -397,13 +397,13 @@ def print_run_help(project_dir: Path, subcommand: Optional[str] = None) -> None:
|
||||||
commands = {cmd["name"]: cmd for cmd in config_commands}
|
commands = {cmd["name"]: cmd for cmd in config_commands}
|
||||||
if subcommand:
|
if subcommand:
|
||||||
validate_subcommand(commands.keys(), subcommand)
|
validate_subcommand(commands.keys(), subcommand)
|
||||||
print(f"Usage: {COMMAND} project run {project_dir} {subcommand}")
|
print(f"Usage: {COMMAND} project run {subcommand} {project_dir}")
|
||||||
help_text = commands[subcommand].get("help")
|
help_text = commands[subcommand].get("help")
|
||||||
if help_text:
|
if help_text:
|
||||||
msg.text(f"\n{help_text}\n")
|
msg.text(f"\n{help_text}\n")
|
||||||
else:
|
else:
|
||||||
print(f"\nAvailable commands in {CONFIG_FILE}")
|
print(f"\nAvailable commands in {CONFIG_FILE}")
|
||||||
print(f"Usage: {COMMAND} project run {project_dir} [COMMAND]")
|
print(f"Usage: {COMMAND} project run [COMMAND] {project_dir}")
|
||||||
msg.table([(cmd["name"], cmd.get("help", "")) for cmd in config_commands])
|
msg.table([(cmd["name"], cmd.get("help", "")) for cmd in config_commands])
|
||||||
msg.text("Run all commands defined in the 'run' block of the project config:")
|
msg.text("Run all commands defined in the 'run' block of the project config:")
|
||||||
print(f"{COMMAND} project run-all {project_dir}")
|
print(f"{COMMAND} project run-all {project_dir}")
|
||||||
|
@ -525,7 +525,7 @@ def update_dvc_config(
|
||||||
continue
|
continue
|
||||||
# Default to "." as the project path since dvc.yaml is auto-generated
|
# Default to "." as the project path since dvc.yaml is auto-generated
|
||||||
# and we don't want arbitrary paths in there
|
# and we don't want arbitrary paths in there
|
||||||
project_cmd = ["python", "-m", NAME, "project", "exec", ".", name]
|
project_cmd = ["python", "-m", NAME, "project", ".", "exec", name]
|
||||||
deps_cmd = [c for cl in [["-d", p] for p in deps] for c in cl]
|
deps_cmd = [c for cl in [["-d", p] for p in deps] for c in cl]
|
||||||
outputs_cmd = [c for cl in [["-o", p] for p in outputs] for c in cl]
|
outputs_cmd = [c for cl in [["-o", p] for p in outputs] for c in cl]
|
||||||
outputs_nc_cmd = [c for cl in [["-O", p] for p in outputs_no_cache] for c in cl]
|
outputs_nc_cmd = [c for cl in [["-O", p] for p in outputs_no_cache] for c in cl]
|
||||||
|
@ -609,7 +609,7 @@ def run_commands(
|
||||||
elif len(command) and command[0] in ("pip", "pip3"):
|
elif len(command) and command[0] in ("pip", "pip3"):
|
||||||
command = [sys.executable, "-m", "pip", *command[1:]]
|
command = [sys.executable, "-m", "pip", *command[1:]]
|
||||||
if not silent:
|
if not silent:
|
||||||
print(" ".join(command))
|
print(f"Running command: {command}")
|
||||||
run_command(command)
|
run_command(command)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -539,6 +539,7 @@ class Errors(object):
|
||||||
E199 = ("Unable to merge 0-length span at doc[{start}:{end}].")
|
E199 = ("Unable to merge 0-length span at doc[{start}:{end}].")
|
||||||
|
|
||||||
# TODO: fix numbering after merging develop into master
|
# TODO: fix numbering after merging develop into master
|
||||||
|
E970 = ("Can not execute command '{str_command}'. Do you have '{tool}' installed?")
|
||||||
E971 = ("Found incompatible lengths in Doc.from_array: {array_length} for the "
|
E971 = ("Found incompatible lengths in Doc.from_array: {array_length} for the "
|
||||||
"array and {doc_length} for the Doc itself.")
|
"array and {doc_length} for the Doc itself.")
|
||||||
E972 = ("Example.__init__ got None for '{arg}'. Requires Doc.")
|
E972 = ("Example.__init__ got None for '{arg}'. Requires Doc.")
|
||||||
|
|
|
@ -452,7 +452,12 @@ def run_command(command: Union[str, List[str]]) -> None:
|
||||||
"""
|
"""
|
||||||
if isinstance(command, str):
|
if isinstance(command, str):
|
||||||
command = split_command(command)
|
command = split_command(command)
|
||||||
status = subprocess.call(command, env=os.environ.copy())
|
try:
|
||||||
|
status = subprocess.call(command, env=os.environ.copy())
|
||||||
|
except FileNotFoundError:
|
||||||
|
raise FileNotFoundError(
|
||||||
|
Errors.E970.format(str_command=" ".join(command), tool=command[0])
|
||||||
|
)
|
||||||
if status != 0:
|
if status != 0:
|
||||||
sys.exit(status)
|
sys.exit(status)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user