witty/cmd/replay/replay.go

70 lines
1.2 KiB
Go
Raw Normal View History

2022-01-14 23:04:50 +01:00
package main
import (
"encoding/json"
"io"
"log"
"os"
"time"
"golang.org/x/term"
)
type writeRecord struct {
Dur time.Duration `json:"Duration"`
Data []byte `json:"Data"`
}
func main() {
if len(os.Args) != 2 {
log.Fatalln("Usage: replay <recordfile>")
}
fp, err := os.Open(os.Args[1])
if err != nil {
log.Fatalln("Failed to open record file", err)
}
screen := struct {
io.Reader
io.Writer
}{os.Stdin, os.Stdout}
t := term.NewTerminal(screen, ">")
if t == nil {
log.Fatalln("Failed to create terminal")
}
2022-01-14 23:16:06 +01:00
w, h, _ := term.GetSize(int(os.Stdout.Fd()))
2022-01-14 23:04:50 +01:00
if (w != 120) || (h != 36) {
2022-01-16 00:54:15 +01:00
log.Println("Set terminal window to 120x36 before continue")
2022-01-14 23:04:50 +01:00
}
decoder := json.NewDecoder(fp)
if decoder == nil {
log.Fatalln("Failed to create JSON decoder")
}
2022-01-16 00:54:15 +01:00
// To work with javascript decoder, we organize the file as
// an array of writeRecord. golang decode instead decode
// as individual record. Call decoder.Token to skip opening [
decoder.Token()
2022-01-14 23:04:50 +01:00
for decoder.More() {
var record writeRecord
if err := decoder.Decode(&record); err != nil {
log.Println("Failed to decode record", err)
continue
}
time.Sleep(record.Dur)
t.Write(record.Data)
}
2022-01-16 00:54:15 +01:00
t.Write([]byte("\n\n---end of replay---\n\n"))
2022-01-14 23:04:50 +01:00
}