Documentation ¶
Index ¶
- Constants
- Variables
- func AlgType(t *Type) (AlgKind, *Type)
- func AllowsGoVersion(pkg *Pkg, major, minor int) bool
- func CalcSize(t *Type)
- func CalcStructSize(s *Type)
- func CheckDclstack()
- func CheckSize(t *Type)
- func CleanroomDo(f func())
- func DeferCheckSize()
- func FmtConst(v constant.Value, sharp bool) string
- func Identical(t1, t2 *Type) bool
- func IdenticalIgnoreTags(t1, t2 *Type) bool
- func IdenticalStrict(t1, t2 *Type) bool
- func InitTypes(defTypeName func(sym *Sym, typ *Type) Object)
- func InternString(b []byte) string
- func IsComparable(t *Type) bool
- func IsDirectIface(t *Type) bool
- func IsExported(name string) bool
- func IsInterfaceMethod(f *Type) bool
- func IsMethodApplicable(t *Type, m *Field) bool
- func IsPaddedField(t *Type, i int) bool
- func IsReflectPkg(p *Pkg) bool
- func IsReflexive(t *Type) bool
- func IsRuntimePkg(p *Pkg) bool
- func Markdcl()
- func ParseLangFlag()
- func Popdcl()
- func PtrDataSize(t *Type) int64
- func Pushdcl(s *Sym)
- func RecalcSize(t *Type)
- func ResumeCheckSize()
- func Rnd(o int64, r int64) int64
- func TypeHasNoAlg(t *Type) bool
- func TypeHash(t *Type) uint32
- func TypeSymName(t *Type) string
- type AlgKind
- type Array
- type Chan
- type ChanArgs
- type ChanDir
- type Cmp
- type EmbeddedsByName
- type Field
- type Fields
- type Forward
- type Funarg
- type Func
- type FuncArgs
- type Interface
- type Kind
- type Map
- type MethodsByName
- type Object
- type Pkg
- type Ptr
- type Results
- type Slice
- type Struct
- type Sym
- func (sym *Sym) Asm() bool
- func (s *Sym) Format(f fmt.State, verb rune)
- func (sym *Sym) Func() bool
- func (sym *Sym) IsBlank() bool
- func (a *Sym) Less(b *Sym) bool
- func (sym *Sym) Linksym() *obj.LSymdeprecated
- func (sym *Sym) LinksymABI(abi obj.ABI) *obj.LSymdeprecated
- func (sym *Sym) OnExportList() bool
- func (s *Sym) PkgDef() Object
- func (sym *Sym) SetAsm(b bool)
- func (sym *Sym) SetFunc(b bool)
- func (sym *Sym) SetOnExportList(b bool)
- func (s *Sym) SetPkgDef(n Object)
- func (sym *Sym) SetSiggen(b bool)
- func (sym *Sym) SetUniq(b bool)
- func (sym *Sym) Siggen() bool
- func (s *Sym) String() string
- func (sym *Sym) Uniq() bool
- type Tuple
- type Type
- func ComplexForFloat(t *Type) *Type
- func FakeRecvType() *Type
- func FloatForComplex(t *Type) *Type
- func NewArray(elem *Type, bound int64) *Type
- func NewChan(elem *Type, dir ChanDir) *Type
- func NewChanArgs(c *Type) *Type
- func NewFuncArgs(f *Type) *Type
- func NewInterface(pkg *Pkg, methods []*Field, implicit bool) *Type
- func NewMap(k, v *Type) *Type
- func NewNamed(obj TypeObject) *Type
- func NewPtr(elem *Type) *Type
- func NewResults(types []*Type) *Type
- func NewSignature(pkg *Pkg, recv *Field, tparams, params, results []*Field) *Type
- func NewSlice(elem *Type) *Type
- func NewStruct(pkg *Pkg, fields []*Field) *Type
- func NewTuple(t1, t2 *Type) *Type
- func NewTypeParam(sym *Sym, index int) *Type
- func NewUnion(terms []*Type, tildes []bool) *Type
- func ReceiverBaseType(t *Type) *Type
- func SubstAny(t *Type, types *[]*Type) *Type
- func (t *Type) Alignment() int64
- func (t *Type) AllMethods() *Fields
- func (t *Type) ArgWidth() int64
- func (t *Type) Bound() *Type
- func (t *Type) Broke() bool
- func (*Type) CanBeAnSSAAux()
- func (t *Type) ChanArgs() *Type
- func (t *Type) ChanDir() ChanDir
- func (t *Type) ChanType() *Chan
- func (t *Type) Compare(x *Type) Cmp
- func (t *Type) Deferwidth() bool
- func (t *Type) Elem() *Type
- func (t *Type) Field(i int) *Field
- func (t *Type) FieldName(i int) string
- func (t *Type) FieldOff(i int) int64
- func (t *Type) FieldSlice() []*Field
- func (t *Type) FieldType(i int) *Type
- func (t *Type) Fields() *Fields
- func (t *Type) Format(s fmt.State, verb rune)
- func (t *Type) ForwardType() *Forward
- func (t *Type) FuncArgs() *Type
- func (t *Type) FuncType() *Func
- func (t *Type) HasNil() bool
- func (t *Type) HasPointers() bool
- func (t *Type) HasShape() bool
- func (t *Type) HasTParam() bool
- func (t *Type) Index() int
- func (t *Type) IsArray() bool
- func (t *Type) IsBaseGeneric() bool
- func (t *Type) IsBoolean() bool
- func (t *Type) IsChan() bool
- func (t *Type) IsComplex() bool
- func (t *Type) IsEmptyInterface() bool
- func (t *Type) IsFlags() bool
- func (t *Type) IsFloat() bool
- func (t *Type) IsFullyInstantiated() bool
- func (t *Type) IsFuncArgStruct() bool
- func (t *Type) IsImplicit() bool
- func (t *Type) IsInstantiatedGeneric() bool
- func (t *Type) IsInteger() bool
- func (t *Type) IsInterface() bool
- func (t *Type) IsKind(et Kind) bool
- func (t *Type) IsMap() bool
- func (t *Type) IsMemory() bool
- func (t *Type) IsPtr() bool
- func (t *Type) IsPtrElem() bool
- func (t *Type) IsPtrShaped() bool
- func (t *Type) IsResults() bool
- func (t *Type) IsScalar() bool
- func (t *Type) IsShape() bool
- func (t *Type) IsSigned() bool
- func (t *Type) IsSlice() bool
- func (t *Type) IsString() bool
- func (t *Type) IsStruct() bool
- func (t *Type) IsTuple() bool
- func (t *Type) IsTypeParam() bool
- func (t *Type) IsUintptr() bool
- func (t *Type) IsUnion() bool
- func (t *Type) IsUnsafePtr() bool
- func (t *Type) IsUnsigned() bool
- func (t *Type) IsUntyped() bool
- func (t *Type) IsVariadic() bool
- func (t *Type) IsVoid() bool
- func (t *Type) Key() *Type
- func (t *Type) Kind() Kind
- func (t *Type) LinkString() string
- func (t *Type) MapType() *Map
- func (t *Type) MarkImplicit()
- func (t *Type) Methods() *Fields
- func (t *Type) NameString() string
- func (t *Type) Noalg() bool
- func (t *Type) NotInHeap() bool
- func (t *Type) NumComponents(countBlank componentsIncludeBlankFields) int64
- func (t *Type) NumElem() int64
- func (t *Type) NumFields() int
- func (t *Type) NumParams() int
- func (t *Type) NumRecvs() int
- func (t *Type) NumResults() int
- func (t *Type) NumTParams() int
- func (t *Type) NumTerms() int
- func (t *Type) Obj() Object
- func (t *Type) OrigSym() *Sym
- func (t *Type) Params() *Type
- func (t *Type) Pkg() *Pkg
- func (t *Type) Pos() src.XPos
- func (t *Type) PtrTo() *Type
- func (t *Type) RParams() []*Type
- func (t *Type) Recur() bool
- func (t *Type) Recv() *Field
- func (t *Type) Recvs() *Type
- func (t *Type) Results() *Type
- func (t *Type) SetAllMethods(fs []*Field)
- func (t *Type) SetBound(bound *Type)
- func (t *Type) SetBroke(b bool)
- func (t *Type) SetDeferwidth(b bool)
- func (t *Type) SetFields(fields []*Field)
- func (t *Type) SetHasShape(b bool)
- func (t *Type) SetHasTParam(b bool)
- func (t *Type) SetIndex(i int)
- func (t *Type) SetInterface(methods []*Field)
- func (t *Type) SetIsShape(b bool)
- func (t *Type) SetNoalg(b bool)
- func (t *Type) SetNod(n Object)
- func (t *Type) SetNotInHeap(b bool)
- func (t *Type) SetOrigSym(sym *Sym)
- func (t *Type) SetRParams(rparams []*Type)
- func (t *Type) SetRecur(b bool)
- func (t *Type) SetSym(sym *Sym)
- func (t *Type) SetUnderlying(underlying *Type)
- func (t *Type) SetVargen()
- func (t *Type) SimpleString() string
- func (t *Type) Size() int64
- func (t *Type) SoleComponent() *Type
- func (t *Type) String() string
- func (t *Type) StructType() *Struct
- func (t *Type) Sym() *Sym
- func (t *Type) TParams() *Type
- func (t *Type) Term(i int) (*Type, bool)
- func (t *Type) ToUnsigned() *Type
- func (t *Type) Underlying() *Type
- type TypeObject
- type Typeparam
- type Union
Constants ¶
const ( CMPlt = Cmp(-1) CMPeq = Cmp(0) CMPgt = Cmp(1) )
const ( IgnoreBlankFields componentsIncludeBlankFields = false CountBlankFields componentsIncludeBlankFields = true )
const BADWIDTH = -1000000000
const BOGUS_FUNARG_OFFSET = -1000000000
const MaxPkgHeight = 1e9
MaxPkgHeight is a height greater than any likely package height.
Variables ¶
var ( SlicePtrOffset int64 SliceLenOffset int64 SliceCapOffset int64 SliceSize int64 StringSize int64 )
Slices in the runtime are represented by three components:
type slice struct { ptr unsafe.Pointer len int cap int }
Strings in the runtime are represented by two components:
type string struct { ptr unsafe.Pointer len int }
These variables are the offsets of fields and sizes of these structs.
var ( // Predeclared alias types. These are actually created as distinct // defined types for better error messages, but are then specially // treated as identical to their respective underlying types. AnyType *Type ByteType *Type RuneType *Type // Predeclared error interface type. ErrorType *Type // Predeclared comparable interface type. ComparableType *Type // Types to represent untyped string and boolean constants. UntypedString = newType(TSTRING) UntypedBool = newType(TBOOL) // Types to represent untyped numeric constants. UntypedInt = newType(TIDEAL) UntypedRune = newType(TIDEAL) UntypedFloat = newType(TIDEAL) UntypedComplex = newType(TIDEAL) )
var ( // TSSA types. HasPointers assumes these are pointer-free. TypeInvalid = newSSA("invalid") TypeMem = newSSA("mem") TypeFlags = newSSA("flags") TypeVoid = newSSA("void") TypeInt128 = newSSA("int128") TypeResultMem = newResults([]*Type{TypeMem}) )
var ( IsInt [NTYPE]bool IsFloat [NTYPE]bool IsComplex [NTYPE]bool IsSimple [NTYPE]bool )
var BasicTypeNames = []string{
TINT: "int",
TUINT: "uint",
TINT8: "int8",
TUINT8: "uint8",
TINT16: "int16",
TUINT16: "uint16",
TINT32: "int32",
TUINT32: "uint32",
TINT64: "int64",
TUINT64: "uint64",
TUINTPTR: "uintptr",
TFLOAT32: "float32",
TFLOAT64: "float64",
TCOMPLEX64: "complex64",
TCOMPLEX128: "complex128",
TBOOL: "bool",
TANY: "any",
TSTRING: "string",
TNIL: "nil",
TIDEAL: "untyped number",
TBLANK: "blank",
}
var Block int32 = 1 // current block number
var CalcSizeDisabled bool
CalcSizeDisabled indicates whether it is safe to calculate Types' widths and alignments. See CalcSize.
var IsOrdered [NTYPE]bool
var MaxWidth int64
MaxWidth is the maximum size of a value on the target architecture.
var NewPtrCacheEnabled = true
NewPtrCacheEnabled controls whether *T Types are cached in T. Caching is disabled just before starting the backend. This allows the backend to run concurrently.
var NumImport = make(map[string]int)
numImport tracks how often a package with a given name is imported. It is used to provide a better error message (by using the package path to disambiguate) if a package that appears multiple times with the same name appears in an error message.
var ParamsResults = [2]func(*Type) *Type{ (*Type).Params, (*Type).Results, }
ParamsResults is like RecvsParamsResults, but omits receiver parameters.
var PtrSize int
var RecvsParams = [2]func(*Type) *Type{ (*Type).Recvs, (*Type).Params, }
RecvsParams is like RecvsParamsResults, but omits result parameters.
var RecvsParamsResults = [3]func(*Type) *Type{ (*Type).Recvs, (*Type).Params, (*Type).Results, }
RecvsParamsResults stores the accessor functions for a function Type's receiver, parameters, and result parameters, in that order. It can be used to iterate over all of a function's parameter lists.
var RegSize int
var ShapePkg = NewPkg("go.shape", "go.shape")
var SimType [NTYPE]Kind
var SkipSizeForTracing bool
var Types [NTYPE]*Type
Types stores pointers to predeclared named types.
It also stores pointers to several special types:
- Types[TANY] is the placeholder "any" type recognized by SubstArgTypes.
- Types[TBLANK] represents the blank variable's type.
- Types[TINTER] is the canonical "interface{}" type.
- Types[TNIL] represents the predeclared "nil" value's type.
- Types[TUNSAFEPTR] is package unsafe's Pointer type.
Functions ¶
func AlgType ¶ added in go1.17
AlgType returns the AlgKind used for comparing and hashing Type t. If it returns ANOEQ, it also returns the component type of t that makes it incomparable.
func AllowsGoVersion ¶ added in go1.17
AllowsGoVersion reports whether a particular package is allowed to use Go version major.minor. We assume the imported packages have all been checked, so we only have to check the local package against the -lang flag.
func CalcSize ¶ added in go1.17
func CalcSize(t *Type)
CalcSize calculates and stores the size and alignment for t. If CalcSizeDisabled is set, and the size/alignment have not already been calculated, it calls Fatal. This is used to prevent data races in the back end.
func CalcStructSize ¶ added in go1.17
func CalcStructSize(s *Type)
CalcStructSize calculates the size of s, filling in s.Width and s.Align, even if size calculation is otherwise disabled.
func CheckDclstack ¶ added in go1.17
func CheckDclstack()
func CleanroomDo ¶
func CleanroomDo(f func())
CleanroomDo invokes f in an environment with no preexisting packages. For testing of import/export only.
func DeferCheckSize ¶ added in go1.17
func DeferCheckSize()
func Identical ¶ added in go1.12
Identical reports whether t1 and t2 are identical types, following the spec rules. Receiver parameter types are ignored. Named (defined) types are only equal if they are pointer-equal - i.e. there must be a unique types.Type for each specific named type. Also, a type containing a shape type is considered identical to another type (shape or not) if their underlying types are the same, or they are both pointers.
func IdenticalIgnoreTags ¶ added in go1.12
IdenticalIgnoreTags is like Identical, but it ignores struct tags for struct identity.
func IdenticalStrict ¶ added in go1.18
IdenticalStrict is like Identical, but matches types exactly, without the exception for shapes.
func InternString ¶
func IsComparable ¶ added in go1.17
IsComparable reports whether t is a comparable type.
func IsDirectIface ¶ added in go1.17
Can this type be stored directly in an interface word? Yes, if the representation is a single pointer.
func IsExported ¶ added in go1.11
IsExported reports whether name is an exported Go symbol (that is, whether it begins with an upper-case letter).
func IsInterfaceMethod ¶ added in go1.17
IsInterfaceMethod reports whether (field) m is an interface method. Such methods have the special receiver type types.FakeRecvType().
func IsMethodApplicable ¶ added in go1.17
IsMethodApplicable reports whether method m can be called on a value of type t. This is necessary because we compute a single method set for both T and *T, but some *T methods are not applicable to T receivers.
func IsPaddedField ¶ added in go1.17
IsPaddedField reports whether the i'th field of struct type t is followed by padding.
func IsReflectPkg ¶ added in go1.17
IsReflectPkg reports whether p is package reflect.
func IsReflexive ¶ added in go1.17
IsReflexive reports whether t has a reflexive equality operator. That is, if x==x for all x of type t.
func IsRuntimePkg ¶ added in go1.17
IsRuntimePkg reports whether p is package runtime.
func ParseLangFlag ¶ added in go1.17
func ParseLangFlag()
ParseLangFlag verifies that the -lang flag holds a valid value, and exits if not. It initializes data used by langSupported.
func Popdcl ¶
func Popdcl()
Popdcl pops the innermost block scope and restores all symbol declarations to their previous state.
func PtrDataSize ¶ added in go1.17
PtrDataSize returns the length in bytes of the prefix of t containing pointer data. Anything after this offset is scalar data.
PtrDataSize is only defined for actual Go types. It's an error to use it on compiler-internal types (e.g., TSSA, TRESULTS).
func Pushdcl ¶
func Pushdcl(s *Sym)
Pushdcl pushes the current declaration for symbol s (if any) so that it can be shadowed by a new declaration within a nested block scope.
func RecalcSize ¶ added in go1.18
func RecalcSize(t *Type)
RecalcSize is like CalcSize, but recalculates t's size even if it has already been calculated before. It does not recalculate other types.
func ResumeCheckSize ¶ added in go1.17
func ResumeCheckSize()
func TypeHasNoAlg ¶ added in go1.17
TypeHasNoAlg reports whether t does not have any associated hash/eq algorithms because t, or some component of t, is marked Noalg.
func TypeHash ¶ added in go1.17
TypeHash computes a hash value for type t to use in type switch statements.
func TypeSymName ¶ added in go1.17
Types ¶
type AlgKind ¶ added in go1.17
type AlgKind int
AlgKind describes the kind of algorithms used for comparing and hashing a Type.
const ( // These values are known by runtime. ANOEQ AlgKind = iota AMEM0 AMEM8 AMEM16 AMEM32 AMEM64 AMEM128 ASTRING AINTER ANILINTER AFLOAT32 AFLOAT64 ACPLX64 ACPLX128 // Type can be compared/hashed as regular memory. AMEM AlgKind = 100 // Type needs special comparison/hashing functions. ASPECIAL AlgKind = -1 )
type Array ¶
type Array struct { Elem *Type // element type Bound int64 // number of elements; <0 if unknown yet }
Array contains Type fields specific to array types.
type ChanArgs ¶
type ChanArgs struct {
T *Type // reference to a chan type whose elements need a width check
}
ChanArgs contains Type fields specific to TCHANARGS types.
type Cmp ¶
type Cmp int8
Cmp is a comparison between values a and b. -1 if a < b
0 if a == b 1 if a > b
type EmbeddedsByName ¶ added in go1.18
type EmbeddedsByName []*Field
EmbeddedsByName sorts embedded types by name.
func (EmbeddedsByName) Len ¶ added in go1.18
func (x EmbeddedsByName) Len() int
func (EmbeddedsByName) Less ¶ added in go1.18
func (x EmbeddedsByName) Less(i, j int) bool
func (EmbeddedsByName) Swap ¶ added in go1.18
func (x EmbeddedsByName) Swap(i, j int)
type Field ¶
type Field struct { Embedded uint8 // embedded field Pos src.XPos Sym *Sym Type *Type // field type Note string // literal string annotation // For fields that represent function parameters, Nname points // to the associated ONAME Node. Nname Object // Offset in bytes of this field or method within its enclosing struct // or interface Type. Exception: if field is function receiver, arg or // result, then this is BOGUS_FUNARG_OFFSET; types does not know the Abi. Offset int64 // contains filtered or unexported fields }
A Field is a (Sym, Type) pairing along with some other information, and, depending on the context, is used to represent:
- a field in a struct
- a method in an interface or associated with a named type
- a function parameter
func IncomparableField ¶ added in go1.17
IncomparableField returns an incomparable Field of struct Type t, if any.
func (*Field) IsMethod ¶ added in go1.13
IsMethod reports whether f represents a method rather than a struct field.
func (*Field) Nointerface ¶
func (*Field) SetNointerface ¶
type Fields ¶
type Fields struct {
// contains filtered or unexported fields
}
Fields is a pointer to a slice of *Field. This saves space in Types that do not have fields or methods compared to a simple slice of *Field.
func (*Fields) Index ¶
Index returns the i'th element of Fields. It panics if f does not have at least i+1 elements.
type Forward ¶
type Forward struct { Copyto []*Type // where to copy the eventual value to Embedlineno src.XPos // first use of this type as an embedded type }
Forward contains Type fields specific to forward types.
type Func ¶
type Func struct { Receiver *Type // function receiver Results *Type // function results Params *Type // function params TParams *Type // type params of receiver (if method) or function // Argwid is the total width of the function receiver, params, and results. // It gets calculated via a temporary TFUNCARGS type. // Note that TFUNC's Width is Widthptr. Argwid int64 // contains filtered or unexported fields }
Func contains Type fields specific to func types.
type FuncArgs ¶
type FuncArgs struct {
T *Type // reference to a func type whose elements need a width check
}
// FuncArgs contains Type fields specific to TFUNCARGS types.
type Interface ¶
type Interface struct {
// contains filtered or unexported fields
}
Interface contains Type fields specific to interface types.
type Kind ¶ added in go1.17
type Kind uint8
Kind describes a kind of type.
const ( Txxx Kind = iota TINT8 TUINT8 TINT16 TUINT16 TINT32 TUINT32 TINT64 TUINT64 TINT TUINT TUINTPTR TCOMPLEX64 TCOMPLEX128 TFLOAT32 TFLOAT64 TBOOL TPTR TFUNC TSLICE TARRAY TSTRUCT TCHAN TMAP TINTER TFORW TANY TSTRING TUNSAFEPTR TTYPEPARAM TUNION // pseudo-types for literals TIDEAL // untyped numeric constants TNIL TBLANK // pseudo-types for frame layout TFUNCARGS TCHANARGS // SSA backend types TSSA // internal types used by SSA backend (flags, memory, etc.) TTUPLE // a pair of types, used by SSA backend TRESULTS // multiple types; the result of calling a function or method, with a memory at the end. NTYPE )
type Map ¶
type Map struct { Key *Type // Key type Elem *Type // Val (elem) type Bucket *Type // internal struct type representing a hash bucket Hmap *Type // internal struct type representing the Hmap (map header object) Hiter *Type // internal struct type representing hash iterator state }
Map contains Type fields specific to maps.
type MethodsByName ¶ added in go1.17
type MethodsByName []*Field
MethodsByName sorts methods by name.
func (MethodsByName) Len ¶ added in go1.17
func (x MethodsByName) Len() int
func (MethodsByName) Less ¶ added in go1.17
func (x MethodsByName) Less(i, j int) bool
func (MethodsByName) Swap ¶ added in go1.17
func (x MethodsByName) Swap(i, j int)
type Object ¶ added in go1.17
Object represents an ir.Node, but without needing to import cmd/compile/internal/ir, which would cause an import cycle. The uses in other packages must type assert values of type Object to ir.Node or a more specific type.
type Pkg ¶
type Pkg struct { Path string // string literal used in import statement, e.g. "runtime/internal/sys" Name string // package name, e.g. "sys" Prefix string // escaped path for use in symbol table Syms map[string]*Sym Pathsym *obj.LSym // Height is the package's height in the import graph. Leaf // packages (i.e., packages with no imports) have height 0, // and all other packages have height 1 plus the maximum // height of their imported packages. Height int Direct bool // imported directly }
var BuiltinPkg *Pkg
BuiltinPkg is a fake package that declares the universe block.
var LocalPkg *Pkg
LocalPkg is the package being compiled.
NoPkg is a nil *Pkg value for clarity. It's intended for use when constructing types that aren't exported and thus don't need to be associated with any package.
var UnsafePkg *Pkg
UnsafePkg is package unsafe.
func ImportedPkgList ¶
func ImportedPkgList() []*Pkg
ImportedPkgList returns the list of directly imported packages. The list is sorted by package path.
func NewPkg ¶
NewPkg returns a new Pkg for the given package path and name. Unless name is the empty string, if the package exists already, the existing package name and the provided name must match.
func (*Pkg) LookupBytes ¶
type Ptr ¶
type Ptr struct {
Elem *Type // element type
}
Ptr contains Type fields specific to pointer types.
type Results ¶ added in go1.16
type Results struct {
Types []*Type // Last element is memory output from call.
}
Results are the output from calls that will be late-expanded.
type Slice ¶
type Slice struct {
Elem *Type // element type
}
Slice contains Type fields specific to slice types.
type Struct ¶
type Struct struct { // Maps have three associated internal structs (see struct MapType). // Map links such structs back to their map type. Map *Type Funarg Funarg // type of function arguments for arg struct // contains filtered or unexported fields }
StructType contains Type fields specific to struct types.
type Sym ¶
type Sym struct { Linkname string // link name Pkg *Pkg Name string // object name // The unique ONAME, OTYPE, OPACK, or OLITERAL node that this symbol is // bound to within the current scope. (Most parts of the compiler should // prefer passing the Node directly, rather than relying on this field.) Def Object Block int32 // blocknumber to catch redeclaration Lastlineno src.XPos // last declaration for diagnostic // contains filtered or unexported fields }
Sym represents an object name in a segmented (pkg, name) namespace. Most commonly, this is a Go identifier naming an object declared within a package, but Syms are also used to name internal synthesized objects.
As an exception, field and method names that are exported use the Sym associated with localpkg instead of the package that declared them. This allows using Sym pointer equality to test for Go identifier uniqueness when handling selector expressions.
Ideally, Sym should be used for representing Go language constructs, while cmd/internal/obj.LSym is used for representing emitted artifacts.
NOTE: In practice, things can be messier than the description above for various reasons (historical, convenience).
var BlankSym *Sym
BlankSym is the blank (_) symbol.
func TypeSymLookup ¶ added in go1.17
func (*Sym) Format ¶
Format implements formatting for a Sym. The valid formats are:
%v Go syntax: Name for symbols in the local package, PkgName.Name for imported symbols. %+v Debug syntax: always include PkgName. prefix even for local names. %S Short syntax: Name only, no matter what.
func (*Sym) Less ¶ added in go1.11
Less reports whether symbol a is ordered before symbol b.
Symbols are ordered exported before non-exported, then by name, and finally (for non-exported symbols) by package height and path.
Ordering by package height is necessary to establish a consistent ordering for non-exported names with the same spelling but from different packages. We don't necessarily know the path for the package being compiled, but by definition it will have a height greater than any other packages seen within the compilation unit. For more background, see issue #24693.
func (*Sym) Linksym
deprecated
func (*Sym) LinksymABI
deprecated
added in
go1.17
func (*Sym) OnExportList ¶ added in go1.11
func (*Sym) PkgDef ¶ added in go1.11
PkgDef returns the definition associated with s at package scope.
func (*Sym) SetOnExportList ¶ added in go1.11
type Type ¶
type Type struct {
// contains filtered or unexported fields
}
A Type represents a Go type.
func ComplexForFloat ¶ added in go1.17
func FakeRecvType ¶
func FakeRecvType() *Type
FakeRecvType returns the singleton type used for interface method receivers.
func FloatForComplex ¶ added in go1.17
func NewChanArgs ¶
NewChanArgs returns a new TCHANARGS type for channel type c.
func NewFuncArgs ¶
NewFuncArgs returns a new TFUNCARGS type for func type f.
func NewInterface ¶ added in go1.17
NewInterface returns a new interface for the given methods and embedded types. Embedded types are specified as fields with no Sym.
func NewNamed ¶ added in go1.17
func NewNamed(obj TypeObject) *Type
NewNamed returns a new named type for the given type name. obj should be an ir.Name. The new type is incomplete (marked as TFORW kind), and the underlying type should be set later via SetUnderlying(). References to the type are maintained until the type is filled in, so those references can be updated when the type is complete.
func NewResults ¶ added in go1.16
func NewSignature ¶ added in go1.17
NewSignature returns a new function type for the given receiver, parameters, results, and type parameters, any of which may be nil.
func NewTypeParam ¶ added in go1.17
NewTypeParam returns a new type param with the specified sym (package and name) and specified index within the typeparam list.
func NewUnion ¶ added in go1.18
NewUnion returns a new union with the specified set of terms (types). If tildes[i] is true, then terms[i] represents ~T, rather than just T.
func ReceiverBaseType ¶ added in go1.17
ReceiverBaseType returns the underlying type, if any, that owns methods with receiver parameter t. The result is either a named type or an anonymous struct.
func SubstAny ¶
SubstAny walks t, replacing instances of "any" with successive elements removed from types. It returns the substituted type.
func (*Type) AllMethods ¶
AllMethods returns a pointer to all the methods (including embedding) for type t. For an interface type, this is the set of methods that are typically iterated over.
func (*Type) ArgWidth ¶
ArgWidth returns the total aligned argument size for a function. It includes the receiver, parameters, and results.
func (*Type) CanBeAnSSAAux ¶ added in go1.17
func (*Type) CanBeAnSSAAux()
func (*Type) ChanDir ¶
ChanDir returns the direction of a channel type t. The direction will be one of Crecv, Csend, or Cboth.
func (*Type) Compare ¶
Compare compares types for purposes of the SSA back end, returning a Cmp (one of CMPlt, CMPeq, CMPgt). The answers are correct for an optimizer or code generator, but not necessarily typechecking. The order chosen is arbitrary, only consistency and division into equivalence classes (Types that compare CMPeq) matters.
func (*Type) Deferwidth ¶
func (*Type) Elem ¶
Elem returns the type of elements of t. Usable with pointers, channels, arrays, slices, and maps.
func (*Type) FieldSlice ¶
FieldSlice returns a slice of containing all fields of a struct type t.
func (*Type) Format ¶
Format implements formatting for a Type. The valid formats are:
%v Go syntax %+v Debug syntax: Go syntax with a KIND- prefix for all but builtins. %L Go syntax for underlying type if t is named %S short Go syntax: drop leading "func" in function type %-S special case for method receiver symbol
func (*Type) ForwardType ¶
ForwardType returns t's extra forward-type-specific fields.
func (*Type) HasNil ¶ added in go1.14
HasNil reports whether the set of values determined by t includes nil.
func (*Type) HasPointers ¶ added in go1.15.3
HasPointers reports whether t contains a heap pointer. Note that this function ignores pointers to go:notinheap types.
func (*Type) Index ¶ added in go1.18
Index returns the index of the type param within its param list.
func (*Type) IsBaseGeneric ¶ added in go1.18
IsBaseGeneric returns true if t is a generic type (not reinstantiated with another type params or fully instantiated.
func (*Type) IsEmptyInterface ¶
IsEmptyInterface reports whether t is an empty interface type.
func (*Type) IsFullyInstantiated ¶ added in go1.18
IsFullyInstantiated reports whether t is a fully instantiated generic type; i.e. an instantiated generic type where all type arguments are non-generic or fully instantiated generic types.
func (*Type) IsFuncArgStruct ¶
IsFuncArgStruct reports whether t is a struct representing function parameters or results.
func (*Type) IsImplicit ¶ added in go1.18
IsImplicit reports whether an interface is implicit (i.e. elided from a type parameter constraint).
func (*Type) IsInstantiatedGeneric ¶ added in go1.18
IsInstantiatedGeneric returns t if t ia generic type that has been reinstantiated with new typeparams (i.e. is not fully instantiated).
func (*Type) IsInterface ¶
func (*Type) IsPtr ¶
IsPtr reports whether t is a regular Go pointer type. This does not include unsafe.Pointer.
func (*Type) IsPtrElem ¶ added in go1.12
IsPtrElem reports whether t is the element of a pointer (to t).
func (*Type) IsPtrShaped ¶
IsPtrShaped reports whether t is represented by a single machine pointer. In addition to regular Go pointer types, this includes map, channel, and function types and unsafe.Pointer. It does not include array or struct types that consist of a single pointer shaped type. TODO(mdempsky): Should it? See golang.org/issue/15028.
func (*Type) IsScalar ¶ added in go1.17
IsScalar reports whether 't' is a scalar Go type, e.g. bool/int/float/complex. Note that struct and array types consisting of a single scalar element are not considered scalar, likewise pointer types are also not considered scalar.
func (*Type) IsTypeParam ¶ added in go1.18
func (*Type) IsUnsafePtr ¶
IsUnsafePtr reports whether t is an unsafe pointer.
func (*Type) IsUnsigned ¶ added in go1.17
func (*Type) IsVariadic ¶ added in go1.11
IsVariadic reports whether function type t is variadic.
func (*Type) LinkString ¶ added in go1.18
LinkString returns an unexpanded string description of t, suitable for use in link symbols. "Unexpanded" here means that the description uses `"".` to qualify identifiers from the current package, and "expansion" refers to the renaming step performed by the linker to replace these qualifiers with proper `path/to/pkg.` qualifiers.
After expansion, the description corresponds to type identity. That is, for any pair of types t1 and t2, Identical(t1, t2) and expand(t1.LinkString()) == expand(t2.LinkString()) report the same value.
Within a single compilation unit, LinkString always returns the same unexpanded description for identical types. Thus it's safe to use as a map key to implement a type-identity-keyed map. However, make sure all LinkString calls used for this purpose happen within the same compile process; the string keys are not stable across multiple processes.
func (*Type) MarkImplicit ¶ added in go1.18
func (t *Type) MarkImplicit()
MarkImplicit marks the interface as implicit.
func (*Type) Methods ¶
Methods returns a pointer to the base methods (excluding embedding) for type t. These can either be concrete methods (for non-interface types) or interface methods (for interface types).
func (*Type) NameString ¶ added in go1.18
NameString generates a user-readable, mostly unique string description of t. NameString always returns the same description for identical types, even across compilation units.
NameString qualifies identifiers by package name, so it has collisions when different packages share the same names and identifiers. It also does not distinguish function-scope defined types from package-scoped defined types or from each other.
func (*Type) NumComponents ¶ added in go1.10
NumComponents returns the number of primitive elements that compose t. Struct and array types are flattened for the purpose of counting. All other types (including string, slice, and interface types) count as one element. If countBlank is IgnoreBlankFields, then blank struct fields (and their comprised elements) are excluded from the count. struct { x, y [3]int } has six components; [10]struct{ x, y string } has twenty.
func (*Type) NumResults ¶ added in go1.10
func (*Type) NumTParams ¶ added in go1.17
func (*Type) Obj ¶ added in go1.17
Obj returns the canonical type name node for a named type t, nil for an unnamed type.
func (*Type) OrigSym ¶ added in go1.18
OrigSym returns the name of the original generic type that t is an instantiation of, if any.
func (*Type) Pkg ¶ added in go1.11
Pkg returns the package that t appeared in.
Pkg is only defined for function, struct, and interface types (i.e., types with named elements). This information isn't used by cmd/compile itself, but we need to track it because it's exposed by the go/types API.
func (*Type) Pos ¶ added in go1.17
Pos returns a position associated with t, if any. This should only be used for diagnostics.
func (*Type) SetAllMethods ¶ added in go1.17
SetAllMethods sets the set of all methods (including embedding) for type t. Use this method instead of t.AllMethods().Set(), which might call CalcSize() on an uninitialized interface type.
func (*Type) SetDeferwidth ¶
func (*Type) SetHasShape ¶ added in go1.18
func (*Type) SetHasTParam ¶ added in go1.17
Generic types should never have alg functions.
func (*Type) SetIndex ¶ added in go1.18
SetIndex sets the index of the type param within its param list.
func (*Type) SetInterface ¶
SetInterface sets the base methods of an interface type t.
func (*Type) SetIsShape ¶ added in go1.18
Should always do SetHasShape(true) when doing SeIsShape(true).
func (*Type) SetNotInHeap ¶
func (*Type) SetOrigSym ¶ added in go1.18
func (*Type) SetRParams ¶ added in go1.17
func (*Type) SetUnderlying ¶ added in go1.17
SetUnderlying sets the underlying type. SetUnderlying automatically updates any types that were waiting for this type to be completed.
func (*Type) SetVargen ¶ added in go1.18
func (t *Type) SetVargen()
SetVargen assigns a unique generation number to type t, which must be a defined type declared within function scope. The generation number is used to distinguish it from other similarly spelled defined types from the same package.
TODO(mdempsky): Come up with a better solution.
func (*Type) SimpleString ¶
func (*Type) SoleComponent ¶ added in go1.13
SoleComponent returns the only primitive component in t, if there is exactly one. Otherwise, it returns nil. Components are counted as in NumComponents, including blank fields.
func (*Type) StructType ¶
StructType returns t's extra struct-specific fields.
func (*Type) Term ¶ added in go1.18
Term returns ith term of a union type as (term, tilde). If tilde is true, term represents ~T, rather than just T.
func (*Type) ToUnsigned ¶
ToUnsigned returns the unsigned equivalent of integer type t.
func (*Type) Underlying ¶ added in go1.17
Underlying returns the underlying type of type t.
type TypeObject ¶ added in go1.17
A TypeObject is an Object representing a named type.