Refactoring package go-mc/bot

This commit is contained in:
Tnze
2021-02-27 01:06:07 +08:00
parent e864580903
commit 3da9321f59
44 changed files with 564 additions and 3715 deletions

83
bot/basic/events.go Normal file
View File

@ -0,0 +1,83 @@
package basic
import (
"github.com/google/uuid"
"github.com/Tnze/go-mc/bot"
"github.com/Tnze/go-mc/chat"
"github.com/Tnze/go-mc/data/packetid"
pk "github.com/Tnze/go-mc/net/packet"
)
type EventsListener struct {
GameStart func() error
ChatMsg func(c chat.Message, pos byte, uuid uuid.UUID) error
Disconnect func(reason chat.Message) error
HealthChange func(health float32) error
Death func() error
}
func (e EventsListener) Attach(c *bot.Client) {
c.Events.AddListener(
bot.PacketHandler{Priority: 64, ID: packetid.Login, F: e.onJoinGame},
bot.PacketHandler{Priority: 64, ID: packetid.ChatClientbound, F: e.onChatMsg},
bot.PacketHandler{Priority: 64, ID: packetid.Disconnect, F: e.onDisconnect},
bot.PacketHandler{Priority: 64, ID: packetid.UpdateHealth, F: e.onUpdateHealth},
)
}
func (e *EventsListener) onJoinGame(_ pk.Packet) error {
if e.GameStart != nil {
return e.GameStart()
}
return nil
}
func (e *EventsListener) onDisconnect(p pk.Packet) error {
if e.Disconnect != nil {
var reason chat.Message
if err := p.Scan(&reason); err != nil {
return err
}
return e.Disconnect(reason)
}
return nil
}
func (e *EventsListener) onChatMsg(p pk.Packet) error {
if e.ChatMsg != nil {
var msg chat.Message
var pos pk.Byte
var sender pk.UUID
if err := p.Scan(&msg, &pos, &sender); err != nil {
return err
}
return e.ChatMsg(msg, byte(pos), uuid.UUID(sender))
}
return nil
}
func (e *EventsListener) onUpdateHealth(p pk.Packet) error {
if e.ChatMsg != nil {
var health pk.Float
var food pk.VarInt
var foodSaturation pk.Float
if err := p.Scan(&health, &food, &foodSaturation); err != nil {
return err
}
if e.HealthChange != nil {
if err := e.HealthChange(float32(health)); err != nil {
return err
}
}
if e.Death != nil && health <= 0 {
if err := e.Death(); err != nil {
return err
}
}
}
return nil
}