Go docs
Golang-Syd, Oct 17, 2012
Rob Pike
Google, Inc.
Rob Pike
Google, Inc.
There are many ways to show documentation as text
3go.pkgdoc.org/code.google.com/p/goauth2/oauth
16We give a lot of talks.
Most of the tools for presentations focus on style, not ease of creation.
20
In the go.talks
repo, have a new tool: present
.
go get code.google.com/p/go.talks/present
Took about an hour to put this talk together.
Docs:
go.pkgdoc.org/code.google.com/p/go.talks/present
21* Present In the `go.talks` repo, have a new tool: `present`. go get code.google.com/p/go.talks/present - Simple - Easy to use - Easy, smooth to present Took about an hour to put this talk together. Docs: .link http://go.pkgdoc.org/code.google.com/p/go.talks/present
* Input for the previous slide .code go-docs.slide /^\* Present$/,/^\.link/
* Input for the previous slide redux .code go-docs.slide /^\*.*previous/,/^\.code/
Lots of presentations, different styles.
25They all have code.
Can't execute the code!
Want to edit and play.
26Want to embed the playground technology in the other media.
Triggering example: Go Concurrency Patterns, Google I/O, 2012
Needed to demonstrate concurrency and the passage of time.
31An extract from the talk.
32
These programs make Joe and Ann count in lockstep.
We can instead use a fan-in function to let whosoever is ready talk.
func fanIn(input1, input2 <-chan string) <-chan string { c := make(chan string) go func() { for { c <- <-input1 } }() go func() { for { c <- <-input2 } }() return c }
// +build ignore,OMIT
package main
import (
"fmt"
"math/rand"
"time"
)
func main() { c := fanIn(boring("Joe"), boring("Ann")) for i := 0; i < 10; i++ { fmt.Println(<-c) } fmt.Println("You're both boring; I'm leaving.") }
// START2 OMIT
func boring(msg string) <-chan string { // Returns receive-only channel of strings. // HL
c := make(chan string)
go func() { // We launch the goroutine from inside the function. // HL
for i := 0; ; i++ {
c <- fmt.Sprintf("%s: %d", msg, i)
time.Sleep(time.Duration(rand.Intn(2e3)) * time.Millisecond)
}
}()
return c // Return the channel to the caller. // HL
}
// STOP2 OMIT
// START3 OMIT
func fanIn(input1, input2 <-chan string) <-chan string { // HL
c := make(chan string)
go func() { for { c <- <-input1 } }() // HL
go func() { for { c <- <-input2 } }() // HL
return c
}
// STOP3 OMIT
Input for the previous slide:
* Multiplexing These programs make Joe and Ann count in lockstep. We can instead use a fan-in function to let whosoever is ready talk. .code go-docs/faninboring.go /START3/,/STOP3/ .play go-docs/faninboring.go /START1/,/STOP1/
package main import ( "fmt" "math/rand" "time" ) // START1 OMIT func main() { c := fanIn(boring("Joe"), boring("Ann")) // HL for i := 0; i < 10; i++ { fmt.Println(<-c) // HL } fmt.Println("You're both boring; I'm leaving.") } // STOP1 OMIT
// START2 OMIT func boring(msg string) <-chan string { // Returns receive-only channel of strings. // HL c := make(chan string) go func() { // We launch the goroutine from inside the function. // HL for i := 0; ; i++ { c <- fmt.Sprintf("%s: %d", msg, i) time.Sleep(time.Duration(rand.Intn(2e3)) * time.Millisecond) } }() return c // Return the channel to the caller. // HL } // STOP2 OMIT // START3 OMIT func fanIn(input1, input2 <-chan string) <-chan string { // HL c := make(chan string) go func() { for { c <- <-input1 } }() // HL go func() { for { c <- <-input2 } }() // HL return c } // STOP3 OMIT
The input for the Multiplexing slide again:
* Multiplexing These programs make Joe and Ann count in lockstep. We can instead use a fan-in function to let whosoever is ready talk. .code go-docs/faninboring.go /START3/,/STOP3/ .play go-docs/faninboring.go /START1/,/STOP1/
These programs make Joe and Ann count in lockstep.
We can instead use a fan-in function to let whosoever is ready talk.
func fanIn(input1, input2 <-chan string) <-chan string { c := make(chan string) go func() { for { c <- <-input1 } }() go func() { for { c <- <-input2 } }() return c }
// +build ignore,OMIT
package main
import (
"fmt"
"math/rand"
"time"
)
func main() { c := fanIn(boring("Joe"), boring("Ann")) for i := 0; i < 10; i++ { fmt.Println(<-c) } fmt.Println("You're both boring; I'm leaving.") }
// START2 OMIT
func boring(msg string) <-chan string { // Returns receive-only channel of strings. // HL
c := make(chan string)
go func() { // We launch the goroutine from inside the function. // HL
for i := 0; ; i++ {
c <- fmt.Sprintf("%s: %d", msg, i)
time.Sleep(time.Duration(rand.Intn(2e3)) * time.Millisecond)
}
}()
return c // Return the channel to the caller. // HL
}
// STOP2 OMIT
// START3 OMIT
func fanIn(input1, input2 <-chan string) <-chan string { // HL
c := make(chan string)
go func() { for { c <- <-input1 } }() // HL
go func() { for { c <- <-input2 } }() // HL
return c
}
// STOP3 OMIT
Deploy executable examples throughout:
go.dev/pkg/strings/#example_Contains
40