12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- .DEFAULT_GOAL := help
-
- .PHONY: install
- install: ## Install the dependencies
- python -m pip install -r requirements.txt
-
-
- .PHONY: build
- build: ## Generate the site
- @python site.py pages tags feed home
-
- .PHONY: publish
- publish: ## Make heay actions
- @python site.py search blogroll
-
-
- .PHONY: live
- live: ## Rebuild contents on file change.
- ls david/2023/_sources/* | entr -r make build
-
-
- .PHONY: toot
- toot: ## Pre-write the Mastodon message.
- @python site.py toot
-
-
- .PHONY: help
- help:
- @python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
-
- # See https://daniel.feldroy.com/posts/autodocumenting-makefiles
- define PRINT_HELP_PYSCRIPT # start of Python section
- import re, sys
-
- output = []
- # Loop through the lines in this file
- for line in sys.stdin:
- # if the line has a command and a comment start with
- # two pound signs, add it to the output
- match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line)
- if match:
- target, help = match.groups()
- output.append("\033[36m%-10s\033[0m %s" % (target, help))
- # Sort the output in alphanumeric order
- output.sort()
- # Print the help result
- print('\n'.join(output))
- endef
- export PRINT_HELP_PYSCRIPT # End of python section
|