Skip to content

Instantly share code, notes, and snippets.

@caelifer
Created April 4, 2025 01:03
Show Gist options
  • Save caelifer/c2351c1b67a9172de3a94b104930a46c to your computer and use it in GitHub Desktop.
Save caelifer/c2351c1b67a9172de3a94b104930a46c to your computer and use it in GitHub Desktop.
Ring buffer implementation in Go
package main
import (
"fmt"
"log"
)
var (
ErrClosedBuffer = fmt.Errorf("attempted to read from closed buffer")
)
type Ring struct {
queue chan byte
size int
}
func New(size int) *Ring {
return &Ring{
queue: make(chan byte, size),
size: size,
}
}
func NewBuffer(buf []byte) *Ring {
rb := New(len(buf))
for _, c := range buf {
rb.queue <- c
}
return rb
}
func (rb *Ring) Write(data []byte) (int, error) {
for _, c := range data {
rb.queue <- c
log.Printf("write: %q", string(c))
}
return len(data), nil
}
func (rb *Ring) Read(data []byte) (int, error) {
l := len(data)
for i := 0; i < l; i++ {
select {
case c, ok := <-rb.queue:
if !ok {
return i, ErrClosedBuffer
}
data[i] = c
log.Printf("read: %q", string(c))
default:
// Partial read
return i, nil
}
}
// Full read
return l, nil
}
func main() {
sig := make(chan any)
rb := New(8)
go func() {
rb.Write([]byte(text))
}()
go func() {
var buf [256]byte
nText := len(text)
for {
n, err := rb.Read(buf[:])
if err != nil {
log.Fatal(err)
}
nText -= n
if nText <= 0 {
break
}
}
close(sig)
}()
<-sig
}
var text = `Lorem ipsum dolor sit amet consectetur adipiscing elit. Quisque faucibus ex sapien vitae pellentesque sem placerat. In
id cursus mi pretium tellus duis convallis. Tempus leo eu aenean sed diam urna tempor. Pulvinar vivamus fringilla lacus nec metus
bibendum egestas. Iaculis massa nisl malesuada lacinia integer nunc posuere. Ut hendrerit semper vel class aptent taciti sociosqu.
Ad litora torquent per conubia nostra inceptos himenaeos.`
@caelifer
Copy link
Author

caelifer commented Apr 4, 2025

https://go.dev/play/p/SLDPNreDq3S

Output:

2009/11/10 23:00:00 read:      "L"
2009/11/10 23:00:00 write: "L"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "g"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "."
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "g"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "."
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "Q"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "q"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "f"
2009/11/10 23:00:00 read:      "Q"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "q"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "f"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "b"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "x"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "b"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "x"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "v"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "v"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "q"
2009/11/10 23:00:00 write: "q"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "."
2009/11/10 23:00:00 write: "."
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "I"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "\n"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "I"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "\n"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "v"
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "v"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "."
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "T"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "."
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "T"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: "."
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "P"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "v"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      "."
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "P"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "v"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "v"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "v"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "f"
2009/11/10 23:00:00 read:      "v"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "v"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "f"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "g"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "g"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "\n"
2009/11/10 23:00:00 write: "\n"
2009/11/10 23:00:00 write: "b"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "b"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "b"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "b"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      "g"
2009/11/10 23:00:00 write: "g"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "."
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "I"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "."
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "I"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "g"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "g"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "."
2009/11/10 23:00:00 write: "."
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "U"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "h"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "U"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "h"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "v"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "v"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 write: "q"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "."
2009/11/10 23:00:00 write: "\n"
2009/11/10 23:00:00 write: "A"
2009/11/10 23:00:00 write: "d"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "q"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "."
2009/11/10 23:00:00 read:      "\n"
2009/11/10 23:00:00 read:      "A"
2009/11/10 23:00:00 read:      "d"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "l"
2009/11/10 23:00:00 write: "l"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 write: "q"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 read:      "q"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "u"
2009/11/10 23:00:00 write: "b"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "u"
2009/11/10 23:00:00 read:      "b"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 read:      "r"
2009/11/10 23:00:00 write: "r"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "c"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "p"
2009/11/10 23:00:00 write: "t"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "c"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "p"
2009/11/10 23:00:00 read:      "t"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      " "
2009/11/10 23:00:00 write: " "
2009/11/10 23:00:00 write: "h"
2009/11/10 23:00:00 write: "i"
2009/11/10 23:00:00 write: "m"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "n"
2009/11/10 23:00:00 write: "a"
2009/11/10 23:00:00 write: "e"
2009/11/10 23:00:00 write: "o"
2009/11/10 23:00:00 write: "s"
2009/11/10 23:00:00 read:      "h"
2009/11/10 23:00:00 read:      "i"
2009/11/10 23:00:00 read:      "m"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "n"
2009/11/10 23:00:00 read:      "a"
2009/11/10 23:00:00 read:      "e"
2009/11/10 23:00:00 read:      "o"
2009/11/10 23:00:00 read:      "s"
2009/11/10 23:00:00 read:      "."
2009/11/10 23:00:00 write: "."

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment