-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
66 lines (60 loc) · 3.05 KB
/
Makefile
File metadata and controls
66 lines (60 loc) · 3.05 KB
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
# Makefile
# Variables to hold version tags and contributor names
VERSION_OLD ?=
VERSION_NEW ?=
CONTRIBUTORS ?= $(shell git log --pretty=format:'%an' $(VERSION_OLD)..$(VERSION_NEW) | sort | uniq)
# Claude API settings
CLAUDE_MODEL ?= claude-sonnet-4-20250514
MAX_TOKENS ?= 1024
ANTHROPIC_VERSION ?= 2023-06-01
.PHONY: generate-notes prompt all
prompt:
ifndef VERSION_OLD
@echo "Error: VERSION_OLD is not set. Please set it like: make prompt VERSION_OLD=x.x.x VERSION_NEW=y.y.y CONTRIBUTORS='@user1, @user2'"
@exit 1
endif
ifndef VERSION_NEW
@echo "Error: VERSION_NEW is not set. Please set it like: make prompt VERSION_OLD=x.x.x VERSION_NEW=y.y.y CONTRIBUTORS='@user1, @user2'"
@exit 1
endif
@echo "Generate a release note for MediaFlow $(VERSION_NEW) by analyzing the following changes. Organize the release note by importance rather than by commit order. highlight the most significant updates first, and streamline the content to focus on what adds the most value to the user. Ensure to dynamically create sections for New Features & Enhancements, Bug Fixes, and Documentation updates only if relevant based on the types of changes listed. Use emojis relevantly at the start of each item to enhance readability and engagement. Keep the format straightforward & shorter, provide a direct link to the detailed list of changes:\n"
@echo "## 🚀 MediaFlow $(VERSION_NEW) Released\n"
@echo "### Commit Messages and Descriptions:\n"
@git log --pretty=format:'%s%n%b' $(VERSION_OLD)..$(VERSION_NEW) | awk 'BEGIN {RS="\n\n"; FS="\n"} { \
message = $$1; \
description = ""; \
for (i=2; i<=NF; i++) { \
if ($$i ~ /^\*/) description = description " " $$i "\n"; \
else if ($$i != "") description = description " " $$i "\n"; \
} \
if (message != "") print "- " message; \
if (description != "") printf "%s", description; \
}'
@echo "--- \n### 🤝 Contributors: $(CONTRIBUTORS)\n\n### 📄 Full Changelog:\nhttps://github.com/mhdzumair/mediaflow-proxy/compare/$(VERSION_OLD)...$(VERSION_NEW)";
generate-notes:
ifndef VERSION_OLD
@echo "Error: VERSION_OLD is not set"
@exit 1
endif
ifndef VERSION_NEW
@echo "Error: VERSION_NEW is not set"
@exit 1
endif
ifndef ANTHROPIC_API_KEY
@echo "Error: ANTHROPIC_API_KEY is not set"
@exit 1
endif
@PROMPT_CONTENT=$$(make prompt VERSION_OLD=$(VERSION_OLD) VERSION_NEW=$(VERSION_NEW) | jq -sRr @json); \
if [ -z "$$PROMPT_CONTENT" ]; then \
echo "Failed to generate release notes using Claude AI, prompt content is empty"; \
exit 1; \
fi; \
temp_file=$$(mktemp); \
curl -s https://api.anthropic.com/v1/messages \
--header "x-api-key: $(ANTHROPIC_API_KEY)" \
--header "anthropic-version: $(ANTHROPIC_VERSION)" \
--header "content-type: application/json" \
--data "{\"model\":\"$(CLAUDE_MODEL)\",\"max_tokens\":$(MAX_TOKENS),\"messages\":[{\"role\":\"user\",\"content\":$$PROMPT_CONTENT}]}" > $$temp_file; \
jq -r '.content[] | select(.type=="text") | .text' $$temp_file || { echo "Failed to generate release notes using Claude AI, response: $$(cat $$temp_file)"; rm $$temp_file; exit 1; } ; \
rm $$temp_file
all: generate-notes