1
0
mirror of https://github.com/golang/go synced 2024-11-22 11:34:47 -07:00

net/http: couple more triv.go modernizations

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/5834049
This commit is contained in:
Brad Fitzpatrick 2012-03-15 10:06:25 -07:00
parent aec01c3627
commit a4e6197b91

View File

@ -17,6 +17,7 @@ import (
"os" "os"
"os/exec" "os/exec"
"strconv" "strconv"
"sync"
) )
// hello world, the web server // hello world, the web server
@ -29,14 +30,21 @@ func HelloServer(w http.ResponseWriter, req *http.Request) {
// Simple counter server. POSTing to it will set the value. // Simple counter server. POSTing to it will set the value.
type Counter struct { type Counter struct {
mu sync.Mutex // protects n
n int n int
} }
// This makes Counter satisfy the expvar.Var interface, so we can export // This makes Counter satisfy the expvar.Var interface, so we can export
// it directly. // it directly.
func (ctr *Counter) String() string { return fmt.Sprintf("%d", ctr.n) } func (ctr *Counter) String() string {
ctr.mu.Lock()
defer ctr.mu.Unlock()
return fmt.Sprintf("%d", ctr.n)
}
func (ctr *Counter) ServeHTTP(w http.ResponseWriter, req *http.Request) { func (ctr *Counter) ServeHTTP(w http.ResponseWriter, req *http.Request) {
ctr.mu.Lock()
defer ctr.mu.Unlock()
switch req.Method { switch req.Method {
case "GET": case "GET":
ctr.n++ ctr.n++
@ -110,23 +118,22 @@ func Logger(w http.ResponseWriter, req *http.Request) {
http.Error(w, "oops", 404) http.Error(w, "oops", 404)
} }
var webroot = flag.String("root", "/home/rsc", "web root directory") var webroot = flag.String("root", os.Getenv("HOME"), "web root directory")
func main() { func main() {
flag.Parse() flag.Parse()
// The counter is published as a variable directly. // The counter is published as a variable directly.
ctr := new(Counter) ctr := new(Counter)
http.Handle("/counter", ctr)
expvar.Publish("counter", ctr) expvar.Publish("counter", ctr)
http.Handle("/counter", ctr)
http.Handle("/", http.HandlerFunc(Logger)) http.Handle("/", http.HandlerFunc(Logger))
http.Handle("/go/", http.StripPrefix("/go/", http.FileServer(http.Dir(*webroot)))) http.Handle("/go/", http.StripPrefix("/go/", http.FileServer(http.Dir(*webroot))))
http.Handle("/flags", http.HandlerFunc(FlagServer))
http.Handle("/args", http.HandlerFunc(ArgServer))
http.Handle("/go/hello", http.HandlerFunc(HelloServer))
http.Handle("/chan", ChanCreate()) http.Handle("/chan", ChanCreate())
http.Handle("/date", http.HandlerFunc(DateServer)) http.HandleFunc("/flags", FlagServer)
http.HandleFunc("/args", ArgServer)
http.HandleFunc("/go/hello", HelloServer)
http.HandleFunc("/date", DateServer)
err := http.ListenAndServe(":12345", nil) err := http.ListenAndServe(":12345", nil)
if err != nil { if err != nil {
log.Panicln("ListenAndServe:", err) log.Panicln("ListenAndServe:", err)