mirror of
https://github.com/vlang/v.git
synced 2025-08-03 01:37:24 -04:00
233 lines
5.2 KiB
Makefile
233 lines
5.2 KiB
Makefile
CC ?= cc
|
|
CFLAGS ?=
|
|
LDFLAGS ?=
|
|
TMPDIR ?= /tmp
|
|
VROOT ?= .
|
|
VC ?= ./vc
|
|
VEXE ?= ./v
|
|
VCREPO ?= https://github.com/vlang/vc
|
|
TCCREPO ?= https://github.com/vlang/tccbin
|
|
LEGACYREPO ?= https://github.com/macports/macports-legacy-support
|
|
|
|
VCFILE := v.c
|
|
TMPTCC := $(VROOT)/thirdparty/tcc
|
|
LEGACYLIBS := $(VROOT)/thirdparty/legacy
|
|
TMPLEGACY := $(LEGACYLIBS)/source
|
|
TCCOS := unknown
|
|
TCCARCH := unknown
|
|
GITCLEANPULL := git clean -xf && git pull --quiet
|
|
GITFASTCLONE := git clone --filter=blob:none --quiet
|
|
|
|
#### Platform detections and overrides:
|
|
_SYS := $(shell uname 2>/dev/null || echo Unknown)
|
|
_SYS := $(patsubst MSYS%,MSYS,$(_SYS))
|
|
_SYS := $(patsubst MINGW%,MinGW,$(_SYS))
|
|
|
|
ifneq ($(filter $(_SYS),MSYS MinGW),)
|
|
WIN32 := 1
|
|
EXE_EXT := .exe
|
|
endif
|
|
|
|
ifeq ($(_SYS),Linux)
|
|
LINUX := 1
|
|
TCCOS := linux
|
|
ifneq ($(shell ldd --version 2>&1 | grep -i musl),)
|
|
TCCOS := linuxmusl
|
|
endif
|
|
endif
|
|
|
|
ifeq ($(_SYS),Darwin)
|
|
MAC := 1
|
|
TCCOS := macos
|
|
ifeq ($(shell expr $(shell uname -r | cut -d. -f1) \<= 15), 1)
|
|
LEGACY := 1
|
|
endif
|
|
endif
|
|
|
|
ifeq ($(_SYS),FreeBSD)
|
|
TCCOS := freebsd
|
|
LDFLAGS += -lexecinfo
|
|
endif
|
|
|
|
ifeq ($(_SYS),NetBSD)
|
|
NETBSD := 1
|
|
TCCOS := netbsd
|
|
LDFLAGS += -lexecinfo
|
|
endif
|
|
|
|
ifeq ($(_SYS),OpenBSD)
|
|
TCCOS := openbsd
|
|
LDFLAGS += -lexecinfo
|
|
endif
|
|
|
|
ifdef ANDROID_ROOT
|
|
ANDROID := 1
|
|
undefine LINUX
|
|
TCCOS := android
|
|
endif
|
|
#####
|
|
|
|
ifdef WIN32
|
|
TCCOS := windows
|
|
VCFILE := v_win.c
|
|
endif
|
|
|
|
TCCARCH := $(shell uname -m 2>/dev/null || echo unknown)
|
|
|
|
ifeq ($(TCCARCH),x86_64)
|
|
TCCARCH := amd64
|
|
else
|
|
ifneq ($(filter x86%,$(TCCARCH)),)
|
|
TCCARCH := i386
|
|
else
|
|
ifeq ($(TCCARCH),arm64)
|
|
TCCARCH := arm64
|
|
else
|
|
ifneq ($(filter arm%,$(TCCARCH)),)
|
|
TCCARCH := arm
|
|
# otherwise, just use the arch name
|
|
endif
|
|
endif
|
|
endif
|
|
endif
|
|
|
|
.PHONY: all clean rebuild check fresh_vc fresh_tcc fresh_legacy check_for_working_tcc etags ctags
|
|
|
|
ifdef prod
|
|
VFLAGS+=-prod
|
|
endif
|
|
|
|
all: latest_vc latest_tcc latest_legacy
|
|
ifdef WIN32
|
|
$(CC) $(CFLAGS) -std=c99 -municode -w -o v1$(EXE_EXT) $(VC)/$(VCFILE) $(LDFLAGS) -lws2_32 || cmd/tools/cc_compilation_failed_windows.sh
|
|
./v1$(EXE_EXT) -no-parallel -o v2$(EXE_EXT) $(VFLAGS) cmd/v
|
|
./v2$(EXE_EXT) -o $(VEXE)$(EXE_EXT) $(VFLAGS) cmd/v
|
|
$(RM) v1$(EXE_EXT)
|
|
$(RM) v2$(EXE_EXT)
|
|
else
|
|
ifdef LEGACY
|
|
$(MAKE) -C $(TMPLEGACY)
|
|
$(MAKE) -C $(TMPLEGACY) PREFIX=$(realpath $(LEGACYLIBS)) CFLAGS=$(CFLAGS) LDFLAGS=$(LDFLAGS) install
|
|
rm -rf $(TMPLEGACY)
|
|
$(eval override LDFLAGS+=-L$(realpath $(LEGACYLIBS))/lib -lMacportsLegacySupport)
|
|
endif
|
|
$(CC) $(CFLAGS) -std=gnu99 -w -o v1$(EXE_EXT) $(VC)/$(VCFILE) -lm -lpthread $(LDFLAGS) || cmd/tools/cc_compilation_failed_non_windows.sh
|
|
ifdef NETBSD
|
|
paxctl +m v1$(EXE_EXT)
|
|
endif
|
|
./v1$(EXE_EXT) -no-parallel -o v2$(EXE_EXT) $(VFLAGS) cmd/v
|
|
ifdef NETBSD
|
|
paxctl +m v2$(EXE_EXT)
|
|
endif
|
|
./v2$(EXE_EXT) -nocache -o $(VEXE)$(EXE_EXT) $(VFLAGS) cmd/v
|
|
ifdef NETBSD
|
|
paxctl +m $(VEXE)$(EXE_EXT)
|
|
endif
|
|
rm -rf v1$(EXE_EXT) v2$(EXE_EXT)
|
|
endif
|
|
@$(VEXE)$(EXE_EXT) run cmd/tools/detect_tcc.v
|
|
@echo "V has been successfully built"
|
|
@$(VEXE)$(EXE_EXT) -version
|
|
@$(VEXE)$(EXE_EXT) run .github/problem-matchers/register_all.vsh
|
|
|
|
clean:
|
|
rm -rf $(TMPTCC)
|
|
rm -rf $(LEGACYLIBS)
|
|
rm -rf $(VC)
|
|
|
|
rebuild: clean all
|
|
|
|
ifndef local
|
|
latest_vc: $(VC)/.git/config
|
|
cd $(VC) && $(GITCLEANPULL)
|
|
else
|
|
latest_vc:
|
|
@echo "Using local vc"
|
|
endif
|
|
|
|
check_for_working_tcc:
|
|
@$(TMPTCC)/tcc.exe --version > /dev/null 2> /dev/null || echo "The executable '$(TMPTCC)/tcc.exe' does not work."
|
|
|
|
fresh_vc:
|
|
rm -rf $(VC)
|
|
$(GITFASTCLONE) $(VCREPO) $(VC)
|
|
|
|
ifndef local
|
|
latest_tcc: $(TMPTCC)/.git/config
|
|
cd $(TMPTCC) && $(GITCLEANPULL)
|
|
ifneq (,$(wildcard ./tcc.exe))
|
|
@$(MAKE) --quiet check_for_working_tcc 2> /dev/null
|
|
endif
|
|
|
|
else
|
|
latest_tcc:
|
|
@echo "Using local tcc"
|
|
@$(MAKE) --quiet check_for_working_tcc 2> /dev/null
|
|
endif
|
|
|
|
fresh_tcc:
|
|
rm -rf $(TMPTCC)
|
|
ifndef local
|
|
# Check whether a TCC branch exists for the user's system configuration.
|
|
ifneq (,$(findstring thirdparty-$(TCCOS)-$(TCCARCH), $(shell git ls-remote --heads $(TCCREPO) | sed 's/^[a-z0-9]*\trefs.heads.//')))
|
|
$(GITFASTCLONE) --branch thirdparty-$(TCCOS)-$(TCCARCH) $(TCCREPO) $(TMPTCC)
|
|
@$(MAKE) --quiet check_for_working_tcc 2> /dev/null
|
|
else
|
|
@echo 'Pre-built TCC not available for thirdparty-$(TCCOS)-$(TCCARCH) at $(TCCREPO), will use the system compiler: $(CC)'
|
|
$(GITFASTCLONE) --branch thirdparty-unknown-unknown $(TCCREPO) $(TMPTCC)
|
|
endif
|
|
else
|
|
@echo "Using local tccbin"
|
|
@$(MAKE) --quiet check_for_working_tcc 2> /dev/null
|
|
endif
|
|
|
|
ifndef local
|
|
latest_legacy: $(TMPLEGACY)/.git/config
|
|
ifdef LEGACY
|
|
cd $(TMPLEGACY) && $(GITCLEANPULL)
|
|
endif
|
|
else
|
|
latest_legacy:
|
|
ifdef LEGACY
|
|
@echo "Using local legacysupport"
|
|
endif
|
|
endif
|
|
|
|
fresh_legacy:
|
|
rm -rf $(LEGACYLIBS)
|
|
$(GITFASTCLONE) $(LEGACYREPO) $(TMPLEGACY)
|
|
|
|
$(TMPTCC)/.git/config:
|
|
$(MAKE) fresh_tcc
|
|
|
|
$(VC)/.git/config:
|
|
$(MAKE) fresh_vc
|
|
|
|
$(TMPLEGACY)/.git/config:
|
|
ifdef LEGACY
|
|
$(MAKE) fresh_legacy
|
|
endif
|
|
|
|
asan:
|
|
$(MAKE) all CFLAGS='-fsanitize=address,undefined'
|
|
|
|
selfcompile:
|
|
$(VEXE)$(EXE_EXT) -cg -o v cmd/v
|
|
|
|
selfcompile-static:
|
|
$(VEXE)$(EXE_EXT) -cg -cflags '--static' -o v-static cmd/v
|
|
|
|
### NB: Please keep this Makefile and make.bat simple.
|
|
install:
|
|
@echo 'Please use `sudo ./v symlink` instead, or manually add the current directory to your PATH.'
|
|
|
|
check:
|
|
$(VEXE)$(EXE_EXT) test-all
|
|
|
|
etags:
|
|
./v$(EXE_EXT) -print-v-files cmd/v | grep -v :parse_text| etags -L -
|
|
|
|
ctags:
|
|
./v$(EXE_EXT) -print-v-files cmd/v | grep -v :parse_text| ctags -L -
|
|
|