kernel/Makefile: enhance version retrieval logic with GitHub commit count
This commit is contained in:
@@ -21,41 +21,50 @@ obj-$(CONFIG_KPM) += kpm/
|
|||||||
|
|
||||||
REPO_OWNER := SukiSU-Ultra
|
REPO_OWNER := SukiSU-Ultra
|
||||||
REPO_NAME := SukiSU-Ultra
|
REPO_NAME := SukiSU-Ultra
|
||||||
|
REPO_BRANCH := main
|
||||||
KSU_API_VERSION_LOCAL := 3.1.6
|
KSU_API_VERSION_LOCAL := 3.1.6
|
||||||
|
|
||||||
GIT_BIN := /usr/bin/env PATH="$$PATH":/usr/bin:/usr/local/bin git
|
GIT_BIN := /usr/bin/env PATH="$$PATH":/usr/bin:/usr/local/bin git
|
||||||
CURL_BIN := /usr/bin/env PATH="$$PATH":/usr/bin:/usr/local/bin curl
|
CURL_BIN := /usr/bin/env PATH="$$PATH":/usr/bin:/usr/local/bin curl
|
||||||
|
|
||||||
KSU_GITHUB_VERSION := $(shell $(CURL_BIN) -s "https://api.github.com/repos/$(REPO_OWNER)/$(REPO_NAME)/releases/latest" | grep '"tag_name":' | sed -E 's/.*"v([^"]+)".*/\1/')
|
KSU_GITHUB_VERSION := $(shell $(CURL_BIN) -s "https://api.github.com/repos/$(REPO_OWNER)/$(REPO_NAME)/releases/latest" | grep '"tag_name":' | sed -E 's/.*"v([^"]+)".*/\1/')
|
||||||
|
KSU_GITHUB_VERSION_COMMIT := $(shell $(CURL_BIN) -sI "https://api.github.com/repos/$(REPO_OWNER)/$(REPO_NAME)/commits?sha=$(REPO_BRANCH)&per_page=1" | grep -i "link:" | sed -n 's/.*page=\([0-9]*\)>; rel="last".*/\1/p')
|
||||||
|
|
||||||
LOCAL_GIT_EXISTS := $(shell test -e $(srctree)/$(src)/../.git && echo 1 || echo 0)
|
LOCAL_GIT_EXISTS := $(shell test -e $(srctree)/$(src)/../.git && echo 1 || echo 0)
|
||||||
|
|
||||||
define get_ksu_api_version
|
|
||||||
$(shell echo $1 | awk -F'[-.]' '{printf "%d%02d%02d", $$1, $$2, $$3}')
|
|
||||||
endef
|
|
||||||
|
|
||||||
define get_ksu_kernel_version
|
define get_ksu_kernel_version
|
||||||
v$1-$(shell cd $(srctree)/$(src); $(GIT_BIN) rev-parse --short=8 HEAD)@$(shell cd $(srctree)/$(src); $(GIT_BIN) rev-parse --abbrev-ref HEAD)
|
v$1-$(shell cd $(srctree)/$(src); $(GIT_BIN) rev-parse --short=8 HEAD)@$(shell cd $(srctree)/$(src); $(GIT_BIN) rev-parse --abbrev-ref HEAD)
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
ifeq ($(KSU_GITHUB_VERSION_COMMIT),)
|
||||||
|
ifeq ($(LOCAL_GIT_EXISTS),1)
|
||||||
|
$(shell cd $(srctree)/$(src); [ -f ../.git/shallow ] && $(GIT_BIN) fetch --unshallow)
|
||||||
|
KSU_LOCAL_VERSION := $(shell cd $(srctree)/$(src); $(GIT_BIN) rev-list --count $(REPO_BRANCH))
|
||||||
|
KSU_API_VERSION := $(shell expr 10000 + $(KSU_LOCAL_VERSION) + 700)
|
||||||
|
$(info -- $(REPO_NAME) version (local .git): $(KSU_API_VERSION))
|
||||||
|
else
|
||||||
|
KSU_API_VERSION := 13000
|
||||||
|
$(warning -- Could not fetch version online or via local .git! Using fallback version: $(KSU_API_VERSION))
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
KSU_API_VERSION := $(shell expr 10000 + $(KSU_GITHUB_VERSION_COMMIT) + 700)
|
||||||
|
$(info -- $(REPO_NAME) version (GitHub): $(KSU_API_VERSION))
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(KSU_GITHUB_VERSION),)
|
ifeq ($(KSU_GITHUB_VERSION),)
|
||||||
ifeq ($(LOCAL_GIT_EXISTS),1)
|
ifeq ($(LOCAL_GIT_EXISTS),1)
|
||||||
$(shell cd $(srctree)/$(src); [ -f ../.git/shallow ] && $(GIT_BIN) fetch --unshallow)
|
$(shell cd $(srctree)/$(src); [ -f ../.git/shallow ] && $(GIT_BIN) fetch --unshallow)
|
||||||
KSU_API_VERSION := $(call get_ksu_api_version,$(KSU_API_VERSION_LOCAL))
|
|
||||||
KSU_KERNEL_VERSION := $(call get_ksu_kernel_version,$(KSU_API_VERSION_LOCAL))
|
KSU_KERNEL_VERSION := $(call get_ksu_kernel_version,$(KSU_API_VERSION_LOCAL))
|
||||||
$(info -- $(REPO_NAME) version (local .git): $(KSU_KERNEL_VERSION))
|
$(info -- $(REPO_NAME) version (local .git): $(KSU_KERNEL_VERSION))
|
||||||
$(info -- $(REPO_NAME) Formatted version (local .git): $(KSU_API_VERSION))
|
$(info -- $(REPO_NAME) Formatted version (local .git): $(KSU_API_VERSION))
|
||||||
else
|
else
|
||||||
KSU_KERNEL_VERSION := v$(KSU_API_VERSION_LOCAL)-$(REPO_NAME)-unknown@unknown
|
KSU_KERNEL_VERSION := v$(KSU_API_VERSION_LOCAL)-$(REPO_NAME)-unknown@unknown
|
||||||
KSU_API_VERSION := $(call get_ksu_api_version,$(KSU_API_VERSION_LOCAL))
|
|
||||||
$(warning -- $(REPO_NAME) version: $(KSU_KERNEL_VERSION))
|
$(warning -- $(REPO_NAME) version: $(KSU_KERNEL_VERSION))
|
||||||
endif
|
endif
|
||||||
else
|
else
|
||||||
$(shell cd $(srctree)/$(src); [ -f ../.git/shallow ] && $(GIT_BIN) fetch --unshallow)
|
$(shell cd $(srctree)/$(src); [ -f ../.git/shallow ] && $(GIT_BIN) fetch --unshallow)
|
||||||
KSU_API_VERSION := $(call get_ksu_api_version,$(KSU_GITHUB_VERSION))
|
|
||||||
KSU_KERNEL_VERSION := $(call get_ksu_kernel_version,$(KSU_GITHUB_VERSION))
|
KSU_KERNEL_VERSION := $(call get_ksu_kernel_version,$(KSU_GITHUB_VERSION))
|
||||||
$(info -- $(REPO_NAME) version (Github): $(KSU_KERNEL_VERSION))
|
$(info -- $(REPO_NAME) version (Github): $(KSU_KERNEL_VERSION))
|
||||||
$(info -- $(REPO_NAME) Formatted version (Github): $(KSU_API_VERSION))
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ccflags-y += -DKSU_VERSION=\"$(KSU_KERNEL_VERSION)\"
|
ccflags-y += -DKSU_VERSION=\"$(KSU_KERNEL_VERSION)\"
|
||||||
|
|||||||
Reference in New Issue
Block a user