Compare commits

..

No commits in common. "8e58d45e10a331231860cd502c3951c82c58f0aa" and "b3f4cffbca88c4430c5a780577a6b936f5c3c9e2" have entirely different histories.

9 changed files with 1250 additions and 1268 deletions

3
.editorconfig Normal file
View file

@ -0,0 +1,3 @@
[*.sh]
indent_size = 4
indent_style = space

1
.gitignore vendored
View file

@ -1,2 +1,3 @@
__pycache__ __pycache__
/dist /dist
/.venv

View file

@ -291,4 +291,3 @@ Handle project workflows in a unified way:
* tex * tex
* translate to french * translate to french
* try to support nix * try to support nix
* uv

54
spcd.sh
View file

@ -1,30 +1,30 @@
#! /usr/bin/env sh #! /usr/bin/env sh
gource \ gource \
--auto-skip-seconds 0.25 \ --auto-skip-seconds 0.25 \
--date-format "%Y / %m / %d ⋅ %H : %M : %S" \ --date-format "%Y / %m / %d ⋅ %H : %M : %S" \
--disable-input \ --disable-input \
--font-scale 2.5 \ --font-scale 2.5 \
--frameless \ --frameless \
--hide mouse,usernames \ --hide mouse,usernames \
--highlight-dirs \ --highlight-dirs \
--key \ --key \
--multi-sampling \ --multi-sampling \
--output-framerate 60 \ --output-framerate 60 \
--output-ppm-stream - \ --output-ppm-stream - \
--seconds-per-day 0.6 \ --seconds-per-day 0.6 \
--stop-at-end \ --stop-at-end \
--viewport "1920x1080" | --viewport "1920x1080" |
ffmpeg \ ffmpeg \
-codec:v ppm \ -codec:v ppm \
-format image2pipe \ -format image2pipe \
-framerate 120 \ -framerate 120 \
-i - \ -i - \
-codec:v libx264 \ -codec:v libx264 \
-preset veryslow \ -preset veryslow \
-qp 28 \ -qp 28 \
-movflags \ -movflags \
+faststart \ +faststart \
-pix_fmt yuv420p \ -pix_fmt yuv420p \
-y \ -y \
spcd.mp4 spcd.mp4

View file

@ -44,12 +44,8 @@ def clone_project_branch() -> None:
) )
def install_commands(path: Path) -> None: def install_commands(path: str) -> None:
"""Make commands callable in the operating system. """Make commands callable in the operating system."""
:param path: entry point that commands will call
:type path: Path
"""
step("Install commands") step("Install commands")
user = Path("/usr/local/bin") user = Path("/usr/local/bin")
for command in [ for command in [
@ -76,12 +72,10 @@ def install_python_packages() -> None:
"pydoclint", "pydoclint",
"pylint", "pylint",
"pytest", "pytest",
"PyYAML",
"ruff", "ruff",
"Sphinx", "sphinx",
"sphinx-rtd-theme", "sphinx-rtd-theme",
"twine", "twine",
"types-PyYAML",
] ]
for package in packages: for package in packages:
log.info(package) log.info(package)
@ -98,12 +92,8 @@ def list_environment_variables() -> None:
log.info("%s", variable) log.info("%s", variable)
def main(main_file: Path) -> None: def main(main_file: str) -> None:
"""Entry point to initialize environment or run a specific command. """Entry point to initialize environment or run a specific command."""
:param main_file: entry point file calling this function
:type main_file: Path
"""
paths = environ["PATH"].split(pathsep) paths = environ["PATH"].split(pathsep)
if env.SPCD_PYTHON_VENV_BINARIES not in paths: if env.SPCD_PYTHON_VENV_BINARIES not in paths:
environ["PATH"] = pathsep.join([env.SPCD_PYTHON_VENV_BINARIES, *paths]) environ["PATH"] = pathsep.join([env.SPCD_PYTHON_VENV_BINARIES, *paths])

View file

@ -4,7 +4,6 @@
import importlib import importlib
import sys import sys
from pathlib import Path
if __name__ == "__main__": if __name__ == "__main__":
env = importlib.import_module("env") env = importlib.import_module("env")
@ -12,4 +11,4 @@ if __name__ == "__main__":
sys.path.insert(0, env.SPCD_PYTHON_VENV_PACKAGES) sys.path.insert(0, env.SPCD_PYTHON_VENV_PACKAGES)
from spcd import main from spcd import main
main(Path(__file__)) main(__file__)

File diff suppressed because it is too large Load diff

View file

@ -32,13 +32,7 @@ def spcd_check_project() -> None:
def spcd_synchronize( def spcd_synchronize(
target: str | None = None, source: str | None = None target: str | None = None, source: str | None = None
) -> None: ) -> None:
"""Synchronize output towards a target. """Synchronize output towards a target."""
:param target: where to deploy to
:type target: str | None
:param source: where to deploy from
:type source: str | None
"""
if not target: if not target:
user = "cd" user = "cd"
host = env.SPCD_PROJECT_PATH host = env.SPCD_PROJECT_PATH

View file

@ -28,11 +28,7 @@ class Project:
"""Current project.""" """Current project."""
def __init__(self, projects: Projects) -> None: def __init__(self, projects: Projects) -> None:
"""Set projects, branch, name, root & url. """Set projects, branch, name, root & url."""
:param projects: parent class with environment
:type projects: Projects
"""
self.projects = projects self.projects = projects
# branch # branch
for variable in BRANCH: for variable in BRANCH: