aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/compile/internal/noder/import.go
diff options
context:
space:
mode:
authorMatthew Dempsky <mdempsky@google.com>2021-05-27 02:48:33 -0700
committerMatthew Dempsky <mdempsky@google.com>2021-05-27 23:54:29 +0000
commit22f5ece3b13b7e5f6dece399c96d1d665b3a05bc (patch)
tree0917173ad8bfb39b97334c06bdb5d8f595e23983 /src/cmd/compile/internal/noder/import.go
parent417955d151359629ca11be968e3056e6636b828e (diff)
downloadgo-22f5ece3b13b7e5f6dece399c96d1d665b3a05bc.tar.gz
go-22f5ece3b13b7e5f6dece399c96d1d665b3a05bc.zip
[dev.typeparams] cmd/compile/internal/noder: refactor irgen import handling
Rather than re-parsing and re-resolving the import path string, use the PkgName object provided by types2 to determine what package path it refers to. Also, decompose importfile into smaller functions, so that we can directly pass the already-resolved package path to the importer. Finally, switch to simply using height as calculated by types2 rather than redoing the calculations. Change-Id: I3338f4e68387b2835b2e58d6df65d740d6a648cb Reviewed-on: https://go-review.googlesource.com/c/go/+/323309 Run-TryBot: Matthew Dempsky <mdempsky@google.com> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Dan Scales <danscales@google.com> Trust: Dan Scales <danscales@google.com> Trust: Matthew Dempsky <mdempsky@google.com>
Diffstat (limited to 'src/cmd/compile/internal/noder/import.go')
-rw-r--r--src/cmd/compile/internal/noder/import.go40
1 files changed, 22 insertions, 18 deletions
diff --git a/src/cmd/compile/internal/noder/import.go b/src/cmd/compile/internal/noder/import.go
index c4a57806eb..24d911ba38 100644
--- a/src/cmd/compile/internal/noder/import.go
+++ b/src/cmd/compile/internal/noder/import.go
@@ -175,36 +175,44 @@ func resolveImportPath(path string) (string, error) {
return path, nil
}
-// TODO(mdempsky): Return an error instead.
func importfile(decl *syntax.ImportDecl) *types.Pkg {
- if decl.Path.Kind != syntax.StringLit {
- base.Errorf("import path must be a string")
+ path, err := parseImportPath(decl.Path)
+ if err != nil {
+ base.Errorf("%s", err)
return nil
}
- path, err := strconv.Unquote(decl.Path.Value)
- if err != nil {
- base.Errorf("import path must be a string")
- return nil
+ pkg := readImportFile(typecheck.Target, path)
+ if pkg != ir.Pkgs.Unsafe && pkg.Height >= myheight {
+ myheight = pkg.Height + 1
}
+ return pkg
+}
- if err := checkImportPath(path, false); err != nil {
- base.Errorf("%s", err.Error())
- return nil
+func parseImportPath(pathLit *syntax.BasicLit) (string, error) {
+ if pathLit.Kind != syntax.StringLit {
+ return "", errors.New("import path must be a string")
}
- path, err = resolveImportPath(path)
+ path, err := strconv.Unquote(pathLit.Value)
if err != nil {
- base.Errorf("%s", err)
- return nil
+ return "", errors.New("import path must be a string")
+ }
+
+ if err := checkImportPath(path, false); err != nil {
+ return "", err
}
+ return resolveImportPath(path)
+}
+
+func readImportFile(target *ir.Package, path string) *types.Pkg {
importpkg := types.NewPkg(path, "")
if importpkg.Direct {
return importpkg // already fully loaded
}
importpkg.Direct = true
- typecheck.Target.Imports = append(typecheck.Target.Imports, importpkg)
+ target.Imports = append(target.Imports, importpkg)
if path == "unsafe" {
return importpkg // initialized with universe
@@ -324,10 +332,6 @@ func importfile(decl *syntax.ImportDecl) *types.Pkg {
base.Ctxt.AddImport(file[len(file)-len(path)-len(".a"):], fingerprint)
}
- if importpkg.Height >= myheight {
- myheight = importpkg.Height + 1
- }
-
return importpkg
}