cleanup
This commit is contained in:
parent
c9c5ed09ac
commit
000d804f04
@ -86,60 +86,58 @@ func NewFromReader(reader io.ReadSeeker) (*Sprite, error) {
|
|||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func readDirectionHeader(reader io.ReadSeeker) (*directionHeader, error) {
|
func readDirectionHeader(bitReader *streaming.BitReader) (*directionHeader, error) {
|
||||||
r := streaming.NewBitReader(reader)
|
|
||||||
|
|
||||||
var (
|
var (
|
||||||
dirHead directionHeader
|
dirHead directionHeader
|
||||||
err error
|
err error
|
||||||
)
|
)
|
||||||
|
|
||||||
dirHead.CodedSize, err = r.ReadUint32(32)
|
dirHead.CodedSize, err = bitReader.ReadUint32(32)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirHead.HasRawPixelEncoding, err = r.ReadBool()
|
dirHead.HasRawPixelEncoding, err = bitReader.ReadBool()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirHead.CompressEqualCells, err = r.ReadBool()
|
dirHead.CompressEqualCells, err = bitReader.ReadBool()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirHead.Variable0Bits, err = r.ReadUint32(4)
|
dirHead.Variable0Bits, err = bitReader.ReadUint32(4)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirHead.WidthBits, err = r.ReadUint32(4)
|
dirHead.WidthBits, err = bitReader.ReadUint32(4)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirHead.HeightBits, err = r.ReadUint32(4)
|
dirHead.HeightBits, err = bitReader.ReadUint32(4)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirHead.OffsetXBits, err = r.ReadInt32(4)
|
dirHead.OffsetXBits, err = bitReader.ReadInt32(4)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirHead.OffsetYBits, err = r.ReadInt32(4)
|
dirHead.OffsetYBits, err = bitReader.ReadInt32(4)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirHead.OptionalBytesBits, err = r.ReadUint32(4)
|
dirHead.OptionalBytesBits, err = bitReader.ReadUint32(4)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirHead.CodedBytesBits, err = r.ReadUint32(4)
|
dirHead.CodedBytesBits, err = bitReader.ReadUint32(4)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -147,50 +145,48 @@ func readDirectionHeader(reader io.ReadSeeker) (*directionHeader, error) {
|
|||||||
return &dirHead, nil
|
return &dirHead, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func readFrameHeader(reader io.ReadSeeker, dirHead directionHeader) (*frameHeader, error) {
|
func readFrameHeader(bitReader *streaming.BitReader, dirHead directionHeader) (*frameHeader, error) {
|
||||||
r := streaming.NewBitReader(reader)
|
|
||||||
|
|
||||||
var (
|
var (
|
||||||
frameHead frameHeader
|
frameHead frameHeader
|
||||||
err error
|
err error
|
||||||
)
|
)
|
||||||
|
|
||||||
frameHead.Variable0, err = readPackedUint32(r, int(dirHead.Variable0Bits))
|
frameHead.Variable0, err = readPackedUint32(bitReader, int(dirHead.Variable0Bits))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
frameHead.Width, err = readPackedUint32(r, int(dirHead.WidthBits))
|
frameHead.Width, err = readPackedUint32(bitReader, int(dirHead.WidthBits))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
frameHead.Height, err = readPackedUint32(r, int(dirHead.HeightBits))
|
frameHead.Height, err = readPackedUint32(bitReader, int(dirHead.HeightBits))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
frameHead.OffsetX, err = readPackedInt32(r, int(dirHead.OffsetXBits))
|
frameHead.OffsetX, err = readPackedInt32(bitReader, int(dirHead.OffsetXBits))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
frameHead.OffsetY, err = readPackedInt32(r, int(dirHead.OffsetYBits))
|
frameHead.OffsetY, err = readPackedInt32(bitReader, int(dirHead.OffsetYBits))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
frameHead.OptionalBytes, err = readPackedUint32(r, int(dirHead.OptionalBytesBits))
|
frameHead.OptionalBytes, err = readPackedUint32(bitReader, int(dirHead.OptionalBytesBits))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
frameHead.CodedBytes, err = readPackedUint32(r, int(dirHead.CodedBytesBits))
|
frameHead.CodedBytes, err = readPackedUint32(bitReader, int(dirHead.CodedBytesBits))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
frameHead.FrameBottomUp, err = r.ReadBool()
|
frameHead.FrameBottomUp, err = bitReader.ReadBool()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -199,17 +195,19 @@ func readFrameHeader(reader io.ReadSeeker, dirHead directionHeader) (*frameHeade
|
|||||||
}
|
}
|
||||||
|
|
||||||
func readDirection(reader io.ReadSeeker, fileHead fileHeader) error {
|
func readDirection(reader io.ReadSeeker, fileHead fileHeader) error {
|
||||||
dirHead, err := readDirectionHeader(reader)
|
bitReader := streaming.NewBitReader(reader)
|
||||||
|
|
||||||
|
dirHead, err := readDirectionHeader(bitReader)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
frameHead, err := readFrameHeader(reader, *dirHead)
|
frameHead, err := readFrameHeader(bitReader, *dirHead)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// fmt.Printf("%+v\n", dirHead)
|
fmt.Printf("%+v\n", dirHead)
|
||||||
fmt.Printf("%+v\n", frameHead)
|
fmt.Printf("%+v\n", frameHead)
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
Loading…
Reference in New Issue
Block a user