Package loader
Overview ▹
Index ▹
Constants ¶
FromArgsUsage is a partial usage message that applications calling FromArgs may wish to include in their -help output.
const FromArgsUsage = ` <args> is a list of arguments denoting a set of initial packages. It may take one of two forms: 1. A list of *.go source files. All of the specified files are loaded, parsed and type-checked as a single package. All the files must belong to the same directory. 2. A list of import paths, each denoting a package. The package's directory is found relative to the $GOROOT and $GOPATH using similar logic to 'go build', and the *.go files in that directory are loaded, parsed and type-checked as a single package. In addition, all *_test.go files in the directory are then loaded and parsed. Those files whose package declaration equals that of the non-*_test.go files are included in the primary package. Test files whose package declaration ends with "_test" are type-checked as another package, the 'external' test package, so that a single import path may denote two packages. (Whether this behaviour is enabled is tool-specific, and may depend on additional flags.) A '--' argument terminates the list of packages. `
type Config ¶
Config specifies the configuration for loading a whole program from Go source code. The zero value for Config is a ready-to-use default configuration.
type Config struct { // Fset is the file set for the parser to use when loading the // program. If nil, it may be lazily initialized by any // method of Config. Fset *token.FileSet // ParserMode specifies the mode to be used by the parser when // loading source packages. ParserMode parser.Mode // TypeChecker contains options relating to the type checker. // // The supplied IgnoreFuncBodies is not used; the effective // value comes from the TypeCheckFuncBodies func below. // The supplied Import function is not used either. TypeChecker types.Config // TypeCheckFuncBodies is a predicate over package paths. // A package for which the predicate is false will // have its package-level declarations type checked, but not // its function bodies; this can be used to quickly load // dependencies from source. If nil, all func bodies are type // checked. TypeCheckFuncBodies func(path string) bool // If Build is non-nil, it is used to locate source packages. // Otherwise &build.Default is used. // // By default, cgo is invoked to preprocess Go files that // import the fake package "C". This behaviour can be // disabled by setting CGO_ENABLED=0 in the environment prior // to startup, or by setting Build.CgoEnabled=false. Build *build.Context // The current directory, used for resolving relative package // references such as "./go/loader". If empty, os.Getwd will be // used instead. Cwd string // If DisplayPath is non-nil, it is used to transform each // file name obtained from Build.Import(). This can be used // to prevent a virtualized build.Config's file names from // leaking into the user interface. DisplayPath func(path string) string // If AllowErrors is true, Load will return a Program even // if some of the its packages contained I/O, parser or type // errors; such errors are accessible via PackageInfo.Errors. If // false, Load will fail if any package had an error. AllowErrors bool // CreatePkgs specifies a list of non-importable initial // packages to create. The resulting packages will appear in // the corresponding elements of the Program.Created slice. CreatePkgs []PkgSpec // ImportPkgs specifies a set of initial packages to load. // The map keys are package paths. // // The map value indicates whether to load tests. If true, Load // will add and type-check two lists of files to the package: // non-test files followed by in-package *_test.go files. In // addition, it will append the external test package (if any) // to Program.Created. ImportPkgs map[string]bool // FindPackage is called during Load to create the build.Package // for a given import path from a given directory. // If FindPackage is nil, (*build.Context).Import is used. // A client may use this hook to adapt to a proprietary build // system that does not follow the "go build" layout // conventions, for example. // // It must be safe to call concurrently from multiple goroutines. FindPackage func(ctxt *build.Context, fromDir, importPath string, mode build.ImportMode) (*build.Package, error) // AfterTypeCheck is called immediately after a list of files // has been type-checked and appended to info.Files. // // This optional hook function is the earliest opportunity for // the client to observe the output of the type checker, // which may be useful to reduce analysis latency when loading // a large program. // // The function is permitted to modify info.Info, for instance // to clear data structures that are no longer needed, which can // dramatically reduce peak memory consumption. // // The function may be called twice for the same PackageInfo: // once for the files of the package and again for the // in-package test files. // // It must be safe to call concurrently from multiple goroutines. AfterTypeCheck func(info *PackageInfo, files []*ast.File) }
func (*Config) CreateFromFilenames ¶
func (conf *Config) CreateFromFilenames(path string, filenames ...string)
CreateFromFilenames is a convenience function that adds a conf.CreatePkgs entry to create a package of the specified *.go files.
▹ Example
func (*Config) CreateFromFiles ¶
func (conf *Config) CreateFromFiles(path string, files ...*ast.File)
CreateFromFiles is a convenience function that adds a conf.CreatePkgs entry to create package of the specified path and parsed files.
▹ Example
func (*Config) FromArgs ¶
func (conf *Config) FromArgs(args []string, xtest bool) ([]string, error)
FromArgs interprets args as a set of initial packages to load from source and updates the configuration. It returns the list of unconsumed arguments.
It is intended for use in command-line interfaces that require a set of initial packages to be specified; see FromArgsUsage message for details.
Only superficial errors are reported at this stage; errors dependent on I/O are detected during Load.
▹ Example
func (*Config) Import ¶
func (conf *Config) Import(path string)
Import is a convenience function that adds path to ImportPkgs, the set of initial packages that will be imported from source.
▹ Example
func (*Config) ImportWithTests ¶
func (conf *Config) ImportWithTests(path string)
ImportWithTests is a convenience function that adds path to ImportPkgs, the set of initial source packages located relative to $GOPATH. The package will be augmented by any *_test.go files in its directory that contain a "package x" (not "package x_test") declaration.
In addition, if any *_test.go files contain a "package x_test" declaration, an additional package comprising just those files will be added to CreatePkgs.
func (*Config) Load ¶
func (conf *Config) Load() (*Program, error)
Load creates the initial packages specified by conf.{Create,Import}Pkgs, loading their dependencies packages as needed.
On success, Load returns a Program containing a PackageInfo for each package. On failure, it returns an error.
If AllowErrors is true, Load will return a Program even if some packages contained I/O, parser or type errors, or if dependencies were missing. (Such errors are accessible via PackageInfo.Errors. If false, Load will fail if any package had an error.
It is an error if no packages were loaded.
func (*Config) ParseFile ¶
func (conf *Config) ParseFile(filename string, src interface{}) (*ast.File, error)
ParseFile is a convenience function (intended for testing) that invokes the parser using the Config's FileSet, which is initialized if nil.
src specifies the parser input as a string, []byte, or io.Reader, and filename is its apparent name. If src is nil, the contents of filename are read from the file system.
type PackageInfo ¶
PackageInfo holds the ASTs and facts derived by the type-checker for a single package.
Not mutated once exposed via the API.
type PackageInfo struct { Pkg *types.Package Importable bool // true if 'import "Pkg.Path()"' would resolve to this TransitivelyErrorFree bool // true if Pkg and all its dependencies are free of errors Files []*ast.File // syntax trees for the package's files Errors []error // non-nil if the package had errors types.Info // type-checker deductions. // contains filtered or unexported fields }
func (*PackageInfo) String ¶
func (info *PackageInfo) String() string
type PkgSpec ¶
A PkgSpec specifies a non-importable package to be created by Load. Files are processed first, but typically only one of Files and Filenames is provided. The path needn't be globally unique.
For vendoring purposes, the package's directory is the one that contains the first file.
type PkgSpec struct { Path string // package path ("" => use package declaration) Files []*ast.File // ASTs of already-parsed files Filenames []string // names of files to be parsed }
type Program ¶
A Program is a Go program loaded from source as specified by a Config.
type Program struct { Fset *token.FileSet // the file set for this program // Created[i] contains the initial package whose ASTs or // filenames were supplied by Config.CreatePkgs[i], followed by // the external test package, if any, of each package in // Config.ImportPkgs ordered by ImportPath. // // NOTE: these files must not import "C". Cgo preprocessing is // only performed on imported packages, not ad hoc packages. // // TODO(adonovan): we need to copy and adapt the logic of // goFilesPackage (from $GOROOT/src/cmd/go/build.go) and make // Config.Import and Config.Create methods return the same kind // of entity, essentially a build.Package. // Perhaps we can even reuse that type directly. Created []*PackageInfo // Imported contains the initially imported packages, // as specified by Config.ImportPkgs. Imported map[string]*PackageInfo // AllPackages contains the PackageInfo of every package // encountered by Load: all initial packages and all // dependencies, including incomplete ones. AllPackages map[*types.Package]*PackageInfo // contains filtered or unexported fields }
func (*Program) InitialPackages ¶
func (prog *Program) InitialPackages() []*PackageInfo
InitialPackages returns a new slice containing the set of initial packages (Created + Imported) in unspecified order.
func (*Program) Package ¶
func (prog *Program) Package(path string) *PackageInfo
Package returns the ASTs and results of type checking for the specified package.
func (*Program) PathEnclosingInterval ¶
func (prog *Program) PathEnclosingInterval(start, end token.Pos) (pkg *PackageInfo, path []ast.Node, exact bool)
PathEnclosingInterval returns the PackageInfo and ast.Node that contain source interval [start, end), and all the node's ancestors up to the AST root. It searches all ast.Files of all packages in prog. exact is defined as for astutil.PathEnclosingInterval.
The zero value is returned if not found.