aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFelix Lange <fjl@twurst.com>2015-12-15 04:32:00 +0800
committerFelix Lange <fjl@twurst.com>2015-12-15 04:32:00 +0800
commit9c636d2490c4f88598752834cc3226902d198ced (patch)
tree81fa2ef7931fd9ed80a5bff0ecc064626a04b590
parentfa187a366dda1894179635eeec2a929bfacc4ad3 (diff)
parent03f090b30bdee27bfd8e45b0532b6674d808c8ae (diff)
downloadgo-tangerine-9c636d2490c4f88598752834cc3226902d198ced.tar
go-tangerine-9c636d2490c4f88598752834cc3226902d198ced.tar.gz
go-tangerine-9c636d2490c4f88598752834cc3226902d198ced.tar.bz2
go-tangerine-9c636d2490c4f88598752834cc3226902d198ced.tar.lz
go-tangerine-9c636d2490c4f88598752834cc3226902d198ced.tar.xz
go-tangerine-9c636d2490c4f88598752834cc3226902d198ced.tar.zst
go-tangerine-9c636d2490c4f88598752834cc3226902d198ced.zip
Merge pull request #2070 from karalabe/android-archives
Makefile, cmd/geth: support building Android archives
-rw-r--r--Makefile45
-rw-r--r--cmd/geth/library_android.go56
2 files changed, 76 insertions, 25 deletions
diff --git a/Makefile b/Makefile
index d5d3825d8..abf99945a 100644
--- a/Makefile
+++ b/Makefile
@@ -7,7 +7,7 @@
.PHONY: geth-linux-arm geth-linux-arm-5 geth-linux-arm-6 geth-linux-arm-7 geth-linux-arm64
.PHONY: geth-darwin geth-darwin-386 geth-darwin-amd64
.PHONY: geth-windows geth-windows-386 geth-windows-amd64
-.PHONY: geth-android geth-ios geth-ios-sim
+.PHONY: geth-android geth-ios
GOBIN = build/bin
GO ?= latest
@@ -19,88 +19,83 @@ geth:
geth-cross: geth-linux geth-darwin geth-windows geth-android geth-ios
@echo "Full cross compilation done:"
- @ls -l $(GOBIN)/geth-*
+ @ls -ld $(GOBIN)/geth-*
geth-linux: geth-linux-386 geth-linux-amd64 geth-linux-arm
@echo "Linux cross compilation done:"
- @ls -l $(GOBIN)/geth-linux-*
+ @ls -ld $(GOBIN)/geth-linux-*
geth-linux-386: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=linux/386 -v $(shell build/flags.sh) ./cmd/geth
@echo "Linux 386 cross compilation done:"
- @ls -l $(GOBIN)/geth-linux-* | grep 386
+ @ls -ld $(GOBIN)/geth-linux-* | grep 386
geth-linux-amd64: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=linux/amd64 -v $(shell build/flags.sh) ./cmd/geth
@echo "Linux amd64 cross compilation done:"
- @ls -l $(GOBIN)/geth-linux-* | grep amd64
+ @ls -ld $(GOBIN)/geth-linux-* | grep amd64
geth-linux-arm: geth-linux-arm-5 geth-linux-arm-6 geth-linux-arm-7 geth-linux-arm64
@echo "Linux ARM cross compilation done:"
- @ls -l $(GOBIN)/geth-linux-* | grep arm
+ @ls -ld $(GOBIN)/geth-linux-* | grep arm
geth-linux-arm-5: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=linux/arm-5 -v $(shell build/flags.sh) ./cmd/geth
@echo "Linux ARMv5 cross compilation done:"
- @ls -l $(GOBIN)/geth-linux-* | grep arm-5
+ @ls -ld $(GOBIN)/geth-linux-* | grep arm-5
geth-linux-arm-6: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=linux/arm-6 -v $(shell build/flags.sh) ./cmd/geth
@echo "Linux ARMv6 cross compilation done:"
- @ls -l $(GOBIN)/geth-linux-* | grep arm-6
+ @ls -ld $(GOBIN)/geth-linux-* | grep arm-6
geth-linux-arm-7: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=linux/arm-7 -v $(shell build/flags.sh) ./cmd/geth
@echo "Linux ARMv7 cross compilation done:"
- @ls -l $(GOBIN)/geth-linux-* | grep arm-7
+ @ls -ld $(GOBIN)/geth-linux-* | grep arm-7
geth-linux-arm64: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=linux/arm64 -v $(shell build/flags.sh) ./cmd/geth
@echo "Linux ARM64 cross compilation done:"
- @ls -l $(GOBIN)/geth-linux-* | grep arm64
+ @ls -ld $(GOBIN)/geth-linux-* | grep arm64
geth-darwin: geth-darwin-386 geth-darwin-amd64
@echo "Darwin cross compilation done:"
- @ls -l $(GOBIN)/geth-darwin-*
+ @ls -ld $(GOBIN)/geth-darwin-*
geth-darwin-386: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=darwin/386 -v $(shell build/flags.sh) ./cmd/geth
@echo "Darwin 386 cross compilation done:"
- @ls -l $(GOBIN)/geth-darwin-* | grep 386
+ @ls -ld $(GOBIN)/geth-darwin-* | grep 386
geth-darwin-amd64: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=darwin/amd64 -v $(shell build/flags.sh) ./cmd/geth
@echo "Darwin amd64 cross compilation done:"
- @ls -l $(GOBIN)/geth-darwin-* | grep amd64
+ @ls -ld $(GOBIN)/geth-darwin-* | grep amd64
geth-windows: geth-windows-386 geth-windows-amd64
@echo "Windows cross compilation done:"
- @ls -l $(GOBIN)/geth-windows-*
+ @ls -ld $(GOBIN)/geth-windows-*
geth-windows-386: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=windows/386 -v $(shell build/flags.sh) ./cmd/geth
@echo "Windows 386 cross compilation done:"
- @ls -l $(GOBIN)/geth-windows-* | grep 386
+ @ls -ld $(GOBIN)/geth-windows-* | grep 386
geth-windows-amd64: xgo
build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=windows/amd64 -v $(shell build/flags.sh) ./cmd/geth
@echo "Windows amd64 cross compilation done:"
- @ls -l $(GOBIN)/geth-windows-* | grep amd64
+ @ls -ld $(GOBIN)/geth-windows-* | grep amd64
geth-android: xgo
- build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=android/* -v $(shell build/flags.sh) ./cmd/geth
+ build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=android-21/aar -v $(shell build/flags.sh) ./cmd/geth
@echo "Android cross compilation done:"
- @ls -l $(GOBIN)/geth-android-*
+ @ls -ld $(GOBIN)/geth-android-*
geth-ios: xgo
- build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=ios-7.0/* -v $(shell build/flags.sh) ./cmd/geth
+ build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=ios-7.0/framework -v $(shell build/flags.sh) ./cmd/geth
@echo "iOS framework cross compilation done:"
- @ls -l $(GOBIN)/geth-ios-*
-
-geth-ios-sim: xgo
- build/env.sh $(GOBIN)/xgo --go=$(GO) --dest=$(GOBIN) --targets=ios-7.0/amd64 -v $(shell build/flags.sh) ./cmd/geth
- @echo "iOS framework simulator-only cross compilation done:"
- @ls -l $(GOBIN)/geth-ios-*
+ @ls -ld $(GOBIN)/geth-ios-*
evm:
build/env.sh $(GOROOT)/bin/go install -v $(shell build/flags.sh) ./cmd/evm
diff --git a/cmd/geth/library_android.go b/cmd/geth/library_android.go
new file mode 100644
index 000000000..fb021bfe0
--- /dev/null
+++ b/cmd/geth/library_android.go
@@ -0,0 +1,56 @@
+// Copyright 2015 The go-ethereum Authors
+// This file is part of go-ethereum.
+//
+// go-ethereum is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// go-ethereum is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with go-ethereum. If not, see <http://www.gnu.org/licenses/>.
+
+// Contains specialized code for running Geth on Android.
+
+package main
+
+// #include <android/log.h>
+// #cgo LDFLAGS: -llog
+import "C"
+import (
+ "bufio"
+ "os"
+)
+
+func init() {
+ // Redirect the standard output and error to logcat
+ oldStdout, oldStderr := os.Stdout, os.Stderr
+
+ outRead, outWrite, _ := os.Pipe()
+ errRead, errWrite, _ := os.Pipe()
+
+ os.Stdout = outWrite
+ os.Stderr = errWrite
+
+ go func() {
+ scanner := bufio.NewScanner(outRead)
+ for scanner.Scan() {
+ line := scanner.Text()
+ C.__android_log_write(C.ANDROID_LOG_INFO, C.CString("Stdout"), C.CString(line))
+ oldStdout.WriteString(line + "\n")
+ }
+ }()
+
+ go func() {
+ scanner := bufio.NewScanner(errRead)
+ for scanner.Scan() {
+ line := scanner.Text()
+ C.__android_log_write(C.ANDROID_LOG_INFO, C.CString("Stderr"), C.CString(line))
+ oldStderr.WriteString(line + "\n")
+ }
+ }()
+}