"compress/zlib"
"encoding/binary"
"errors"
- "fmt"
"github.com/anon55555/mt"
"io"
)
ErrInvalidStaticObjVer = errors.New("invalid static object version")
)
-type ErrInvalidNodeName struct {
- Name string
-}
-
-func (e ErrInvalidNodeName) Error() string {
- return fmt.Sprintf("invalid node \"%v\"", e.Name)
-}
-
-type ErrInvalidNodeId struct {
- Id mt.Content
-}
-
-func (e ErrInvalidNodeId) Error() string {
- return fmt.Sprintf("invalid node %v", e.Id)
-}
-
func Deserialize(r io.Reader, idNameMap map[string]mt.Content) *MapBlk {
var blk = &MapBlk{}
}
for i := 0; i < 4096; i++ {
- name, ok := nameIdMap[blk.Param0[i]]
+ id := blk.Param0[i]
+ if isSpecial(id) {
+ continue
+ }
+
+ name, ok := nameIdMap[id]
if !ok {
- panic(ErrInvalidNodeId{blk.Param0[i]})
+ panic(ErrInvalidNodeId{id})
}
- id, ok := idNameMap[name]
+ blk.Param0[i], ok = idNameMap[name]
if !ok {
panic(ErrInvalidNodeName{name})
}
-
- blk.Param0[i] = id
}
return blk
var localNameIdMap = make(map[mt.Content]string)
for i := 0; i < 4096; i++ {
- if _, ok := localNameIdMap[blk.Param0[i]]; ok {
+ id := blk.Param0[i]
+ if isSpecial(id) {
continue
}
- localNameIdMap[blk.Param0[i]] = nameIdMap[blk.Param0[i]]
+ if _, ok := localNameIdMap[id]; ok {
+ continue
+ }
+
+ name, ok := nameIdMap[id]
+ if !ok {
+ panic(ErrInvalidNodeId{id})
+ }
+
+ localNameIdMap[id] = name
}
var nameIdMapCount = uint16(len(localNameIdMap))
package mtmap
import (
+ "fmt"
"github.com/anon55555/mt"
)
Pos [3]float32
Data string
}
+
+type ErrInvalidNodeName struct {
+ Name string
+}
+
+func (e ErrInvalidNodeName) Error() string {
+ return fmt.Sprintf("invalid node \"%v\"", e.Name)
+}
+
+type ErrInvalidNodeId struct {
+ Id mt.Content
+}
+
+func (e ErrInvalidNodeId) Error() string {
+ return fmt.Sprintf("invalid node %v", e.Id)
+}
+
+func isSpecial(id mt.Content) bool {
+ return id >= 125 && id <= 127
+}