145 lines
4.6 KiB
Makefile
145 lines
4.6 KiB
Makefile
.PHONY: clean data lint requirements sync_data_to_s3 sync_data_from_s3
|
|
|
|
#################################################################################
|
|
# GLOBALS #
|
|
#################################################################################
|
|
|
|
PROJECT_DIR := $(shell dirname $(realpath $(lastword $(MAKEFILE_LIST))))
|
|
BUCKET = [OPTIONAL] your-bucket-for-syncing-data (do not include 's3://')
|
|
PROFILE = default
|
|
PROJECT_NAME = project_name
|
|
PYTHON_INTERPRETER = python3
|
|
|
|
ifeq (,$(shell which conda))
|
|
HAS_CONDA=False
|
|
else
|
|
HAS_CONDA=True
|
|
endif
|
|
|
|
#################################################################################
|
|
# COMMANDS #
|
|
#################################################################################
|
|
|
|
## Install Python Dependencies
|
|
requirements: test_environment
|
|
$(PYTHON_INTERPRETER) -m pip install -U pip setuptools wheel
|
|
$(PYTHON_INTERPRETER) -m pip install -r requirements.txt
|
|
|
|
## Make Dataset
|
|
data: requirements
|
|
$(PYTHON_INTERPRETER) src/data/make_dataset.py data/raw
|
|
|
|
## Delete all compiled Python files
|
|
clean:
|
|
find . -type f -name "*.py[co]" -delete
|
|
find . -type d -name "__pycache__" -delete
|
|
|
|
## Lint using flake8
|
|
lint:
|
|
flake8 src
|
|
|
|
## Upload Data to S3
|
|
sync_data_to_s3:
|
|
ifeq (default,$(PROFILE))
|
|
aws s3 sync data/ s3://$(BUCKET)/data/
|
|
else
|
|
aws s3 sync data/ s3://$(BUCKET)/data/ --profile $(PROFILE)
|
|
endif
|
|
|
|
## Download Data from S3
|
|
sync_data_from_s3:
|
|
ifeq (default,$(PROFILE))
|
|
aws s3 sync s3://$(BUCKET)/data/ data/
|
|
else
|
|
aws s3 sync s3://$(BUCKET)/data/ data/ --profile $(PROFILE)
|
|
endif
|
|
|
|
## Set up python interpreter environment
|
|
create_environment:
|
|
ifeq (True,$(HAS_CONDA))
|
|
@echo ">>> Detected conda, creating conda environment."
|
|
ifeq (3,$(findstring 3,$(PYTHON_INTERPRETER)))
|
|
conda create --name $(PROJECT_NAME) python=3
|
|
else
|
|
conda create --name $(PROJECT_NAME) python=2.7
|
|
endif
|
|
@echo ">>> New conda env created. Activate with:\nsource activate $(PROJECT_NAME)"
|
|
else
|
|
$(PYTHON_INTERPRETER) -m pip install -q virtualenv virtualenvwrapper
|
|
@echo ">>> Installing virtualenvwrapper if not already installed.\nMake sure the following lines are in shell startup file\n\
|
|
export WORKON_HOME=$$HOME/.virtualenvs\nexport PROJECT_HOME=$$HOME/Devel\nsource /usr/local/bin/virtualenvwrapper.sh\n"
|
|
@bash -c "source `which virtualenvwrapper.sh`;mkvirtualenv $(PROJECT_NAME) --python=$(PYTHON_INTERPRETER)"
|
|
@echo ">>> New virtualenv created. Activate with:\nworkon $(PROJECT_NAME)"
|
|
endif
|
|
|
|
## Test python environment is setup correctly
|
|
test_environment:
|
|
$(PYTHON_INTERPRETER) test_environment.py
|
|
|
|
#################################################################################
|
|
# PROJECT RULES #
|
|
#################################################################################
|
|
|
|
|
|
|
|
#################################################################################
|
|
# Self Documenting Commands #
|
|
#################################################################################
|
|
|
|
.DEFAULT_GOAL := help
|
|
|
|
# Inspired by <http://marmelab.com/blog/2016/02/29/auto-documented-makefile.html>
|
|
# sed script explained:
|
|
# /^##/:
|
|
# * save line in hold space
|
|
# * purge line
|
|
# * Loop:
|
|
# * append newline + line to hold space
|
|
# * go to next line
|
|
# * if line starts with doc comment, strip comment character off and loop
|
|
# * remove target prerequisites
|
|
# * append hold space (+ newline) to line
|
|
# * replace newline plus comments by `---`
|
|
# * print line
|
|
# Separate expressions are necessary because labels cannot be delimited by
|
|
# semicolon; see <http://stackoverflow.com/a/11799865/1968>
|
|
.PHONY: help
|
|
help:
|
|
@echo "$$(tput bold)Available rules:$$(tput sgr0)"
|
|
@echo
|
|
@sed -n -e "/^## / { \
|
|
h; \
|
|
s/.*//; \
|
|
:doc" \
|
|
-e "H; \
|
|
n; \
|
|
s/^## //; \
|
|
t doc" \
|
|
-e "s/:.*//; \
|
|
G; \
|
|
s/\\n## /---/; \
|
|
s/\\n/ /g; \
|
|
p; \
|
|
}" ${MAKEFILE_LIST} \
|
|
| LC_ALL='C' sort --ignore-case \
|
|
| awk -F '---' \
|
|
-v ncol=$$(tput cols) \
|
|
-v indent=19 \
|
|
-v col_on="$$(tput setaf 6)" \
|
|
-v col_off="$$(tput sgr0)" \
|
|
'{ \
|
|
printf "%s%*s%s ", col_on, -indent, $$1, col_off; \
|
|
n = split($$2, words, " "); \
|
|
line_length = ncol - indent; \
|
|
for (i = 1; i <= n; i++) { \
|
|
line_length -= length(words[i]) + 1; \
|
|
if (line_length <= 0) { \
|
|
line_length = ncol - indent - length(words[i]) - 1; \
|
|
printf "\n%*s ", -indent, " "; \
|
|
} \
|
|
printf "%s ", words[i]; \
|
|
} \
|
|
printf "\n"; \
|
|
}' \
|
|
| more $(shell test $(shell uname) = Darwin && echo '--no-init --raw-control-chars')
|