From 4b5ce620fa3f0f674be75a169414c07312218c73 Mon Sep 17 00:00:00 2001 From: Travis Jeffery Date: Thu, 12 Apr 2018 21:01:45 -0500 Subject: [PATCH] re-add named pkg support --- pkg/mocker/mocker.go | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/pkg/mocker/mocker.go b/pkg/mocker/mocker.go index 045f60e..01358cc 100644 --- a/pkg/mocker/mocker.go +++ b/pkg/mocker/mocker.go @@ -3,6 +3,7 @@ package mocker import ( "bytes" "fmt" + "go/ast" "go/format" "go/parser" "go/token" @@ -54,11 +55,36 @@ func (m *mocker) Mock() error { return errors.Wrap(err, "failed to parse template") } f := file{Pkg: *m.pkg, Imports: []iimport{{Path: "sync"}}} - pkgInfo, err := m.pkgInfo(*m.src) if err != nil { return errors.Wrap(err, "failed to get pkg info") } + for _, pkg := range pkgs { + i := 0 + files := make([]*ast.File, len(pkg.Files)) + for _, f := range pkg.Files { + files[i] = f + i++ + } + for _, f := range files { + for _, d := range f.Decls { + gd, ok := d.(*ast.GenDecl) + if !ok { + continue + } + for _, s := range gd.Specs { + is, ok := s.(*ast.ImportSpec) + if !ok { + continue + } + if is.Name != nil { + i := iimport{Name: is.Name.Name, Path: strings.Replace(is.Path.Value, `"`, "", -1)} + m.imports.named[i.Path] = i + } + } + } + } + } for _, n := range *m.iface { ifaceobj := pkgInfo.Pkg.Scope().Lookup(n) if ifaceobj == nil {