// Daze could join an offline-mode server as client. // Just standing there and do nothing. Automatically reborn after five seconds of death. package main import ( "errors" "flag" "log" "time" "github.com/google/uuid" //"github.com/mattn/go-colorable" "github.com/Tnze/go-mc/bot" "github.com/Tnze/go-mc/bot/basic" "github.com/Tnze/go-mc/bot/screen" "github.com/Tnze/go-mc/chat" "github.com/Tnze/go-mc/data/item" _ "github.com/Tnze/go-mc/data/lang/zh-cn" ) var address = flag.String("address", "127.0.0.1", "The server address") var client *bot.Client var player *basic.Player var screenManager *screen.Manager func main() { flag.Parse() //log.SetOutput(colorable.NewColorableStdout()) client = bot.NewClient() client.Auth.Name = "Daze" player = basic.NewPlayer(client, basic.DefaultSettings) basic.EventsListener{ GameStart: onGameStart, ChatMsg: onChatMsg, Disconnect: onDisconnect, Death: onDeath, }.Attach(client) screenManager = screen.NewManager(client, screen.EventsListener{ Open: nil, SetSlot: onScreenSlotChange, Close: nil, }) //Login err := client.JoinServer(*address) if err != nil { log.Fatal(err) } log.Println("Login success") //JoinGame for { if err = client.HandleGame(); err == nil { panic("HandleGame never return nil") } if err2 := new(bot.PacketHandlerError); errors.As(err, err2) { if err := new(DisconnectErr); errors.As(err2, err) { log.Print("Disconnect: ", err.Reason) return } else { // print and ignore the error log.Print(err2) } } else { log.Fatal(err) } } } func onDeath() error { log.Println("Died and Respawned") // If we exclude Respawn(...) then the player won't press the "Respawn" button upon death go func() { time.Sleep(time.Second * 5) err := player.Respawn() if err != nil { log.Print(err) } }() return nil } func onGameStart() error { log.Println("Game start") return nil //if err isn't nil, HandleGame() will return it. } func onChatMsg(c chat.Message, _ byte, _ uuid.UUID) error { log.Println("Chat:", c) // output chat message without any format code (like color or bold) return nil } func onScreenSlotChange(id, index int) error { if id == -2 { log.Printf("Slot: inventory: %v", screenManager.Inventory.Slots[index]) } else if id == -1 && index == -1 { log.Printf("Slot: cursor: %v", screenManager.Cursor) } else { container, ok := screenManager.Screens[id] if ok { // Currently, only inventory container is supported switch container.(type) { case *screen.Inventory: slot := container.(*screen.Inventory).Slots[index] itemInfo := item.ByID[item.ID(slot.ID)] log.Printf("Slot: Screen[%d].Slot[%d]: [%v] * %d | NBT: %v", id, index, itemInfo, slot.Count, slot.NBT) } } } return nil } type DisconnectErr struct { Reason chat.Message } func (d DisconnectErr) Error() string { return "disconnect: " + d.Reason.String() } func onDisconnect(reason chat.Message) error { // return an error value so that we can stop main loop return DisconnectErr{Reason: reason} }