github.com/bir3/gocompiler@v0.9.2202/src/go/importer/importer.go (about) 1 // Copyright 2015 The Go Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style 3 // license that can be found in the LICENSE file. 4 5 // Package importer provides access to export data importers. 6 package importer 7 8 import ( 9 "github.com/bir3/gocompiler/src/go/build" 10 "github.com/bir3/gocompiler/src/go/internal/gccgoimporter" 11 "github.com/bir3/gocompiler/src/go/internal/gcimporter" 12 "github.com/bir3/gocompiler/src/go/internal/srcimporter" 13 "github.com/bir3/gocompiler/src/go/token" 14 "github.com/bir3/gocompiler/src/go/types" 15 "io" 16 "runtime" 17 ) 18 19 // A Lookup function returns a reader to access package data for 20 // a given import path, or an error if no matching package is found. 21 type Lookup func(path string) (io.ReadCloser, error) 22 23 // ForCompiler returns an Importer for importing from installed packages 24 // for the compilers "gc" and "gccgo", or for importing directly 25 // from the source if the compiler argument is "source". In this 26 // latter case, importing may fail under circumstances where the 27 // exported API is not entirely defined in pure Go source code 28 // (if the package API depends on cgo-defined entities, the type 29 // checker won't have access to those). 30 // 31 // The lookup function is called each time the resulting importer needs 32 // to resolve an import path. In this mode the importer can only be 33 // invoked with canonical import paths (not relative or absolute ones); 34 // it is assumed that the translation to canonical import paths is being 35 // done by the client of the importer. 36 // 37 // A lookup function must be provided for correct module-aware operation. 38 // Deprecated: If lookup is nil, for backwards-compatibility, the importer 39 // will attempt to resolve imports in the $GOPATH workspace. 40 func ForCompiler(fset *token.FileSet, compiler string, lookup Lookup) types.Importer { 41 switch compiler { 42 case "gc": 43 return &gcimports{ 44 fset: fset, 45 packages: make(map[string]*types.Package), 46 lookup: lookup, 47 } 48 49 case "gccgo": 50 var inst gccgoimporter.GccgoInstallation 51 if err := inst.InitFromDriver("gccgo"); err != nil { 52 return nil 53 } 54 return &gccgoimports{ 55 packages: make(map[string]*types.Package), 56 importer: inst.GetImporter(nil, nil), 57 lookup: lookup, 58 } 59 60 case "source": 61 if lookup != nil { 62 panic("source importer for custom import path lookup not supported (issue #13847).") 63 } 64 65 return srcimporter.New(&build.Default, fset, make(map[string]*types.Package)) 66 } 67 68 // compiler not supported 69 return nil 70 } 71 72 // For calls [ForCompiler] with a new FileSet. 73 // 74 // Deprecated: Use [ForCompiler], which populates a FileSet 75 // with the positions of objects created by the importer. 76 func For(compiler string, lookup Lookup) types.Importer { 77 return ForCompiler(token.NewFileSet(), compiler, lookup) 78 } 79 80 // Default returns an Importer for the compiler that built the running binary. 81 // If available, the result implements [types.ImporterFrom]. 82 func Default() types.Importer { 83 return For(runtime.Compiler, nil) 84 } 85 86 // gc importer 87 88 type gcimports struct { 89 fset *token.FileSet 90 packages map[string]*types.Package 91 lookup Lookup 92 } 93 94 func (m *gcimports) Import(path string) (*types.Package, error) { 95 return m.ImportFrom(path, "" /* no vendoring */, 0) 96 } 97 98 func (m *gcimports) ImportFrom(path, srcDir string, mode types.ImportMode) (*types.Package, error) { 99 if mode != 0 { 100 panic("mode must be 0") 101 } 102 return gcimporter.Import(m.fset, m.packages, path, srcDir, m.lookup) 103 } 104 105 // gccgo importer 106 107 type gccgoimports struct { 108 packages map[string]*types.Package 109 importer gccgoimporter.Importer 110 lookup Lookup 111 } 112 113 func (m *gccgoimports) Import(path string) (*types.Package, error) { 114 return m.ImportFrom(path, "" /* no vendoring */, 0) 115 } 116 117 func (m *gccgoimports) ImportFrom(path, srcDir string, mode types.ImportMode) (*types.Package, error) { 118 if mode != 0 { 119 panic("mode must be 0") 120 } 121 return m.importer(m.packages, path, srcDir, m.lookup) 122 }