
This commit includes updates that affects the build, testing, and deployment of Tile38. - The root level build.sh has been broken up into multiple scripts and placed in the "scripts" directory. - The vendor directory has been updated to follow the Go modules rules, thus `make` should work on isolated environments. Also some vendored packages may have been updated to a later version, if needed. - The Makefile has been updated to allow for making single binaries such as `make tile38-server`. There is some scaffolding during the build process, so from now on all binaries should be made using make. For example, to run a development version of the tile38-cli binary, do this: make tile38-cli && ./tile38-cli not this: go run cmd/tile38-cli/main.go - Travis.CI docker push script has been updated to address a change to Docker's JSON repo meta output, which in turn fixes a bug where new Tile38 versions were not being properly pushed to Docker
30 lines
694 B
Go
30 lines
694 B
Go
package sarama
|
|
|
|
import "encoding/binary"
|
|
|
|
// LengthField implements the PushEncoder and PushDecoder interfaces for calculating 4-byte lengths.
|
|
type lengthField struct {
|
|
startOffset int
|
|
}
|
|
|
|
func (l *lengthField) saveOffset(in int) {
|
|
l.startOffset = in
|
|
}
|
|
|
|
func (l *lengthField) reserveLength() int {
|
|
return 4
|
|
}
|
|
|
|
func (l *lengthField) run(curOffset int, buf []byte) error {
|
|
binary.BigEndian.PutUint32(buf[l.startOffset:], uint32(curOffset-l.startOffset-4))
|
|
return nil
|
|
}
|
|
|
|
func (l *lengthField) check(curOffset int, buf []byte) error {
|
|
if uint32(curOffset-l.startOffset-4) != binary.BigEndian.Uint32(buf[l.startOffset:]) {
|
|
return PacketDecodingError{"length field invalid"}
|
|
}
|
|
|
|
return nil
|
|
}
|