diff options
| author | Russ Cox <rsc@golang.org> | 2010-03-16 23:10:33 -0700 | 
|---|---|---|
| committer | Russ Cox <rsc@golang.org> | 2010-03-16 23:10:33 -0700 | 
| commit | 504ccfeeda3134aa47e4a9646c8885782f513539 (patch) | |
| tree | 54618cda4018c5a0abe309fb4d7bf02d9c71551c | |
| parent | 95426769e7a75e8d10e0a37022c694a7283f4649 (diff) | |
| download | golang-504ccfeeda3134aa47e4a9646c8885782f513539.tar.gz | |
runtime: add GOROOT and Version
R=r
CC=golang-dev
http://codereview.appspot.com/608041
| -rw-r--r-- | .hgignore | 6 | ||||
| -rw-r--r-- | src/pkg/runtime/Makefile | 9 | ||||
| -rw-r--r-- | src/pkg/runtime/extern.go | 20 | ||||
| -rw-r--r-- | src/pkg/runtime/mkversion.c | 15 | ||||
| -rw-r--r-- | src/pkg/runtime/runtime.c | 9 | 
5 files changed, 57 insertions, 2 deletions
| @@ -26,9 +26,13 @@ src/cmd/gc/yerr.h  src/pkg/Make.deps  src/pkg/exp/ogle/ogle  src/pkg/os/signal/unix.go -src/pkg/runtime/cgo2c  src/pkg/runtime/*/asm.h +src/pkg/runtime/cgo2c +src/pkg/runtime/mkversion  src/pkg/runtime/runtime.acid.* +src/pkg/runtime/version.go +src/pkg/github.com/ +src/pkg/*.googlecode.com/  test/pass.out  test/run.out  test/times.out diff --git a/src/pkg/runtime/Makefile b/src/pkg/runtime/Makefile index bc8a2d8bf..f44de25d4 100644 --- a/src/pkg/runtime/Makefile +++ b/src/pkg/runtime/Makefile @@ -23,6 +23,7 @@ CFLAGS=-I$(GOOS) -I$(GOOS)/$(GOARCH) -wF $(CFLAGS_$(SIZE)) $(CFLAGS_$(GOARCH)) $  GOFILES=\  	extern.go\  	type.go\ +	version.go\  GOFILES_pchw=\  	pchw/io.go\ @@ -111,7 +112,7 @@ $(pkgdir)/%.h: %.h  clean: clean-local  clean-local: -	rm -f cgo2c */asm.h runtime.acid.* +	rm -f cgo2c mkversion version.go */asm.h runtime.acid.*  $(GOARCH)/asm.h: mkasmh.sh runtime.acid.$(GOARCH)  	./mkasmh.sh >$@.x @@ -120,6 +121,12 @@ $(GOARCH)/asm.h: mkasmh.sh runtime.acid.$(GOARCH)  cgo2c: cgo2c.c  	$(QUOTED_GOBIN)/quietgcc -o $@ $< +mkversion: mkversion.c +	$(QUOTED_GOBIN)/quietgcc -o $@ -I "$(GOROOT)/include" $< "$(GOROOT)/lib/lib9.a" + +version.go: mkversion +	mkversion >version.go +  %.c:	%.cgo cgo2c  	./cgo2c $< > $@.tmp  	mv -f $@.tmp $@ diff --git a/src/pkg/runtime/extern.go b/src/pkg/runtime/extern.go index f34bb2256..b4d903c30 100644 --- a/src/pkg/runtime/extern.go +++ b/src/pkg/runtime/extern.go @@ -150,3 +150,23 @@ func GC()  // TODO(rsc): allow f to have (ignored) return values  //  func SetFinalizer(x, f interface{}) + +func getgoroot() string + +// GOROOT returns the root of the Go tree. +// It uses the GOROOT environment variable, if set, +// or else the root used during the Go build. +func GOROOT() string { +	s := getgoroot() +	if s != "" { +		return s +	} +	return defaultGoroot +} + +// Version returns the Go tree's version string. +// It is either a sequence number or, when possible, +// a release tag like "release.2010-03-04". +// A trailing + indicates that the tree had local modifications +// at the time of the build. +func Version() string { return defaultVersion } diff --git a/src/pkg/runtime/mkversion.c b/src/pkg/runtime/mkversion.c new file mode 100644 index 000000000..bf33c0f85 --- /dev/null +++ b/src/pkg/runtime/mkversion.c @@ -0,0 +1,15 @@ +#include <u.h> +#include <libc.h> + +char *template = +	"// generated by mkversion.c; do not edit.\n" +	"package runtime\n" +	"const defaultGoroot = \"%s\"\n" +	"const defaultVersion = \"%s\"\n"; + +void +main(void) +{ +	print(template, getgoroot(), getgoversion()); +	exits(0); +} diff --git a/src/pkg/runtime/runtime.c b/src/pkg/runtime/runtime.c index 3a94c8bce..ed1bdcab8 100644 --- a/src/pkg/runtime/runtime.c +++ b/src/pkg/runtime/runtime.c @@ -206,6 +206,15 @@ getenv(int8 *s)  	return nil;  } +void +·getgoroot(String out) +{ +	byte *p; +	 +	p = getenv("GOROOT"); +	out = gostring(p); +	FLUSH(&out); +}  int32  atoi(byte *p) | 
