libwg-go: use system Go when possible
We're still maybe curlzipping and using a binary distribution of Go, but at least this is only the case on machines that don't have go. Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
This commit is contained in:
		
							parent
							
								
									05b4e395a9
								
							
						
					
					
						commit
						6ce739f01f
					
				@ -10,8 +10,6 @@ NDK_GO_ARCH_MAP_mips := mipsx
 | 
				
			|||||||
NDK_GO_ARCH_MAP_mips64 := mips64x
 | 
					NDK_GO_ARCH_MAP_mips64 := mips64x
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export GOPATH := $(CURDIR)/gopath
 | 
					export GOPATH := $(CURDIR)/gopath
 | 
				
			||||||
export GOROOT := $(CURDIR)/goroot
 | 
					 | 
				
			||||||
export PATH := $(GOROOT)/bin:$(PATH)
 | 
					 | 
				
			||||||
CLANG_FLAGS := --target=$(ANDROID_LLVM_TRIPLE) --gcc-toolchain=$(ANDROID_TOOLCHAIN_ROOT) --sysroot=$(ANDROID_SYSROOT)
 | 
					CLANG_FLAGS := --target=$(ANDROID_LLVM_TRIPLE) --gcc-toolchain=$(ANDROID_TOOLCHAIN_ROOT) --sysroot=$(ANDROID_SYSROOT)
 | 
				
			||||||
export CGO_CFLAGS := $(CLANG_FLAGS) $(CFLAGS)
 | 
					export CGO_CFLAGS := $(CLANG_FLAGS) $(CFLAGS)
 | 
				
			||||||
export CGO_LDFLAGS := $(CLANG_FLAGS) $(LDFLAGS)
 | 
					export CGO_LDFLAGS := $(CLANG_FLAGS) $(LDFLAGS)
 | 
				
			||||||
@ -20,20 +18,32 @@ export GOARCH := $(NDK_GO_ARCH_MAP_$(ANDROID_ARCH_NAME))
 | 
				
			|||||||
export GOOS := android
 | 
					export GOOS := android
 | 
				
			||||||
export CGO_ENABLED := 1
 | 
					export CGO_ENABLED := 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
GORELEASEVERSION := 1.10.1
 | 
					 | 
				
			||||||
GORELEASETARBALL := https://dl.google.com/go/go$(GORELEASEVERSION).$(shell uname -s | tr '[:upper:]' '[:lower:]')-$(NDK_GO_ARCH_MAP_$(shell uname -m)).tar.gz
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
default: $(DESTDIR)/libwg-go.so
 | 
					default: $(DESTDIR)/libwg-go.so
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					GOBUILDARCH := $(NDK_GO_ARCH_MAP_$(shell uname -m))
 | 
				
			||||||
 | 
					GOBUILDOS := $(shell uname -s | tr '[:upper:]' '[:lower:]')
 | 
				
			||||||
 | 
					GOBUILDVERSION := 1.10.1
 | 
				
			||||||
 | 
					GOBUILDTARBALL := https://dl.google.com/go/go$(GOBUILDVERSION).$(GOBUILDOS)-$(GOBUILDARCH).tar.gz
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifeq (go version go$(GOBUILDVERSION) $(GOBUILDOS)/$(GOBUILDARCH),$(shell go version 2>/dev/null))
 | 
				
			||||||
 | 
					ensure_go_exists:
 | 
				
			||||||
 | 
						@echo "Using system go"
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
					export GOROOT := $(CURDIR)/goroot
 | 
				
			||||||
 | 
					export PATH := $(GOROOT)/bin:$(PATH)
 | 
				
			||||||
$(GOROOT)/bin/go:
 | 
					$(GOROOT)/bin/go:
 | 
				
			||||||
	rm -rf "$(GOROOT)"
 | 
						rm -rf "$(GOROOT)"
 | 
				
			||||||
	mkdir -p "$(GOROOT)"
 | 
						mkdir -p "$(GOROOT)"
 | 
				
			||||||
	curl "$(GORELEASETARBALL)" | tar -C "$(GOROOT)" --strip-components=1 -xzf - || rm -rf "$(GOROOT)"
 | 
						curl "$(GOBUILDTARBALL)" | tar -C "$(GOROOT)" --strip-components=1 -xzf - || rm -rf "$(GOROOT)"
 | 
				
			||||||
 | 
					ensure_go_exists: $(GOROOT)/bin/go
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(DESTDIR)/libwg-go.so: $(FILES) api-android.go jni.c $(GOROOT)/bin/go
 | 
					$(DESTDIR)/libwg-go.so: $(FILES) api-android.go jni.c ensure_go_exists
 | 
				
			||||||
	find . -name '*.go' -type l -delete
 | 
						find . -name '*.go' -type l -delete
 | 
				
			||||||
	find . -type d -empty -delete
 | 
						find . -type d -empty -delete
 | 
				
			||||||
	mkdir -p $(subst ../wireguard-go/,./,$(dir $(FILES)))
 | 
						mkdir -p $(subst ../wireguard-go/,./,$(dir $(FILES)))
 | 
				
			||||||
	$(foreach FILE,$(FILES),ln -sfrt $(subst ../wireguard-go/,./,$(dir $(FILE))) $(FILE);)
 | 
						$(foreach FILE,$(FILES),ln -sfrt $(subst ../wireguard-go/,./,$(dir $(FILE))) $(FILE);)
 | 
				
			||||||
	go get -v -d
 | 
						go get -v -d
 | 
				
			||||||
	go build -v -o $(DESTDIR)/libwg-go.so -buildmode c-shared
 | 
						go build -v -o $(DESTDIR)/libwg-go.so -buildmode c-shared
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.PHONY: ensure_go_exists
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user