ToAST is a thin wrapper for the Go standard library ast package that provides a simple interface for working with Go types.
This package only supports parsing of type definitions. It was originally intended to be used for generating type definitions for other languages -- particularly CUE, a typesafe superset of JSON.
Each go/ast type specification maps to one of four structs:
PlainType
: Basic types, type aliases, and pointersArrayType
: Array and slice typesMapType
: MapsStructType
: Structs, which may contain fields that are themselves one of the four types.
There is also partial support for an EnumType
, which is expressed by convention in Go as a type
declaration with a group of constants of the same type.
When parsing a file, ToAST can apply a number of transformations on matching objects:
ExcludeImport
excludes specific importsModifyImport
mutates specific importsExcludeTypeDecl
excludes specific type declarationsExcludeType
excludes specific type declarations and referencesModifyType
mutates specific typesExcludeField
excludes specific fields in aStructType
ModifyField
mutates specific fields in aStructType
CopyIntoStruct
copies fields from one or more namedStructType
s into a targetStructType
, replacing the field at of a given namePromoteToEnumType
converts aPlainType
into anEnumType
GenFieldTransform
takes aStructType
and aField
and returns someTransform
that can be matched on subsequent nodes in the fileGenEnumTypeTransform
takes a string andgo/ast.ValueSpec
and returns aPromoteToEnumType
transform that can be matched on aPlainType
in the file
First, load an *ast.File
. For example:
import "go/parser"
filePath := "path/to/file.go"
astFile, err := parser.ParseFile(token.NewFileSet(), filePath, nil, parser.ParseComments)
if err != nil {
panic(err)
}
Then create a *toast.File
:
file := toast.NewFile(astFile,
WithTransform(&toast.ExcludeImport{
Match: func(i Import) bool {
return i.Name == "foo"
}
}),
WithTransform(&toast.ExcludeType{
Match: func(t Type) bool {
return t.Name == "bar"
}
}),
...
)