TastyBuffer

dotty.tools.tasty.TastyBuffer
See theTastyBuffer companion object
class TastyBuffer(initialSize: Int)

A byte array buffer that can be filled with bytes or natural numbers in TASTY format, and that supports reading and patching addresses represented as natural numbers.

Attributes

Companion
object
Graph
Supertypes
class Object
trait Matchable
class Any

Members list

Value members

Concrete methods

def assemble(): Unit

Hook to be overridden in subclasses. Perform all actions necessary to assemble the final byte array. After assemble no more output actions to this buffer are permitted.

Hook to be overridden in subclasses. Perform all actions necessary to assemble the final byte array. After assemble no more output actions to this buffer are permitted.

Attributes

The address referring to the end of data written so far

The address referring to the end of data written so far

Attributes

def fillAddr(at: Addr, target: Addr): Unit

Fill reserved space at address at with address target

Fill reserved space at address at with address target

Attributes

def getAddr(at: Addr): Addr

The address (represented as a natural number) at address at

The address (represented as a natural number) at address at

Attributes

def getByte(at: Addr): Int

The byte at given address

The byte at given address

Attributes

def getLongNat(at: Addr): Long

The long natural number at address at

The long natural number at address at

Attributes

def getNat(at: Addr): Int

The natural number at address at

The natural number at address at

Attributes

def putNat(at: Addr, x: Int, width: Int): Unit

Write natural number x right-adjusted in a field of width bytes starting with address at.

Write natural number x right-adjusted in a field of width bytes starting with address at.

Attributes

def reserveAddr(): Addr

Reserve AddrWidth bytes to write an address into

Reserve AddrWidth bytes to write an address into

Attributes

def reset(): Unit
final def skipNat(at: Addr): Addr

The address after the natural number found at address at.

The address after the natural number found at address at.

Attributes

final def skipZeroes(at: Addr): Addr

The smallest address equal to or following at which points to a non-zero byte

The smallest address equal to or following at which points to a non-zero byte

Attributes

def writeAddr(addr: Addr): Unit

Write address without leading zeroes

Write address without leading zeroes

Attributes

def writeByte(b: Int): Unit

Write a byte of data.

Write a byte of data.

Attributes

def writeBytes(data: Array[Byte], n: Int): Unit

Write the first n bytes of data.

Write the first n bytes of data.

Attributes

def writeInt(x: Int): Unit

Write a natural number in 2's complement big endian format, base 128. All but the last digits have bit 0x80 set.

Write a natural number in 2's complement big endian format, base 128. All but the last digits have bit 0x80 set.

Attributes

def writeLongInt(x: Long): Unit

Like writeInt, but for longs

Like writeInt, but for longs

Attributes

def writeLongNat(x: Long): Unit

Like writeNat, but for longs. Note that the binary representation of LongNat is identical to Nat if the long value is in the range Int.MIN_VALUE to Int.MAX_VALUE.

Like writeNat, but for longs. Note that the binary representation of LongNat is identical to Nat if the long value is in the range Int.MIN_VALUE to Int.MAX_VALUE.

Attributes

def writeNat(x: Int): Unit

Write a natural number in big endian format, base 128. All but the last digits have bit 0x80 set.

Write a natural number in big endian format, base 128. All but the last digits have bit 0x80 set.

Attributes

def writeUncompressedLong(x: Long): Unit

Write an uncompressed Long stored in 8 bytes in big endian format

Write an uncompressed Long stored in 8 bytes in big endian format

Attributes

Concrete fields

var bytes: Array[Byte]

The current byte array, will be expanded as needed

The current byte array, will be expanded as needed

Attributes

var length: Int

The number of bytes written

The number of bytes written

Attributes