Skip to content

Commit

Permalink
remove 'decorator' dependency
Browse files Browse the repository at this point in the history
  • Loading branch information
danieleades committed Feb 11, 2024
1 parent ece7c9c commit fad3e75
Show file tree
Hide file tree
Showing 3 changed files with 485 additions and 488 deletions.
57 changes: 30 additions & 27 deletions copier/cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,57 +48,60 @@
```
"""

import functools
import sys
from os import PathLike
from pathlib import Path
from textwrap import dedent
from typing import Callable

import yaml
from decorator import decorator
from plumbum import cli, colors
from typing_extensions import ParamSpec

from .errors import UnsafeTemplateError, UserMessageError
from .main import Worker
from .tools import copier_version
from .types import AnyByStrDict, OptStr, StrSeq

P = ParamSpec("P")

@decorator
def handle_exceptions(method, *args, **kwargs):
"""Handle keyboard interruption while running a method."""
try:

def _handle_exceptions(method: Callable[P, int]) -> Callable[P, int]:
@functools.wraps(method)
def inner(*args: P.args, **kwargs: P.kwargs) -> int:
try:
return method(*args, **kwargs)
except KeyboardInterrupt:
raise UserMessageError("Execution stopped by user")
except UserMessageError as error:
print(colors.red | "\n".join(error.args), file=sys.stderr)
return 1
except UnsafeTemplateError as error:
print(colors.red | "\n".join(error.args), file=sys.stderr)
# DOCS https://github.com/copier-org/copier/issues/1328#issuecomment-1723214165
return 0b100
try:
return method(*args, **kwargs)
except KeyboardInterrupt:
raise UserMessageError("Execution stopped by user")
except UserMessageError as error:
print(colors.red | "\n".join(error.args), file=sys.stderr)
return 1
except UnsafeTemplateError as error:
print(colors.red | "\n".join(error.args), file=sys.stderr)
# DOCS https://github.com/copier-org/copier/issues/1328#issuecomment-1723214165
return 0b100

return inner


class CopierApp(cli.Application):
"""The Copier CLI application."""

DESCRIPTION = "Create a new project from a template."
DESCRIPTION_MORE = (
dedent(
"""\
DESCRIPTION_MORE = dedent(
"""\
Docs in https://copier.readthedocs.io/
"""
)
+ (
colors.yellow
| dedent(
"""\
) + (
colors.yellow
| dedent(
"""\
WARNING! Use only trusted project templates, as they might
execute code with the same level of access as your user.\n
"""
)
)
)
VERSION = copier_version()
Expand Down Expand Up @@ -247,7 +250,7 @@ class CopierCopySubApp(_Subcommand):
help="Overwrite files that already exist, without asking.",
)

@handle_exceptions
@_handle_exceptions
def main(self, template_src: str, destination_path: str) -> int:
"""Call [run_copy][copier.main.Worker.run_copy].
Expand Down Expand Up @@ -315,7 +318,7 @@ class CopierRecopySubApp(_Subcommand):
help="Skip questions that have already been answered",
)

@handle_exceptions
@_handle_exceptions
def main(self, destination_path: cli.ExistingDirectory = ".") -> int:
"""Call [run_recopy][copier.main.Worker.run_recopy].
Expand Down Expand Up @@ -387,7 +390,7 @@ class CopierUpdateSubApp(_Subcommand):
help="Skip questions that have already been answered",
)

@handle_exceptions
@_handle_exceptions
def main(self, destination_path: cli.ExistingDirectory = ".") -> int:
"""Call [run_update][copier.main.Worker.run_update].
Expand Down
Loading

0 comments on commit fad3e75

Please sign in to comment.