@ -40,6 +40,8 @@ ifneq ($(RACE_ENABLED),)
GOTESTFLAGS ?= -race
GOTESTFLAGS ?= -race
e n d i f
e n d i f
STORED_VERSION_FILE := VERSION
i f n e q ( $( DRONE_TAG ) , )
i f n e q ( $( DRONE_TAG ) , )
VERSION ?= $( subst v,,$( DRONE_TAG) )
VERSION ?= $( subst v,,$( DRONE_TAG) )
GITEA_VERSION ?= $( VERSION)
GITEA_VERSION ?= $( VERSION)
@ -49,7 +51,13 @@ else
else
else
VERSION ?= master
VERSION ?= master
endif
endif
STORED_VERSION = $( shell cat $( STORED_VERSION_FILE) 2>/dev/null)
ifneq ( $( STORED_VERSION) ,)
GITEA_VERSION ?= $( STORED_VERSION)
else
GITEA_VERSION ?= $( shell git describe --tags --always | sed 's/-/+/' | sed 's/^v//' )
GITEA_VERSION ?= $( shell git describe --tags --always | sed 's/-/+/' | sed 's/^v//' )
endif
e n d i f
e n d i f
LDFLAGS := $( LDFLAGS) -X " main.MakeVersion= $( MAKE_VERSION) " -X " main.Version= $( GITEA_VERSION) " -X " main.Tags= $( TAGS) "
LDFLAGS := $( LDFLAGS) -X " main.MakeVersion= $( MAKE_VERSION) " -X " main.Version= $( GITEA_VERSION) " -X " main.Tags= $( TAGS) "
@ -109,13 +117,15 @@ include docker/Makefile
help :
help :
@echo "Make Routines:"
@echo "Make Routines:"
@echo " - \"\" equivalent to \"build\""
@echo " - \"\" equivalent to \"build\""
@echo " - build creates the entire project"
@echo " - build build everything"
@echo " - clean delete integration files and build files but not css and js files"
@echo " - frontend build frontend files"
@echo " - clean-all delete all generated files (integration test, build, css and js files)"
@echo " - backend build backend files"
@echo " - webpack rebuild only js and css files"
@echo " - clean delete backend and integration files"
@echo " - fomantic rebuild fomantic-ui files"
@echo " - clean-all delete backend, frontend and integration files"
@echo " - generate run \"make fomantic webpack\" and \"go generate\""
@echo " - webpack build webpack files"
@echo " - fmt format the code"
@echo " - fomantic build fomantic files"
@echo " - generate run \"go generate\""
@echo " - fmt format the Go code"
@echo " - generate-swagger generate the swagger spec from code comments"
@echo " - generate-swagger generate the swagger spec from code comments"
@echo " - swagger-validate check if the swagger spec is valid"
@echo " - swagger-validate check if the swagger spec is valid"
@echo " - revive run code linter revive"
@echo " - revive run code linter revive"
@ -179,10 +189,6 @@ ifneq "$(TAGS)" "$(shell cat $(TAGS_EVIDENCE) 2>/dev/null)"
TAGS_PREREQ := $( TAGS_EVIDENCE)
TAGS_PREREQ := $( TAGS_EVIDENCE)
e n d i f
e n d i f
.PHONY : generate
generate : fomantic webpack $( TAGS_PREREQ )
GO111MODULE = on $( GO) generate -mod= vendor -tags '$(TAGS)' $( PACKAGES)
.PHONY : generate -swagger
.PHONY : generate -swagger
generate-swagger :
generate-swagger :
$( SWAGGER) generate spec -o './$(SWAGGER_SPEC)'
$( SWAGGER) generate spec -o './$(SWAGGER_SPEC)'
@ -441,13 +447,23 @@ install: $(wildcard *.go)
$( GO) install -v -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)'
$( GO) install -v -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)'
.PHONY : build
.PHONY : build
build : go -check generate $( EXECUTABLE )
build : frontend backend
.PHONY : frontend
frontend : node -check $( FOMANTIC_EVIDENCE ) $( WEBPACK_DEST )
.PHONY : backend
backend : go -check generate $( EXECUTABLE )
.PHONY : generate
generate : $( TAGS_PREREQ )
GO111MODULE = on $( GO) generate -mod= vendor -tags '$(TAGS)' $( PACKAGES)
$(EXECUTABLE) : $( GO_SOURCES ) $( TAGS_PREREQ )
$(EXECUTABLE) : $( GO_SOURCES ) $( TAGS_PREREQ )
GO111MODULE = on $( GO) build -mod= vendor $( GOFLAGS) $( EXTRA_GOFLAGS) -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' -o $@
GO111MODULE = on $( GO) build -mod= vendor $( GOFLAGS) $( EXTRA_GOFLAGS) -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' -o $@
.PHONY : release
.PHONY : release
release : generate release -windows release -linux release -darwin release -copy release -compress release -sources release -check
release : frontend generate release -windows release -linux release -darwin release -copy release -compress release -sources release -check
$(DIST_DIRS) :
$(DIST_DIRS) :
mkdir -p $( DIST_DIRS)
mkdir -p $( DIST_DIRS)
@ -498,8 +514,10 @@ release-compress: | $(DIST_DIRS)
cd $( DIST) /release/; for file in ` find . -type f -name "*" ` ; do echo " compressing $$ {file} " && gxz -k -9 $$ { file} ; done ;
cd $( DIST) /release/; for file in ` find . -type f -name "*" ` ; do echo " compressing $$ {file} " && gxz -k -9 $$ { file} ; done ;
.PHONY : release -sources
.PHONY : release -sources
release-sources : | $( DIST_DIRS )
release-sources : | $( DIST_DIRS ) node_modules
tar cvzf $( DIST) /release/gitea-src-$( VERSION) .tar.gz --exclude $( DIST) --exclude .git --exclude $( MAKE_EVIDENCE_DIR) .
echo $( VERSION) > $( STORED_VERSION_FILE)
tar --exclude= ./$( DIST) --exclude= ./.git --exclude= ./$( MAKE_EVIDENCE_DIR) --exclude= ./node_modules/.cache -czf $( DIST) /release/gitea-src-$( VERSION) .tar.gz .
rm -f $( STORED_VERSION_FILE)
node_modules : package -lock .json
node_modules : package -lock .json
npm install --no-save
npm install --no-save
@ -522,7 +540,7 @@ css:
$( MAKE) webpack
$( MAKE) webpack
.PHONY : fomantic
.PHONY : fomantic
fomantic : node -check $( FOMANTIC_EVIDENCE )
fomantic : $( FOMANTIC_EVIDENCE )
$(FOMANTIC_EVIDENCE) : semantic .json $( FOMANTIC_SOURCES ) | node_modules
$(FOMANTIC_EVIDENCE) : semantic .json $( FOMANTIC_SOURCES ) | node_modules
cp web_src/fomantic/theme.config.less node_modules/fomantic-ui/src/theme.config
cp web_src/fomantic/theme.config.less node_modules/fomantic-ui/src/theme.config
@ -531,7 +549,7 @@ $(FOMANTIC_EVIDENCE): semantic.json $(FOMANTIC_SOURCES) | node_modules
@mkdir -p $( MAKE_EVIDENCE_DIR) && touch $( FOMANTIC_EVIDENCE)
@mkdir -p $( MAKE_EVIDENCE_DIR) && touch $( FOMANTIC_EVIDENCE)
.PHONY : webpack
.PHONY : webpack
webpack : node -check $( WEBPACK_DEST )
webpack : $( WEBPACK_DEST )
$(WEBPACK_DEST) : $( WEBPACK_SOURCES ) $( WEBPACK_CONFIGS ) | node_modules
$(WEBPACK_DEST) : $( WEBPACK_SOURCES ) $( WEBPACK_CONFIGS ) | node_modules
npx eslint web_src/js webpack.config.js
npx eslint web_src/js webpack.config.js