This is a standards compliant Gopher library for the Go programming language implementing the RFC 1436 specification. The library includes both client and server handling and examples of each.
$ go get github.com/writefreely/go-gopher
import "github.com/writefreely/go-gopher"
package main
import (
"fmt"
"github.com/writefreely/go-gopher"
)
func main() {
res, _ := gopher.Get("gopher://gopher.floodgap.com/")
bytes, _ := res.Dir.ToText()
fmt.Println(string(bytes))
}
package main
import (
"log"
"github.com/writefreely/go-gopher"
)
func hello(w gopher.ResponseWriter, r *gopher.Request) {
w.WriteInfo("Hello World!")
}
func main() {
gopher.HandleFunc("/hello", hello)
log.Fatal(gopher.ListenAndServe("localhost:70", nil))
}
Related projects:
-
gopherproxy gopherproxy is Gopher to HTTP proxy that uses go-gopher for all of its core functionality.
-
gopherclient gopherclient is a cross-platform QT/QML GUI Gopher Client using the gopherproxy library as its backend.
MIT