Commit 0c71e293 authored by Matthew Dempsky's avatar Matthew Dempsky

cmd/compile: minor cleanup to import loading

Briefly document what the importfoo functions do.

Get rid of importsym's unused result parameter.

Get rid of the redundant calls to importsym(s, OTYPE)
after we've already called pkgtype(s).

Passes toolstash -cmp.

Change-Id: I4c057358144044f5356e4dec68907ec85f1fe806
Reviewed-on: https://go-review.googlesource.com/21498
Run-TryBot: Matthew Dempsky <mdempsky@google.com>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
Reviewed-by: default avatarRobert Griesemer <gri@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent 86e7a5b9
...@@ -290,7 +290,6 @@ func (p *importer) typ() *Type { ...@@ -290,7 +290,6 @@ func (p *importer) typ() *Type {
// parser.go:hidden_pkgtype // parser.go:hidden_pkgtype
t = pkgtype(tsym) t = pkgtype(tsym)
importsym(tsym, OTYPE)
p.typList = append(p.typList, t) p.typList = append(p.typList, t)
// read underlying type // read underlying type
......
...@@ -445,10 +445,8 @@ func dumpexport() { ...@@ -445,10 +445,8 @@ func dumpexport() {
} }
} }
// import // importsym declares symbol s as an imported object representable by op.
func importsym(s *Sym, op Op) {
// return the sym for ss, which should match lexical
func importsym(s *Sym, op Op) *Sym {
if s.Def != nil && s.Def.Op != op { if s.Def != nil && s.Def.Op != op {
pkgstr := fmt.Sprintf("during import %q", importpkg.Path) pkgstr := fmt.Sprintf("during import %q", importpkg.Path)
redeclare(s, pkgstr) redeclare(s, pkgstr)
...@@ -462,11 +460,10 @@ func importsym(s *Sym, op Op) *Sym { ...@@ -462,11 +460,10 @@ func importsym(s *Sym, op Op) *Sym {
s.Flags |= SymPackage // package scope s.Flags |= SymPackage // package scope
} }
} }
return s
} }
// return the type pkg.name, forward declaring if needed // pkgtype returns the named type declared by symbol s.
// If no such type has been declared yet, a forward declaration is returned.
func pkgtype(s *Sym) *Type { func pkgtype(s *Sym) *Type {
importsym(s, OTYPE) importsym(s, OTYPE)
if s.Def == nil || s.Def.Op != OTYPE { if s.Def == nil || s.Def.Op != OTYPE {
...@@ -506,6 +503,7 @@ func importimport(s *Sym, path string) { ...@@ -506,6 +503,7 @@ func importimport(s *Sym, path string) {
} }
} }
// importconst declares symbol s as an imported constant with type t and value n.
func importconst(s *Sym, t *Type, n *Node) { func importconst(s *Sym, t *Type, n *Node) {
importsym(s, OLITERAL) importsym(s, OLITERAL)
n = convlit(n, t) n = convlit(n, t)
...@@ -533,6 +531,7 @@ func importconst(s *Sym, t *Type, n *Node) { ...@@ -533,6 +531,7 @@ func importconst(s *Sym, t *Type, n *Node) {
} }
} }
// importvar declares symbol s as an imported variable with type t.
func importvar(s *Sym, t *Type) { func importvar(s *Sym, t *Type) {
importsym(s, ONAME) importsym(s, ONAME)
if s.Def != nil && s.Def.Op == ONAME { if s.Def != nil && s.Def.Op == ONAME {
......
...@@ -2931,12 +2931,7 @@ func (p *parser) hidden_pkgtype() *Type { ...@@ -2931,12 +2931,7 @@ func (p *parser) hidden_pkgtype() *Type {
defer p.trace("hidden_pkgtype")() defer p.trace("hidden_pkgtype")()
} }
s1 := p.hidden_pkg_importsym() return pkgtype(p.hidden_pkg_importsym())
ss := pkgtype(s1)
importsym(s1, OTYPE)
return ss
} }
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment