define BROWSER_PYSCRIPT import os, webbrowser, sys from urllib.request import pathname2url webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1]))) endef export BROWSER_PYSCRIPT define PRINT_HELP_PYSCRIPT import re, sys for line in sys.stdin: match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line) if match: target, help = match.groups() print("%-20s %s" % (target, help)) endef export PRINT_HELP_PYSCRIPT BROWSER := python -c "$$BROWSER_PYSCRIPT" help: @python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST) purge: clean ## โš ๏ธ Removes All Developer Data for a fresh server start rm -r ./dev/data/recipes/ rm -r ./dev/data/users/ rm -f ./dev/data/mealie_v*.db rm -f ./dev/data/mealie.log rm -f ./dev/data/.secret clean: clean-pyc clean-test ## ๐Ÿงน Remove all build, test, coverage and Python artifacts clean-pyc: ## ๐Ÿงน Remove Python file artifacts find . -name '*.pyc' -exec rm -f {} + find . -name '*.pyo' -exec rm -f {} + find . -name '*~' -exec rm -f {} + find . -name '__pycache__' -exec rm -fr {} + clean-test: ## ๐Ÿงน Remove test and coverage artifacts rm -fr .tox/ rm -f .coverage rm -fr htmlcov/ rm -fr .pytest_cache test-all: lint test ## ๐Ÿงช Check Lint Format and Testing test: ## ๐Ÿงช Run tests quickly with the default Python poetry run pytest lint: ## ๐Ÿงบ Check style with flake8 poetry run black . poetry run black . --check poetry run flake8 mealie tests coverage: ## โ˜‚๏ธ Check code coverage quickly with the default Python poetry run pytest poetry run coverage report -m poetry run coverage html $(BROWSER) htmlcov/index.html setup: ## ๐Ÿ— Setup Development Instance poetry install && \ cd frontend && \ npm install && \ cd .. backend: ## ๐ŸŽฌ Start Mealie Backend Development Server poetry run python mealie/db/init_db.py && \ poetry run python mealie/services/image/minify.py && \ poetry run python mealie/app.py .PHONY: frontend frontend: ## ๐ŸŽฌ Start Mealie Frontend Development Server cd frontend && npm run serve frontend-build: ## ๐Ÿ— Build Frontend in frontend/dist cd frontend && npm run build .PHONY: docs docs: ## ๐Ÿ“„ Start Mkdocs Development Server poetry run python dev/scripts/api_docs_gen.py && \ cd docs && poetry run python -m mkdocs serve docker-dev: ## ๐Ÿณ Build and Start Docker Development Stack docker-compose -f docker-compose.dev.yml -p dev-mealie up --build docker-prod: ## ๐Ÿณ Build and Start Docker Production Stack docker-compose -f docker-compose.yml -p mealie up --build code-gen: ## ๐Ÿค– Run Code-Gen Scripts poetry run python dev/scripts/app_routes_gen.py