From ac2204200cbe149ee050e1cacefa178de84b0643 Mon Sep 17 00:00:00 2001 From: Xander Flood Date: Wed, 9 Oct 2024 14:48:53 -0600 Subject: [PATCH] issue #298 - go 1.23 go/types alias change --- generator/loader.go | 23 ++++++++++++++++------- go.mod | 2 +- 2 files changed, 17 insertions(+), 8 deletions(-) diff --git a/generator/loader.go b/generator/loader.go index 4a8695b..4ffb873 100644 --- a/generator/loader.go +++ b/generator/loader.go @@ -130,14 +130,10 @@ func (f *Fake) addImportsFor(typ types.Type) { f.addImportsFor(t.Elem()) case *types.Chan: f.addImportsFor(t.Elem()) + case *types.Alias: + f.addImportsForNamedType(t) case *types.Named: - if t.Obj() != nil && t.Obj().Pkg() != nil { - typeArgs := t.TypeArgs() - for i := 0; i < typeArgs.Len(); i++ { - f.addImportsFor(typeArgs.At(i)) - } - f.Imports.Add(t.Obj().Pkg().Name(), t.Obj().Pkg().Path()) - } + f.addImportsForNamedType(t) case *types.Slice: f.addImportsFor(t.Elem()) case *types.Array: @@ -154,3 +150,16 @@ func (f *Fake) addImportsFor(typ types.Type) { log.Printf("!!! WARNING: Missing case for type %s\n", reflect.TypeOf(typ).String()) } } + +func (f *Fake) addImportsForNamedType(t interface { + Obj() *types.TypeName + TypeArgs() *types.TypeList +}) { + if t.Obj() != nil && t.Obj().Pkg() != nil { + typeArgs := t.TypeArgs() + for i := 0; i < typeArgs.Len(); i++ { + f.addImportsFor(typeArgs.At(i)) + } + f.Imports.Add(t.Obj().Pkg().Name(), t.Obj().Pkg().Path()) + } +} diff --git a/go.mod b/go.mod index 7806358..15dcc4b 100644 --- a/go.mod +++ b/go.mod @@ -16,6 +16,6 @@ require ( gopkg.in/yaml.v3 v3.0.1 // indirect ) -go 1.22.0 +go 1.23 toolchain go1.23.1