2023-11-21 04:12:34 +08:00
|
|
|
# simple Makefile with scripts that are otherwise hard to remember
|
|
|
|
# to use, run from the repo root `make <command>`
|
|
|
|
|
2023-12-12 10:08:03 +08:00
|
|
|
default: help
|
|
|
|
|
|
|
|
help:
|
|
|
|
@echo Developer commands:
|
|
|
|
@echo
|
2024-03-08 08:53:11 +08:00
|
|
|
@echo "ruff Run ruff, fixing any safely-fixable errors and formatting"
|
|
|
|
@echo "ruff-unsafe Run ruff, fixing all fixable errors and formatting"
|
|
|
|
@echo "mypy Run mypy using the config in pyproject.toml to identify type mismatches and other coding errors"
|
|
|
|
@echo "mypy-all Run mypy ignoring the config in pyproject.tom but still ignoring missing imports"
|
|
|
|
@echo "test Run the unit tests."
|
|
|
|
@echo "update-config-docstring Update the app's config docstring so mkdocs can autogenerate it correctly."
|
|
|
|
@echo "frontend-install Install the pnpm modules needed for the front end"
|
|
|
|
@echo "frontend-build Build the frontend in order to run on localhost:9090"
|
|
|
|
@echo "frontend-dev Run the frontend in developer mode on localhost:5173"
|
|
|
|
@echo "frontend-typegen Generate types for the frontend from the OpenAPI schema"
|
|
|
|
@echo "installer-zip Build the installer .zip file for the current version"
|
|
|
|
@echo "tag-release Tag the GitHub repository with the current version (use at release time only!)"
|
2024-05-29 15:29:51 +08:00
|
|
|
@echo "openapi Generate the OpenAPI schema for the app, outputting to stdout"
|
2024-09-22 14:05:39 +08:00
|
|
|
@echo "docs Serve the mkdocs site with live reload"
|
2023-12-12 10:08:03 +08:00
|
|
|
|
2023-11-21 04:12:34 +08:00
|
|
|
# Runs ruff, fixing any safely-fixable errors and formatting
|
|
|
|
ruff:
|
2024-02-20 00:40:53 +08:00
|
|
|
ruff check . --fix
|
|
|
|
ruff format .
|
2023-11-21 04:12:34 +08:00
|
|
|
|
|
|
|
# Runs ruff, fixing all errors it can fix and formatting
|
|
|
|
ruff-unsafe:
|
2024-02-20 00:40:53 +08:00
|
|
|
ruff check . --fix --unsafe-fixes
|
|
|
|
ruff format .
|
2023-11-21 04:12:34 +08:00
|
|
|
|
|
|
|
# Runs mypy, using the config in pyproject.toml
|
|
|
|
mypy:
|
2024-02-20 00:40:53 +08:00
|
|
|
mypy scripts/invokeai-web.py
|
2023-11-21 04:12:34 +08:00
|
|
|
|
|
|
|
# Runs mypy, ignoring the config in pyproject.toml but still ignoring missing (untyped) imports
|
2023-11-21 04:18:04 +08:00
|
|
|
# (many files are ignored by the config, so this is useful for checking all files)
|
2023-11-21 04:12:34 +08:00
|
|
|
mypy-all:
|
2024-02-20 00:40:53 +08:00
|
|
|
mypy scripts/invokeai-web.py --config-file= --ignore-missing-imports
|
|
|
|
|
|
|
|
# Run the unit tests
|
|
|
|
test:
|
|
|
|
pytest ./tests
|
|
|
|
|
2024-03-08 08:53:11 +08:00
|
|
|
# Update config docstring
|
|
|
|
update-config-docstring:
|
|
|
|
python scripts/update_config_docstring.py
|
|
|
|
|
2024-02-20 00:40:53 +08:00
|
|
|
# Install the pnpm modules needed for the front end
|
|
|
|
frontend-install:
|
|
|
|
rm -rf invokeai/frontend/web/node_modules
|
|
|
|
cd invokeai/frontend/web && pnpm install
|
2023-12-12 10:08:03 +08:00
|
|
|
|
|
|
|
# Build the frontend
|
|
|
|
frontend-build:
|
|
|
|
cd invokeai/frontend/web && pnpm build
|
|
|
|
|
|
|
|
# Run the frontend in dev mode
|
|
|
|
frontend-dev:
|
|
|
|
cd invokeai/frontend/web && pnpm dev
|
|
|
|
|
2024-03-06 10:49:08 +08:00
|
|
|
frontend-typegen:
|
|
|
|
cd invokeai/frontend/web && python ../../../scripts/generate_openapi_schema.py | pnpm typegen
|
|
|
|
|
2023-12-12 10:08:03 +08:00
|
|
|
# Installer zip file
|
|
|
|
installer-zip:
|
|
|
|
cd installer && ./create_installer.sh
|
|
|
|
|
|
|
|
# Tag the release
|
|
|
|
tag-release:
|
2023-12-12 10:11:37 +08:00
|
|
|
cd installer && ./tag_release.sh
|
2023-12-12 10:08:03 +08:00
|
|
|
|
2024-05-29 15:29:51 +08:00
|
|
|
# Generate the OpenAPI Schema for the app
|
|
|
|
openapi:
|
|
|
|
python scripts/generate_openapi_schema.py
|
2024-09-22 14:05:39 +08:00
|
|
|
|
|
|
|
# Serve the mkdocs site w/ live reload
|
2024-09-22 14:54:36 +08:00
|
|
|
.PHONY: docs
|
2024-09-22 14:05:39 +08:00
|
|
|
docs:
|
|
|
|
mkdocs serve
|