refactor package

This commit is contained in:
2025-08-22 05:14:59 +08:00
parent bec0a56a3d
commit 65690e51ab
371 changed files with 835 additions and 627 deletions

View File

@ -0,0 +1,275 @@
// Code generated by github.com/go-mc/packetizer; DO NOT EDIT.
package recipe
import (
"io"
"github.com/Tnze/go-mc/net/packet"
)
func (c *Shapeless) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = packet.Array(&c.Ingredients).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c Shapeless) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = packet.Array(&c.Ingredients).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c *Shaped) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = (*packet.VarInt)(&c.Width).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (*packet.VarInt)(&c.Height).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = packet.Array(&c.Ingredients).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c Shaped) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = (*packet.VarInt)(&c.Width).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (*packet.VarInt)(&c.Height).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = packet.Array(&c.Ingredients).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c *Furnace) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = (&c.Ingredient).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Fuel).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (*packet.VarInt)(&c.CookingTime).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (*packet.Float)(&c.Experience).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c Furnace) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = (&c.Ingredient).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Fuel).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (*packet.VarInt)(&c.CookingTime).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (*packet.Float)(&c.Experience).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c *Stonecutter) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = (&c.Ingredient).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c Stonecutter) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = (&c.Ingredient).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c *Smithing) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = (&c.Template).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Base).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Addition).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c Smithing) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = (&c.Template).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Base).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Addition).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Result).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.CraftingStation).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}

View File

@ -0,0 +1,118 @@
package recipe
import (
"io"
"git.konjactw.dev/patyhank/minego/codec/slot/display/slot"
pk "github.com/Tnze/go-mc/net/packet"
)
type DisplayType int32
const (
DisplayCraftingShapeless DisplayType = 0 + iota
DisplayCraftingShaped
DisplayFurnace
DisplayStonecutter
DisplaySmithing
)
type Display struct {
Display RecipeDisplay
}
func (d Display) WriteTo(w io.Writer) (n int64, err error) {
pk.VarInt(d.Display.RecipeType()).WriteTo(w)
return d.Display.WriteTo(w)
}
func (d *Display) ReadFrom(r io.Reader) (n int64, err error) {
var displayType DisplayType
_, err = (*pk.VarInt)(&displayType).ReadFrom(r)
if err != nil {
return
}
switch displayType {
case DisplayCraftingShapeless:
d.Display = new(Shapeless)
case DisplayCraftingShaped:
d.Display = new(Shaped)
case DisplayFurnace:
d.Display = new(Furnace)
case DisplayStonecutter:
d.Display = new(Stonecutter)
case DisplaySmithing:
d.Display = new(Smithing)
}
if d.Display != nil {
return d.Display.ReadFrom(r)
}
return
}
type RecipeDisplay interface {
RecipeType() DisplayType
pk.Field
}
//codec:gen
type Shapeless struct {
Ingredients []slot.Display
Result slot.Display
CraftingStation slot.Display
}
func (i Shapeless) RecipeType() DisplayType {
return DisplayCraftingShapeless
}
//codec:gen
type Shaped struct {
Width int32 `mc:"VarInt"`
Height int32 `mc:"VarInt"`
Ingredients []slot.Display
Result slot.Display
CraftingStation slot.Display
}
func (i Shaped) RecipeType() DisplayType {
return DisplayCraftingShaped
}
//codec:gen
type Furnace struct {
Ingredient slot.Display
Fuel slot.Display
Result slot.Display
CraftingStation slot.Display
CookingTime int32 `mc:"VarInt"`
Experience float32
}
func (i Furnace) RecipeType() DisplayType {
return DisplayFurnace
}
//codec:gen
type Stonecutter struct {
Ingredient slot.Display
Result slot.Display
CraftingStation slot.Display
}
func (i Stonecutter) RecipeType() DisplayType {
return DisplayStonecutter
}
//codec:gen
type Smithing struct {
Template slot.Display
Base slot.Display
Addition slot.Display
Result slot.Display
CraftingStation slot.Display
}
func (i Smithing) RecipeType() DisplayType {
return DisplaySmithing
}

View File

@ -0,0 +1,154 @@
// Code generated by github.com/go-mc/packetizer; DO NOT EDIT.
package slot
import (
"io"
"github.com/Tnze/go-mc/net/packet"
)
func (c *Item) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = (*packet.VarInt)(&c.ID).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c Item) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = (*packet.VarInt)(&c.ID).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c *ItemStack) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = (&c.ItemStack).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c ItemStack) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = (&c.ItemStack).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c *Tag) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = (&c.Tag).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c Tag) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = (&c.Tag).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c *SmithingTrim) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = (&c.Base).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Trim).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Remainder).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c SmithingTrim) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = (&c.Base).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Trim).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Remainder).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c *WithRemainder) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = (&c.Ingredient).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Remainder).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c WithRemainder) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = (&c.Ingredient).WriteTo(w)
n += temp
if err != nil {
return n, err
}
temp, err = (&c.Remainder).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c *Composite) ReadFrom(r io.Reader) (n int64, err error) {
var temp int64
temp, err = packet.Array(&c.Displays).ReadFrom(r)
n += temp
if err != nil {
return n, err
}
return n, err
}
func (c Composite) WriteTo(w io.Writer) (n int64, err error) {
var temp int64
temp, err = packet.Array(&c.Displays).WriteTo(w)
n += temp
if err != nil {
return n, err
}
return n, err
}

View File

@ -0,0 +1,135 @@
package slot
import (
"io"
"git.konjactw.dev/patyhank/minego/pkg/protocol/slot"
pk "github.com/Tnze/go-mc/net/packet"
)
type DisplayType int32
const (
DisplayEmpty DisplayType = iota
DisplayItem
DisplayItemStack
DisplayTag
DisplaySmithingTrim
DisplayWithRemainder
DisplayComposite
)
type Display struct {
SlotDisplay
}
func (s Display) WriteTo(w io.Writer) (n int64, err error) {
pk.VarInt(s.SlotDisplay.SlotDisplayType()).WriteTo(w)
s.SlotDisplay.WriteTo(w)
return
}
func (s *Display) ReadFrom(r io.Reader) (n int64, err error) {
var displayType DisplayType
_, err = (*pk.VarInt)(&displayType).ReadFrom(r)
if err != nil {
return
}
switch displayType {
case DisplayEmpty:
return
case DisplayItem:
var item Item
if _, err = item.ReadFrom(r); err != nil {
return
}
case DisplayItemStack:
var itemStack ItemStack
if _, err = itemStack.ReadFrom(r); err != nil {
return
}
case DisplayTag:
var tag Tag
if _, err = tag.ReadFrom(r); err != nil {
return
}
case DisplaySmithingTrim:
var trim SmithingTrim
if _, err = trim.ReadFrom(r); err != nil {
return
}
case DisplayWithRemainder:
var remainder WithRemainder
if _, err = remainder.ReadFrom(r); err != nil {
return
}
case DisplayComposite:
var composite Composite
if _, err = composite.ReadFrom(r); err != nil {
return
}
}
return
}
type SlotDisplay interface {
SlotDisplayType() DisplayType
pk.Field
}
//codec:gen
type Item struct {
ID int32 `mc:"VarInt"`
}
func (i Item) SlotDisplayType() DisplayType {
return DisplayItem
}
//codec:gen
type ItemStack struct {
ItemStack slot.Slot
}
func (i ItemStack) SlotDisplayType() DisplayType {
return DisplayItemStack
}
//codec:gen
type Tag struct {
Tag pk.Identifier
}
func (i Tag) SlotDisplayType() DisplayType {
return DisplayTag
}
//codec:gen
type SmithingTrim struct {
Base Display
Trim Display
Remainder Display
}
func (i SmithingTrim) SlotDisplayType() DisplayType {
return DisplaySmithingTrim
}
//codec:gen
type WithRemainder struct {
Ingredient Display
Remainder Display
}
func (i WithRemainder) SlotDisplayType() DisplayType {
return DisplayWithRemainder
}
//codec:gen
type Composite struct {
Displays []Display
}
func (i Composite) SlotDisplayType() DisplayType {
return DisplayComposite
}