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 @@
// Goplay is a web interface for experimenting with Go code.
// 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
// $ gomake install
// Then, run it:
// $ goplay
// $ go run goplay.go
// and load http://localhost:3999/ in a web browser.
//
// You should see a Hello World program, which you can compile and run by
......
......@@ -12,7 +12,6 @@ import (
"net/http"
"os"
"os/exec"
"runtime"
"strconv"
"text/template"
)
......@@ -25,25 +24,11 @@ var (
var (
// a source of numbers, for naming temporary files
uniq = make(chan int)
// the architecture-identifying character of the tool chain, 5, 6, or 8
archChar string
)
func main() {
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
go func() {
for i := 0; ; i++ {
......@@ -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("/compile", Compile)
log.Fatal(http.ListenAndServe(*httpListen, nil))
......@@ -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,
// 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.
func Compile(w http.ResponseWriter, req *http.Request) {
// x is the base name for .go, .6, executable files
x := os.TempDir() + "/compile" + strconv.Itoa(<-uniq)
src := x + ".go"
obj := x + "." + archChar
bin := x
if runtime.GOOS == "windows" {
bin += ".exe"
}
// x is the base name for .go files
x := "goplay" + strconv.Itoa(<-uniq) + ".go"
// write request Body to x.go
f, err := os.Create(src)
f, err := os.Create(x)
if err != nil {
error_(w, nil, err)
return
}
defer os.Remove(src)
defer os.Remove(x)
defer f.Close()
_, err = io.Copy(f, req.Body)
if err != nil {
......@@ -96,26 +81,11 @@ func Compile(w http.ResponseWriter, req *http.Request) {
}
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
out, err = run(bin)
out, err := run("go", "run", x)
if err != nil {
error_(w, out, err)
return
}
// 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