types

package
v0.9.3 Latest Latest
Warning

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

Go to latest
Published: Jun 28, 2024 License: Apache-2.0 Imports: 16 Imported by: 3

Documentation

Overview

Package types contains the infrastructure needed to support serialization of Go types.

Index

Constants

This section is empty.

Variables

View Source
var ErrBuildIDMismatch = errors.New("build ID mismatch")

ErrBuildIDMismatch is an error that occurs when a program attempts to deserialize objects from another build.

Functions

func Deserialize

func Deserialize(b []byte) (x interface{}, err error)

Deserialize value from b. Return left over bytes.

func DeserializeTo

func DeserializeTo[T any](d *Deserializer, x *T)

Deserialize a value to the provided non-nil pointer. See [RegisterSerde].

func FuncAddr

func FuncAddr(fn any) uintptr

FuncAddr returns the address in memory of the closure passed as argument.

This function can only resolve addresses of closures in the compilation unit that it is part of; for example, if compiled in a Go plugin, it can only resolve the address of functions within that plugin, and the main program cannot resolve addresses of functions in the plugins it loaded.

If the argument is a nil function value, the return address is zero.

The function panics if called with a value which is not a function.

func Register

func Register[T any](
	serializer SerializerFunc[T],
	deserializer DeserializerFunc[T])

Register attaches custom serialization and deserialization functions to type T.

Coroutine state is serialized and deserialized when calling [Context.Marshal] and [Context.Unmarshal] respectively.

Go basic types, structs, interfaces, slices, arrays, or any combination of them have built-in serialization and deserialization mechanisms. Channels and sync values do not.

Custom serializer and deserializer functions can be attached to types using Register to control how they are serialized, and possibly perform additional initialization on deserialization. Those functions are drivers for Serializer and Deserializer, that need to invoke Serialize and DeserializeTo in order to actually perform serialization and deserialization operations. Pointers to the same address are detected as such to be reconstructed as pointing to the same value. Slices are serialized by first serializing their backing array, and then length and capacity. As a result, slices sharing the same backing array are deserialized into one array with two shared slices, just like the original state was. Elements between length and capacity are also preserved.

func RegisterClosure

func RegisterClosure[Type, Closure any](name string)

RegisterClosure is like RegisterFunc but the caller can specify the closure type (see types.Func for details).

func RegisterFunc

func RegisterFunc[Type any](name string)

RegisterFunc is a helper function used to register function types. The type parameter must be a function type, but no compile nor runtime checks are used to enforce it; passing anything other than a function type will likely result in panics later on when the program attempts to serialize the function value.

The name argument is a unique identifier of the Go symbol that represents the function, which has the package path as prefix, and the dot-separated sequence identifying the function in the package.

func Serialize

func Serialize(x any) ([]byte, error)

Serialize x.

The output of Serialize can be reconstructed back to a Go value using Deserialize.

func SerializeT

func SerializeT[T any](s *Serializer, x T)

Serialize a value. See [RegisterSerde].

Types

type Deserializer

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

type DeserializerFunc

type DeserializerFunc[T any] func(*Deserializer, *T) error

DeserializerFunc is the signature of customer deserializer functions. Use the Deserialize function to drive the Deserializer. Returning an error results in the program panicking.

type Field

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

Field is a struct field.

func (*Field) Anonymous

func (f *Field) Anonymous() bool

Anonymous is true of the field is an embedded field (with a name derived from its type).

func (*Field) Name

func (f *Field) Name() string

Name is the name of the field.

func (*Field) Offset

func (f *Field) Offset() uint64

Offset is the offset of the field within its struct, in bytes.

func (*Field) Package

func (f *Field) Package() string

Package is the package path that qualifies a lwer case (unexported) field name. It is empty for upper case (exported) field names.

func (*Field) Tag

func (f *Field) Tag() reflect.StructTag

Tag contains struct field metadata.

func (*Field) Type

func (f *Field) Type() *Type

Type is the type of the field.

type Func

type Func struct {
	// The address where the function exists in the program memory.
	Addr uintptr

	// The name that uniquely represents the function.
	//
	// For regular functions, this values has the form <package>.<function>.
	//
	// For closures, this value has the form <package>.<function>.func<N>, where
	// N starts at 1 and increments for each closure defined in the function.
	Name string

	// A type representing the signature of the function value.
	//
	// This field is nil if the type is unknown; by default the field is nil and
	// the program is expected to initialize it to a non-nil value for functions
	// that may be serialized.
	//
	// If non-nil, the type must be of kind reflect.Func.
	Type reflect.Type

	// A struct type representing the memory layout of the closure.
	//
	// This field is nil if the type is unknown; by default the field is nil and
	// the program is expected to initialize it to a non-nil value for closures
	// that may be serialized. For regular functions, this field can remain nil
	// since regular functions do not capture any values.
	//
	// If non-nil, the first field of the struct type must be a uintptr intended
	// to hold the address to the function value.
	Closure reflect.Type
}

Func represents a function in the program.

func FuncByAddr

func FuncByAddr(addr uintptr) *Func

FuncByAddr returns the function associated with the given address.

Addresses in the returned Func value hold the value of the symbol location in the program memory.

If the address passed as argument is not the address of a function in the program, the function returns nil.

func FuncByName

func FuncByName(name string) *Func

FuncByName returns the function associated with the given name.

Addresses in the returned Func value hold the value of the symbol location in the program memory.

If the name passed as argument does not represent any function, the function returns nil.

type Function

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

Function is a function, method or closure referenced by the coroutine.

func (*Function) ClosureType

func (f *Function) ClosureType() *Type

ClosureType returns the memory layout for closure functions.

The returned type is a struct where the first field is a function pointer and the remaining fields are the variables from outer scopes that are referenced by the closure.

Nil is returned for functions that are not closures.

func (*Function) Index

func (f *Function) Index() int

Index is the index of the function in the serialized state.

func (*Function) Name

func (f *Function) Name() string

Name is the name of the function.

func (*Function) String

func (f *Function) String() string

String is the name of the function.

func (*Function) Type

func (f *Function) Type() *Type

Type is the type of the function.

type Region

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

Region is a region of memory referenced by the coroutine.

func (*Region) Index

func (t *Region) Index() int

Index is the index of the region in the serialized state, or -1 if this is the root region.

func (*Region) Scan

func (r *Region) Scan() *Scanner

Scan returns an region scanner.

func (*Region) Size

func (r *Region) Size() int64

Size is the size of the region in bytes.

func (*Region) String

func (r *Region) String() string

String is a summary of the region in string form.

func (*Region) Type

func (r *Region) Type() *Type

Type is the type of the region.

type Scanner

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

Scanner scans a Region.

func (*Scanner) Bool

func (s *Scanner) Bool() bool

Bool returns the bool the scanner points to.

func (*Scanner) Cap

func (s *Scanner) Cap() int

Cap is the capacity of the slice the scanner is pointing to.

func (*Scanner) Close

func (s *Scanner) Close() error

Close closes the scanner and returns any errors that occurred during scanning.

func (*Scanner) Complex128

func (s *Scanner) Complex128() complex128

Complex128 returns the complex128 the scanner points to.

func (*Scanner) Complex64

func (s *Scanner) Complex64() complex64

Complex64 returns the complex64 the scanner points to.

func (*Scanner) Custom

func (s *Scanner) Custom() bool

Custom is true if the scanner is scanning an object for which a custom serializer was registered.

func (*Scanner) Depth

func (s *Scanner) Depth() int

Depth is the depth of the scan stack.

func (*Scanner) Field

func (s *Scanner) Field() *Field

Field is the field the scanner is pointing to.

func (*Scanner) Float32

func (s *Scanner) Float32() float32

Float32 returns the float32 the scanner points to.

func (*Scanner) Float64

func (s *Scanner) Float64() float64

Float64 returns the float64 the scanner points to.

func (*Scanner) Function

func (s *Scanner) Function() *Function

Function is the function the scanner is pointing to.

func (*Scanner) Int

func (s *Scanner) Int() int

Int returns the int the scanner points to.

func (*Scanner) Int16

func (s *Scanner) Int16() int16

Int16 returns the int16 the scanner points to.

func (*Scanner) Int32

func (s *Scanner) Int32() int32

Int32 returns the int32 the scanner points to.

func (*Scanner) Int64

func (s *Scanner) Int64() int64

Int64 returns the int64 the scanner points to.

func (*Scanner) Int8

func (s *Scanner) Int8() int8

Int8 returns the int8 the scanner points to.

func (*Scanner) Kind

func (s *Scanner) Kind() reflect.Kind

Kind is the kind of entity the scanner is pointing to.

func (*Scanner) Len

func (s *Scanner) Len() int

Len is the length of the string, slice, array or map the scanner is pointing to.

func (*Scanner) Next

func (s *Scanner) Next() bool

Next is true if there is more to scan.

func (*Scanner) Nil

func (s *Scanner) Nil() bool

Nil is true if the scanner is pointing to nil.

func (*Scanner) Pos

func (s *Scanner) Pos() int

Pos is the position of the scanner, in terms of number of bytes into the region.

func (*Scanner) Region

func (s *Scanner) Region() (*Region, int64)

Region is the region and offset the scanner is pointing to.

func (*Scanner) Type

func (s *Scanner) Type() *Type

Type is the type the scanner is pointing to.

func (*Scanner) Uint

func (s *Scanner) Uint() uint

Uint returns the uint8 the scanner points to.

func (*Scanner) Uint16

func (s *Scanner) Uint16() uint16

Uint16 returns the uint16 the scanner points to.

func (*Scanner) Uint32

func (s *Scanner) Uint32() uint32

Uint32 returns the uint32 the scanner points to.

func (*Scanner) Uint64

func (s *Scanner) Uint64() uint64

Uint64 returns the uint64 the scanner points to.

func (*Scanner) Uint8

func (s *Scanner) Uint8() uint8

Uint8 returns the uint8 the scanner points to.

func (*Scanner) Uintptr

func (s *Scanner) Uintptr() uintptr

Uintptr returns the uintptr the scanner points to.

type Serializer

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

Serializer holds the state for serialization.

The ptrs value maps from pointers to IDs. Each time the serialization process encounters a pointer, it assigns it a new unique ID for its given address. This mechanism allows writing shared data only once. The actual value is written the first time a given pointer ID is encountered.

The containers value has ranges of memory held by container types. They are the values that actually own memory: structs and arrays.

Serialization starts with scanning the graph of values to find all the containers and add the range of memory they occupy into the map. Regions belong to the outermost container. For example:

struct X {
  struct Y {
    int
  }
}

creates only one container: the struct X. Both struct Y and the int are containers, but they are included in the region of struct X.

Those two mechanisms allow the deserialization of pointers that point to shared memory. Only outermost containers are serialized. All pointers either point to a container, or an offset into that container.

type SerializerFunc

type SerializerFunc[T any] func(*Serializer, *T) error

SerializerFunc is the signature of custom serializer functions. Use the Serialize function to drive the Serializer. Returning an error results in the program panicking.

type State

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

State wraps durable coroutine state.

func Inspect

func Inspect(b []byte) (*State, error)

Inspect inspects serialized durable coroutine state.

The input should be a buffer produced by (*coroutine.Context).Marshal or by types.Serialize.

func (*State) Arch

func (s *State) Arch() string

Arch returns the architecture the coroutine was compiled for.

func (*State) BuildID

func (s *State) BuildID() string

BuildID returns the build ID of the program that generated this state.

func (*State) Function

func (s *State) Function(i int) *Function

Function returns a function by index.

func (*State) NumFunction

func (s *State) NumFunction() int

NumFunction returns the number of functions/methods/closures referenced by the coroutine.

func (*State) NumRegion

func (s *State) NumRegion() int

NumRegion returns the number of memory regions referenced by the coroutine.

func (*State) NumString

func (s *State) NumString() int

NumString returns the number of strings referenced by types.

func (*State) NumType

func (s *State) NumType() int

NumType returns the number of types referenced by the coroutine.

func (*State) OS

func (s *State) OS() string

OS returns the operating system the coroutine was compiled for.

func (*State) Region

func (s *State) Region(i int) *Region

Region retrieves a region by index.

func (*State) Root

func (s *State) Root() *Region

Root is the root object that was serialized.

func (*State) String

func (s *State) String(i int) string

String retrieves a string by index.

func (*State) Type

func (s *State) Type(i int) *Type

Type returns a type by index.

type Type

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

Type is a type referenced by a durable coroutine.

func (*Type) ChanDir

func (t *Type) ChanDir() reflect.ChanDir

ChanDir is the direction of a channel type.

func (*Type) Elem

func (t *Type) Elem() *Type

Elem is the type of an array, slice, pointer, chan or map's element.

func (*Type) Field

func (t *Type) Field(i int) *Field

Field retrieves a struct field by index.

func (*Type) Format

func (t *Type) Format(s fmt.State, v rune)

Format implements fmt.Formatter.

func (*Type) Index

func (t *Type) Index() int

Index is the index of the type in the serialized state, or -1 if the type is derived from a serialized type.

func (*Type) Key

func (t *Type) Key() *Type

Key is the key type for map types.

func (*Type) Kind

func (t *Type) Kind() reflect.Kind

Kind is the underlying kind for this type.

func (*Type) Len

func (t *Type) Len() int

Len is the length of an array type.

func (*Type) MemoryOffset

func (t *Type) MemoryOffset() uint64

MemoryOffset is the location of this type in memory.

The offset is only applicable to the build that generated the state.

func (*Type) Name

func (t *Type) Name() string

Name is the name of the type within the package it was defined.

func (*Type) NumField

func (t *Type) NumField() int

NumField is the number of struct fields for struct types.

func (*Type) NumParam

func (t *Type) NumParam() int

NumParam is the number of parameters for function types.

func (*Type) NumResult

func (t *Type) NumResult() int

NumResult is the number of results for function types.

func (*Type) Opaque

func (t *Type) Opaque() bool

Opaue is true for types that had a custom serializer registered in the program that generated the coroutine state. Custom types are opaque and cannot be inspected.

func (*Type) Package

func (t *Type) Package() string

Package is the name of the package that defines the type.

func (*Type) Param

func (t *Type) Param(i int) *Type

Param is the type of a function parameter with the specified index.

func (*Type) Result

func (t *Type) Result(i int) *Type

Result is the type of a function result with the specified index.

func (*Type) Variadic

func (t *Type) Variadic() bool

Variadic is true for function types with a variadic final argument.

Jump to

Keyboard shortcuts

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