octets

package
v0.0.0-...-eb2fa4d Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 2, 2024 License: MIT Imports: 4 Imported by: 0

Documentation

Overview

Manipulate bytes.

Index

Constants

View Source
const IntSize = 32 << (^uint(0) >> 63)

IntSize is the size in bits of an int or uint value. From: https://cs.opensource.google/go/go/+/refs/tags/go1.20.1:src/strconv/atoi.go;drc=cf26fbb1f6d9644f447342f42d2dddcbe9ceda61;l=68

Variables

View Source
var (
	Digits      = []byte{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9'}
	LetterLower = []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}
	LetterUpper = []byte{'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'}
)

Functions

func BitwiseCheck

func BitwiseCheck[T BitwiseType](x, y T) bool

BitwiseCheck checks whether y bits is set of x. Returns the modified value.

func BitwiseClear

func BitwiseClear[T BitwiseType](x, y T) T

BitwiseClear unsets y bits of x. Returns the modified value.

func BitwiseSet

func BitwiseSet[T BitwiseType](x, y T) T

BitwiseSet sets y bits of x. Returns the modified value.

func BitwiseToggle

func BitwiseToggle[T BitwiseType](x, y T) T

BitwiseToggle toggles y bits of x. Returns the modified value.

func IsDigit

func IsDigit(c byte) bool

IsDigit returns whether c is a number character ascii code.

func IsHexa

func IsHexa(c byte) bool

IsHexa returns whether c is a hexadecimal (0-9 a-f A-F) character ascii code.

func IsLowerLetter

func IsLowerLetter(c byte) bool

IsLowerLetter returns whether c is a lower case letter (a-z) character ascii code.

func IsUpperLetter

func IsUpperLetter(c byte) bool

IsUpperLetter returns whether c is an upper case letter (A-Z) character ascii code.

func ReadBytes

func ReadBytes(b *[]byte, n int) []byte

ReadBytes removes the first n bytes from b and returns it. If the read failed, returns nil.

func ReadInt

func ReadInt(b *[]byte, bitSize int) (int, bool)

ReadInt removes the first bytes (depends on bitSize) from b and returns it as an int. bitSize must be 8, 16, 24, 32 or 64.

func ReadInt16

func ReadInt16(b *[]byte) (int16, bool)

ReadInt16 removes the first 2 bytes from b and returns it as an int16. The bool indicates whether the read was successful.

func ReadInt24

func ReadInt24(b *[]byte) (int32, bool)

ReadInt24 removes the first 3 bytes from b and returns it as a int32. The bool indicates whether the read was successful.

func ReadInt32

func ReadInt32(b *[]byte) (int32, bool)

ReadInt32 removes the first 4 bytes from b and returns it as an int32. The bool indicates whether the read was successful.

func ReadInt64

func ReadInt64(b *[]byte) (int64, bool)

ReadInt64 removes the first 8 bytes from b and returns it as an int64. The bool indicates whether the read was successful.

func ReadInt8

func ReadInt8(b *[]byte) (int8, bool)

ReadInt8 removes the first byte from b and returns it as an int8. The bool indicates whether the read was successful.

func ReadReaderBytes

func ReadReaderBytes(in io.Reader, n int) ([]byte, error)

ReadReaderBytes reads n byte from in. At the end of the file, io.EOF is returned.

func ReadReaderUint16

func ReadReaderUint16(in io.Reader) (uint16, error)

ReadReaderUint16 reads bytes from in and returns it as an uint16. At the end of the file io.EOF returned.

func ReadReaderUint24

func ReadReaderUint24(in io.Reader) (uint32, error)

ReadReaderUint24 reads bytes from in and returns it as an uint32. At the end of the file, io.EOF is returned.

func ReadReaderUint32

func ReadReaderUint32(in io.Reader) (uint32, error)

ReadReaderUint32 reads bytes from in and returns it as an uint32. At the end of the file io.EOF returned.

func ReadReaderUint8

func ReadReaderUint8(in io.Reader) (uint8, error)

ReadReaderUint8 reads a byte from in and returns is as an uint8. At the end of the file, io.EOF is returned.

func ReadUint16

func ReadUint16(b *[]byte) (uint16, bool)

ReadUint16 removes the first 2 bytes from b and returns it as an uint16. The bool indicates whether the read was successful.

func ReadUint24

func ReadUint24(b *[]byte) (uint32, bool)

ReadUint24 removes the first 3 bytes from b and returns it as a uint32. The bool indicates whether the read was successful.

func ReadUint32

func ReadUint32(b *[]byte) (uint32, bool)

ReadUint32 removes the first 4 bytes from b and returns it as an uint32. The bool indicates whether the read was successful.

func ReadUint64

func ReadUint64(b *[]byte) (uint64, bool)

ReadUint64 removes the first 8 bytes from b and returns it as an uint64. The bool indicates whether the read was successful.

func ReadUint8

func ReadUint8(b *[]byte) (uint8, bool)

ReadUint8 removes the first byte from b and returns it as an uint8. The bool indicates whether the read was successful.

func Skip

func Skip(b *[]byte, n int) bool

Skip removes the first n bytes from b. Returns whether it was successful.

func SkipReader

func SkipReader(in io.Reader, n int) error

ReadReaderSkip skips n bytes in in. At the end of the file, io.EOF is returned.

func WriteBytes

func WriteBytes(b *[]byte, bytes ...byte)

WriteBytes appends bytes at the end of b.

func WriteInt

func WriteInt(b *[]byte, v int, bitSize int)

WriteInt append v at the end of b with size bitSize. bitSize must be 8, 16, 24, 32 or 64.

func WriteInt16

func WriteInt16(b *[]byte, v int16)

WriteInt16 appends v at the end of b.

func WriteInt24

func WriteInt24(b *[]byte, v int32)

WriteInt24 appends v at the end of b.

func WriteInt32

func WriteInt32(b *[]byte, v int32)

WriteInt32 appends v at the end of b.

func WriteInt64

func WriteInt64(b *[]byte, v int64)

WriteInt64 appends v at the end of b.

func WriteInt8

func WriteInt8(b *[]byte, v int8)

WriteInt8 appends v at the end of b.

func WriteUint16

func WriteUint16(b *[]byte, v uint16)

WriteUint16 appends v at the end of b.

func WriteUint24

func WriteUint24(b *[]byte, v uint32)

WriteUint24 appends v at the end of b.

func WriteUint32

func WriteUint32(b *[]byte, v uint32)

WriteUint32 appends v at the end of b.

func WriteUint64

func WriteUint64(b *[]byte, v uint64)

WriteUint64 appends v at the end of b.

func WriteUint8

func WriteUint8(b *[]byte, v uint8)

WriteUint8 appends v at the end of b.

func WriteWriterBytes

func WriteWriterBytes(in io.Writer, bytes ...byte) error

WriteWriterBytes appends v at the end of in.

func WriteWriterUint16

func WriteWriterUint16(in io.Writer, v uint16) error

WriteWriterUint16 appends v at the end of in.

func WriteWriterUint24

func WriteWriterUint24(in io.Writer, v uint32) error

WriteWriterUint24 appends v at the end of in.

func WriteWriterUint32

func WriteWriterUint32(in io.Writer, v uint32) error

WriteWriterUint32 appends v at the end of in.

func WriteWriterUint8

func WriteWriterUint8(in io.Writer, v uint8) error

WriteWriterUint8 appends v at the end of in.

Types

type BitwiseType

type BitwiseType interface {
	int8 | uint8 | int16 | uint16 | int32 | uint32 | int64 | uint64 | uint | uintptr | int
}

type Buffer

type Buffer struct {
	// contains filtered or unexported fields
}

func NewBuffer

func NewBuffer(bytes []byte) Buffer

func NewEmpty

func NewEmpty() Buffer

NewEmpty creates a Buffer with a zero length byte slice.

func ReadAll

func ReadAll(r io.Reader) (Buffer, error)

ReadAll reads from r until an error or EOF and returns a Buffer from the data it read. A successful call returns err == nil, not err == EOF. Because ReadAll is defined to read from src until EOF, it does not treat an EOF from Read as an error to be reported.

func (*Buffer) Bytes

func (b *Buffer) Bytes() []byte

Bytes returns the underlying byte slice.

func (*Buffer) BytesPointer

func (b *Buffer) BytesPointer() *[]byte

BytesPointer returns a pointer to the underlying byte slice.

func (*Buffer) Empty

func (b *Buffer) Empty() bool

Empty returns whether b is empty.

func (*Buffer) ReadBytes

func (b *Buffer) ReadBytes(n int) []byte

ReadBytes removes the first n bytes from b and returns it. If the read failed, returns nil.

func (*Buffer) ReadGMTUnixTime32

func (b *Buffer) ReadGMTUnixTime32() (time.Time, bool)

ReadGMTUnixTime32 removes the first bytes from b and returns it as an unix time. The bool indicates whether the read was successful.

func (*Buffer) ReadInt

func (b *Buffer) ReadInt() (int, bool)

ReadInt removes the first bytes (depends on IntSize) from b and returns it as an int.

func (*Buffer) ReadInt16

func (b *Buffer) ReadInt16() (int16, bool)

ReadInt16 removes the first bytes from b and returns it as an int16. The bool indicates whether the read was successful.

func (*Buffer) ReadInt24

func (b *Buffer) ReadInt24() (int32, bool)

ReadInt24 removes the first bytes from b and returns it as a int32. The bool indicates whether the read was successful.

func (*Buffer) ReadInt32

func (b *Buffer) ReadInt32() (int32, bool)

ReadInt32 removes the first bytes from b and returns it as an int32. The bool indicates whether the read was successful.

func (*Buffer) ReadInt64

func (b *Buffer) ReadInt64() (int64, bool)

ReadInt64 removes the first bytes from b and returns it as an int64. The bool indicates whether the read was successful.

func (*Buffer) ReadInt8

func (b *Buffer) ReadInt8() (int8, bool)

ReadInt8 removes the first byte from b and returns it as an int8. The bool indicates whether the read was successful.

func (*Buffer) ReadUint16

func (b *Buffer) ReadUint16() (uint16, bool)

ReadUint16 removes the first bytes from b and returns it as an uint16. The bool indicates whether the read was successful.

func (*Buffer) ReadUint24

func (b *Buffer) ReadUint24() (uint32, bool)

ReadUint24 removes the first bytes from b and returns it as a uint32. The bool indicates whether the read was successful.

func (*Buffer) ReadUint32

func (b *Buffer) ReadUint32() (uint32, bool)

ReadUint32 removes the first bytes from b and returns it as an uint32. The bool indicates whether the read was successful.

func (*Buffer) ReadUint64

func (b *Buffer) ReadUint64() (uint64, bool)

ReadUint64 removes the first bytes from b and returns it as an uint64. The bool indicates whether the read was successful.

func (*Buffer) ReadUint8

func (b *Buffer) ReadUint8() (uint8, bool)

ReadUint8 removes the first byte from b and returns it as an uint8. The bool indicates whether the read was successful.

func (*Buffer) ReadVector

func (b *Buffer) ReadVector(bitSize int) ([]byte, bool)

ReadVector reads the length of bytes then the bytes itself. The length type is depend on bitSize (eg.: uint8, uint16, uint24, uint32, uint64). Therefore, bitSize must be 8/16/24/32/64. If bitSize is an invalid number, this function panics.

func (*Buffer) Size

func (b *Buffer) Size() int

Size returns the size of the underlying byte slice

func (*Buffer) Skip

func (b *Buffer) Skip(n int) bool

Skip removes the first n bytes from b. Returns whether it was successful.

func (*Buffer) WriteBytes

func (b *Buffer) WriteBytes(bytes ...byte)

WriteBytes appends bytes at the end of b.

func (*Buffer) WriteGMTUnixTime32

func (b *Buffer) WriteGMTUnixTime32(time time.Time)

WriteGMTUnixTime32 appends time to b in 32 bit unix format.

func (*Buffer) WriteInt

func (b *Buffer) WriteInt(v int)

WriteInt append v at the end of b with size bitSize. The number of bytes depends on IntSize.

func (*Buffer) WriteInt16

func (b *Buffer) WriteInt16(v int16)

WriteInt16 appends v at the end of b.

func (*Buffer) WriteInt24

func (b *Buffer) WriteInt24(v int32)

WriteInt24 appends v at the end of b.

func (*Buffer) WriteInt32

func (b *Buffer) WriteInt32(v int32)

WriteInt32 appends v at the end of b.

func (*Buffer) WriteInt64

func (b *Buffer) WriteInt64(v int64)

WriteInt64 appends v at the end of b.

func (*Buffer) WriteInt8

func (b *Buffer) WriteInt8(v int8)

WriteInt8 appends v at the end of b.

func (*Buffer) WriteRandom

func (b *Buffer) WriteRandom(n int)

WriteRandom appends n random bytes to b. If failed to read random, this function panics. This function gets random numbers from `crypto/rand` package.

func (*Buffer) WriteUint16

func (b *Buffer) WriteUint16(v uint16)

WriteUint16 appends v at the end of b.

func (*Buffer) WriteUint24

func (b *Buffer) WriteUint24(v uint32)

WriteUint24 appends v at the end of b.

func (*Buffer) WriteUint32

func (b *Buffer) WriteUint32(v uint32)

WriteUint32 appends v at the end of b.

func (*Buffer) WriteUint64

func (b *Buffer) WriteUint64(v uint64)

WriteUint64 appends v at the end of b.

func (*Buffer) WriteUint8

func (b *Buffer) WriteUint8(v uint8)

WriteUint8 appends v at the end of b.

func (*Buffer) WriteVector

func (b *Buffer) WriteVector(v []byte, bitSize int)

WriteVector appends the length of bytes then the bytes itself. The length type is depend on bitSize (eg.: uint8, uint16, uint24, uint32, uint64). Therefore, bitSize must be 8/16/24/32/64. If bitSize is an invalid number, this function panics.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL