mirror of
https://github.com/getpelican/pelican.git
synced 2025-10-15 20:28:56 +02:00
Add Windows support to Invoke tasks
This commit is contained in:
parent
13e138aacd
commit
1ac4abcb67
1 changed files with 11 additions and 9 deletions
20
tasks.py
20
tasks.py
|
|
@ -7,22 +7,24 @@ from invoke import task
|
||||||
PKG_NAME = "pelican"
|
PKG_NAME = "pelican"
|
||||||
PKG_PATH = Path("pelican")
|
PKG_PATH = Path("pelican")
|
||||||
DOCS_PORT = os.environ.get("DOCS_PORT", 8000)
|
DOCS_PORT = os.environ.get("DOCS_PORT", 8000)
|
||||||
|
BIN_DIR = "bin" if os.name != "nt" else "Scripts"
|
||||||
ACTIVE_VENV = os.environ.get("VIRTUAL_ENV", None)
|
ACTIVE_VENV = os.environ.get("VIRTUAL_ENV", None)
|
||||||
VENV_HOME = Path(os.environ.get("WORKON_HOME", "~/virtualenvs"))
|
VENV_HOME = Path(os.environ.get("WORKON_HOME", "~/virtualenvs"))
|
||||||
VENV_PATH = Path(ACTIVE_VENV) if ACTIVE_VENV else (VENV_HOME / PKG_NAME)
|
VENV_PATH = Path(ACTIVE_VENV) if ACTIVE_VENV else (VENV_HOME / PKG_NAME)
|
||||||
VENV = str(VENV_PATH.expanduser())
|
VENV = str(VENV_PATH.expanduser())
|
||||||
|
VENV_BIN = Path(VENV) / Path(BIN_DIR)
|
||||||
|
|
||||||
TOOLS = ["poetry", "pre-commit"]
|
TOOLS = ["poetry", "pre-commit"]
|
||||||
POETRY = which("poetry") if which("poetry") else (VENV / Path("bin") / "poetry")
|
POETRY = which("poetry") if which("poetry") else (VENV_BIN / "poetry")
|
||||||
PRECOMMIT = (
|
PRECOMMIT = (
|
||||||
which("pre-commit") if which("pre-commit") else (VENV / Path("bin") / "pre-commit")
|
which("pre-commit") if which("pre-commit") else (VENV_BIN / "pre-commit")
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@task
|
@task
|
||||||
def docbuild(c):
|
def docbuild(c):
|
||||||
"""Build documentation"""
|
"""Build documentation"""
|
||||||
c.run(f"{VENV}/bin/sphinx-build docs docs/_build")
|
c.run(f"{VENV_BIN}/sphinx-build docs docs/_build")
|
||||||
|
|
||||||
|
|
||||||
@task(docbuild)
|
@task(docbuild)
|
||||||
|
|
@ -40,7 +42,7 @@ def docserve(c):
|
||||||
@task
|
@task
|
||||||
def tests(c):
|
def tests(c):
|
||||||
"""Run the test suite"""
|
"""Run the test suite"""
|
||||||
c.run(f"{VENV}/bin/pytest", pty=True)
|
c.run(f"{VENV_BIN}/pytest", pty=True)
|
||||||
|
|
||||||
|
|
||||||
@task
|
@task
|
||||||
|
|
@ -51,7 +53,7 @@ def black(c, check=False, diff=False):
|
||||||
check_flag = "--check"
|
check_flag = "--check"
|
||||||
if diff:
|
if diff:
|
||||||
diff_flag = "--diff"
|
diff_flag = "--diff"
|
||||||
c.run(f"{VENV}/bin/black {check_flag} {diff_flag} {PKG_PATH} tasks.py")
|
c.run(f"{VENV_BIN}/black {check_flag} {diff_flag} {PKG_PATH} tasks.py")
|
||||||
|
|
||||||
|
|
||||||
@task
|
@task
|
||||||
|
|
@ -62,13 +64,13 @@ def isort(c, check=False, diff=False):
|
||||||
if diff:
|
if diff:
|
||||||
diff_flag = "--diff"
|
diff_flag = "--diff"
|
||||||
c.run(
|
c.run(
|
||||||
f"{VENV}/bin/isort {check_flag} {diff_flag} --recursive {PKG_PATH}/* tasks.py"
|
f"{VENV_BIN}/isort {check_flag} {diff_flag} --recursive {PKG_PATH}/* tasks.py"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@task
|
@task
|
||||||
def flake8(c):
|
def flake8(c):
|
||||||
c.run(f"{VENV}/bin/flake8 {PKG_PATH} tasks.py")
|
c.run(f"{VENV_BIN}/flake8 {PKG_PATH} tasks.py")
|
||||||
|
|
||||||
|
|
||||||
@task
|
@task
|
||||||
|
|
@ -83,7 +85,7 @@ def tools(c):
|
||||||
"""Install tools in the virtual environment if not already on PATH"""
|
"""Install tools in the virtual environment if not already on PATH"""
|
||||||
for tool in TOOLS:
|
for tool in TOOLS:
|
||||||
if not which(tool):
|
if not which(tool):
|
||||||
c.run(f"{VENV}/bin/pip install {tool}")
|
c.run(f"{VENV_BIN}/python -m pip install {tool}")
|
||||||
|
|
||||||
|
|
||||||
@task
|
@task
|
||||||
|
|
@ -94,7 +96,7 @@ def precommit(c):
|
||||||
|
|
||||||
@task
|
@task
|
||||||
def setup(c):
|
def setup(c):
|
||||||
c.run(f"{VENV}/bin/pip install -U pip")
|
c.run(f"{VENV_BIN}/python -m pip install -U pip")
|
||||||
tools(c)
|
tools(c)
|
||||||
c.run(f"{POETRY} install")
|
c.run(f"{POETRY} install")
|
||||||
precommit(c)
|
precommit(c)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue