From e12b0afa5454c7683cb27bef0b6979f964dd0e96 Mon Sep 17 00:00:00 2001 From: Keith Randall Date: Tue, 20 Apr 2021 15:36:11 -0700 Subject: cmd/compile: separate out parameter and field export encoding These two types of *types.Field encode different concepts, so we encode them separately (and ignore fields that don't matter for each concept). Change-Id: I9d1608413949a109f12a3ebd52cd7af5f476e415 Reviewed-on: https://go-review.googlesource.com/c/go/+/312130 Trust: Keith Randall Run-TryBot: Keith Randall Reviewed-by: Matthew Dempsky TryBot-Result: Go Bot --- src/cmd/compile/internal/typecheck/iexport.go | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'src/cmd/compile/internal/typecheck/iexport.go') diff --git a/src/cmd/compile/internal/typecheck/iexport.go b/src/cmd/compile/internal/typecheck/iexport.go index b59a610cf7..6a56abb1b9 100644 --- a/src/cmd/compile/internal/typecheck/iexport.go +++ b/src/cmd/compile/internal/typecheck/iexport.go @@ -749,8 +749,16 @@ func (w *exportWriter) exoticParam(f *types.Field) { w.uint64(uint64(f.Offset)) w.exoticType(f.Type) w.bool(f.IsDDD()) +} + +func (w *exportWriter) exoticField(f *types.Field) { + w.pos(f.Pos) + w.exoticSym(f.Sym) + w.uint64(uint64(f.Offset)) + w.exoticType(f.Type) w.string(f.Note) } + func (w *exportWriter) exoticSym(s *types.Sym) { if s == nil { w.string("") @@ -1593,7 +1601,7 @@ func (w *exportWriter) expr(n ir.Node) { if go117ExportTypes { w.exoticType(n.Type()) if n.Op() == ir.ODOT || n.Op() == ir.ODOTPTR || n.Op() == ir.ODOTINTER { - w.exoticParam(n.Selection) + w.exoticField(n.Selection) } // n.Selection is not required for OMETHEXPR, ODOTMETH, and OCALLPART. It will // be reconstructed during import. -- cgit v1.2.3-54-g00ecf