-
Notifications
You must be signed in to change notification settings - Fork 1
/
makefile
104 lines (93 loc) · 3.05 KB
/
makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
# Get the current date
DATE := $(shell date +%Y-%m-%d)
# Import commit types from existing configuration
define COMMIT_TYPES
feat: A new feature
fix: A bug fix
docs: Documentation only changes
style: Changes that do not affect the meaning of the code
refactor: A code change that neither fixes a bug nor adds a feature
perf: A code change that improves performance
test: Adding missing tests or correcting existing tests
build: Changes that affect the build system or external dependencies
ci: Changes to CI configuration files and scripts
chore: Other changes that don't modify src or test files
revert: Reverts a previous commit
endef
export COMMIT_TYPES
repo-update: git-add git-commit git-push
git-add:
git add .
git-commit:
@echo "Available commit types:"
@echo "$$COMMIT_TYPES" | sed 's/^/ /'
@echo
@read -p "Enter commit type: " type; \
if echo "$$COMMIT_TYPES" | grep -q "^$$type:"; then \
read -p "Enter commit scope (optional, press enter to skip): " scope; \
read -p "Is this a breaking change? (y/N): " breaking; \
read -p "Enter commit message: " msg; \
if [ "$$breaking" = "y" ] || [ "$$breaking" = "Y" ]; then \
if [ -n "$$scope" ]; then \
git commit -m "$$type!($$scope): $$msg [$(DATE)]" -m "BREAKING CHANGE: $$msg"; \
else \
git commit -m "$$type!: $$msg [$(DATE)]" -m "BREAKING CHANGE: $$msg"; \
fi; \
else \
if [ -n "$$scope" ]; then \
git commit -m "$$type($$scope): $$msg [$(DATE)]"; \
else \
git commit -m "$$type: $$msg [$(DATE)]"; \
fi; \
fi; \
else \
echo "Invalid commit type. Please use one of the available types."; \
exit 1; \
fi
git-push:
git push
.PHONY: dev-env dev-env-kill load-env docker-services backend frontend
# Export all variables
export
# Load environment variables and export them
load-env:
@if [ -f .env ]; then \
set -a; \
. .env; \
set +a; \
$(eval include .env) \
$(eval export $(shell sed 's/=.*//' .env)) \
else \
echo "Error: .env file not found"; \
exit 1; \
fi
# Start Docker services
docker-services: load-env
@echo "Starting Docker services..."
docker-compose up -d
# Start backend services
backend: load-env
@echo "Starting backend services..."
cd gridwalk-backend && \
aws-vault exec gridw -- cargo run
# Start frontend services
frontend: load-env
@echo "Starting frontend services..."
cd gridwalk-ui && \
npm run dev
# Main command to set up development environment
dev-env: load-env
@echo "Setting up development environment..."
tmux new-session -d -s gridwalk
tmux rename-window -t gridwalk:0 'GRIDWALK DEV ENVIRONMENT'
tmux send-keys -t gridwalk:0 'make docker-services' C-m
tmux send-keys -t gridwalk:0 'cd gridwalk-ui && npm run dev' C-m
tmux split-window -h -t gridwalk:0
tmux send-keys -t gridwalk:0.1 'cd gridwalk-backend && echo $$AWS_PASS | aws-vault exec gridw -- cargo run' C-m
tmux select-window -t gridwalk:0
tmux attach-session -t gridwalk
# Kill the development environment
dev-env-kill:
@echo "Shutting down development environment..."
tmux kill-session -t gridwalk 2>/dev/null || true
docker-compose down