Commit 98257750 authored by Olivier Duperray's avatar Olivier Duperray Committed by Russ Cox

misc/goplay: use go tool "run"

Fixes #2872

R=andybalholm, rsc
CC=golang-dev
https://golang.org/cl/5608056
parent eac86fd3
...@@ -5,11 +5,9 @@ ...@@ -5,11 +5,9 @@
// Goplay is a web interface for experimenting with Go code. // Goplay is a web interface for experimenting with Go code.
// It is similar to the Go Playground: http://golang.org/doc/play/ // It is similar to the Go Playground: http://golang.org/doc/play/
// //
// To use goplay, first build and install it: // To use goplay:
// $ cd $GOROOT/misc/goplay // $ cd $GOROOT/misc/goplay
// $ gomake install // $ go run goplay.go
// Then, run it:
// $ goplay
// and load http://localhost:3999/ in a web browser. // and load http://localhost:3999/ in a web browser.
// //
// You should see a Hello World program, which you can compile and run by // You should see a Hello World program, which you can compile and run by
......
...@@ -12,7 +12,6 @@ import ( ...@@ -12,7 +12,6 @@ import (
"net/http" "net/http"
"os" "os"
"os/exec" "os/exec"
"runtime"
"strconv" "strconv"
"text/template" "text/template"
) )
...@@ -25,25 +24,11 @@ var ( ...@@ -25,25 +24,11 @@ var (
var ( var (
// a source of numbers, for naming temporary files // a source of numbers, for naming temporary files
uniq = make(chan int) uniq = make(chan int)
// the architecture-identifying character of the tool chain, 5, 6, or 8
archChar string
) )
func main() { func main() {
flag.Parse() flag.Parse()
// set archChar
switch runtime.GOARCH {
case "arm":
archChar = "5"
case "amd64":
archChar = "6"
case "386":
archChar = "8"
default:
log.Fatalln("unrecognized GOARCH:", runtime.GOARCH)
}
// source of unique numbers // source of unique numbers
go func() { go func() {
for i := 0; ; i++ { for i := 0; ; i++ {
...@@ -51,6 +36,12 @@ func main() { ...@@ -51,6 +36,12 @@ func main() {
} }
}() }()
// go to TempDir
err := os.Chdir(os.TempDir())
if err != nil {
log.Fatal(err)
}
http.HandleFunc("/", FrontPage) http.HandleFunc("/", FrontPage)
http.HandleFunc("/compile", Compile) http.HandleFunc("/compile", Compile)
log.Fatal(http.ListenAndServe(*httpListen, nil)) log.Fatal(http.ListenAndServe(*httpListen, nil))
...@@ -69,25 +60,19 @@ func FrontPage(w http.ResponseWriter, req *http.Request) { ...@@ -69,25 +60,19 @@ func FrontPage(w http.ResponseWriter, req *http.Request) {
} }
// Compile is an HTTP handler that reads Go source code from the request, // Compile is an HTTP handler that reads Go source code from the request,
// compiles and links the code (returning any errors), runs the program, // runs the program (returning any errors),
// and sends the program's output as the HTTP response. // and sends the program's output as the HTTP response.
func Compile(w http.ResponseWriter, req *http.Request) { func Compile(w http.ResponseWriter, req *http.Request) {
// x is the base name for .go, .6, executable files // x is the base name for .go files
x := os.TempDir() + "/compile" + strconv.Itoa(<-uniq) x := "goplay" + strconv.Itoa(<-uniq) + ".go"
src := x + ".go"
obj := x + "." + archChar
bin := x
if runtime.GOOS == "windows" {
bin += ".exe"
}
// write request Body to x.go // write request Body to x.go
f, err := os.Create(src) f, err := os.Create(x)
if err != nil { if err != nil {
error_(w, nil, err) error_(w, nil, err)
return return
} }
defer os.Remove(src) defer os.Remove(x)
defer f.Close() defer f.Close()
_, err = io.Copy(f, req.Body) _, err = io.Copy(f, req.Body)
if err != nil { if err != nil {
...@@ -96,26 +81,11 @@ func Compile(w http.ResponseWriter, req *http.Request) { ...@@ -96,26 +81,11 @@ func Compile(w http.ResponseWriter, req *http.Request) {
} }
f.Close() f.Close()
// build x.go, creating x.6
out, err := run(archChar+"g", "-o", obj, src)
defer os.Remove(obj)
if err != nil {
error_(w, out, err)
return
}
// link x.6, creating x (the program binary)
out, err = run(archChar+"l", "-o", bin, obj)
defer os.Remove(bin)
if err != nil {
error_(w, out, err)
return
}
// run x // run x
out, err = run(bin) out, err := run("go", "run", x)
if err != nil { if err != nil {
error_(w, out, err) error_(w, out, err)
return
} }
// write the output of x as the http response // write the output of x as the http response
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment