// exactly one (named or anonymous) result associated
// with the first type in result signature (there may
// be more than one result)
- if n, imp := baseTypeName(res.Type); !imp && r.isVisible(n) {
+ factoryType := res.Type
+ if t, ok := factoryType.(*ast.ArrayType); ok && t.Len == nil {
+ // We consider functions that return slices of type T (or
+ // pointers to T) as factory functions of T.
+ factoryType = t.Elt
+ }
+ if n, imp := baseTypeName(factoryType); !imp && r.isVisible(n) {
if typ := r.lookupType(n); typ != nil {
// associate function with typ
typ.funcs.set(fun)
--- /dev/null
+//
+PACKAGE issue18063
+
+IMPORTPATH
+ testdata/issue18063
+
+FILENAMES
+ testdata/issue18063.go
+
+FUNCTIONS
+ // NewArray is not a factory function because arrays of type T are ...
+ func NewArray() [1]T
+
+ // NewPointerArray is not a factory function because arrays of ...
+ func NewPointerArray() [1]*T
+
+ // NewPointerSliceOfSlice is not a factory function because slices ...
+ func NewPointerSliceOfSlice() [][]*T
+
+ // NewSlice3 is not a factory function because 3 nested slices of ...
+ func NewSlice3() [][][]T
+
+ // NewSliceOfSlice is not a factory function because slices of a ...
+ func NewSliceOfSlice() [][]T
+
+
+TYPES
+ //
+ type T struct{}
+
+ //
+ func New() T
+
+ //
+ func NewPointer() *T
+
+ //
+ func NewPointerOfPointer() **T
+
+ //
+ func NewPointerSlice() []*T
+
+ //
+ func NewSlice() []T
+
--- /dev/null
+//
+PACKAGE issue18063
+
+IMPORTPATH
+ testdata/issue18063
+
+FILENAMES
+ testdata/issue18063.go
+
+FUNCTIONS
+ // NewArray is not a factory function because arrays of type T are ...
+ func NewArray() [1]T
+
+ // NewPointerArray is not a factory function because arrays of ...
+ func NewPointerArray() [1]*T
+
+ // NewPointerSliceOfSlice is not a factory function because slices ...
+ func NewPointerSliceOfSlice() [][]*T
+
+ // NewSlice3 is not a factory function because 3 nested slices of ...
+ func NewSlice3() [][][]T
+
+ // NewSliceOfSlice is not a factory function because slices of a ...
+ func NewSliceOfSlice() [][]T
+
+
+TYPES
+ //
+ type T struct{}
+
+ //
+ func New() T
+
+ //
+ func NewPointer() *T
+
+ //
+ func NewPointerOfPointer() **T
+
+ //
+ func NewPointerSlice() []*T
+
+ //
+ func NewSlice() []T
+
--- /dev/null
+//
+PACKAGE issue18063
+
+IMPORTPATH
+ testdata/issue18063
+
+FILENAMES
+ testdata/issue18063.go
+
+FUNCTIONS
+ // NewArray is not a factory function because arrays of type T are ...
+ func NewArray() [1]T
+
+ // NewPointerArray is not a factory function because arrays of ...
+ func NewPointerArray() [1]*T
+
+ // NewPointerSliceOfSlice is not a factory function because slices ...
+ func NewPointerSliceOfSlice() [][]*T
+
+ // NewSlice3 is not a factory function because 3 nested slices of ...
+ func NewSlice3() [][][]T
+
+ // NewSliceOfSlice is not a factory function because slices of a ...
+ func NewSliceOfSlice() [][]T
+
+
+TYPES
+ //
+ type T struct{}
+
+ //
+ func New() T
+
+ //
+ func NewPointer() *T
+
+ //
+ func NewPointerOfPointer() **T
+
+ //
+ func NewPointerSlice() []*T
+
+ //
+ func NewSlice() []T
+
--- /dev/null
+// Copyright 2017 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+package issue18063
+
+type T struct{}
+
+func New() T { return T{} }
+func NewPointer() *T { return &T{} }
+func NewPointerSlice() []*T { return []*T{&T{}} }
+func NewSlice() []T { return []T{T{}} }
+func NewPointerOfPointer() **T { x := &T{}; return &x }
+
+// NewArray is not a factory function because arrays of type T are not
+// factory functions of type T.
+func NewArray() [1]T { return [1]T{T{}} }
+
+// NewPointerArray is not a factory function because arrays of type *T are not
+// factory functions of type T.
+func NewPointerArray() [1]*T { return [1]*T{&T{}} }
+
+// NewSliceOfSlice is not a factory function because slices of a slice of
+// type *T are not factory functions of type T.
+func NewSliceOfSlice() [][]T { return []T{[]T{}} }
+
+// NewPointerSliceOfSlice is not a factory function because slices of a
+// slice of type *T are not factory functions of type T.
+func NewPointerSliceOfSlice() [][]*T { return []*T{[]*T{}} }
+
+// NewSlice3 is not a factory function because 3 nested slices of type T
+// are not factory functions of type T.
+func NewSlice3() [][][]T { return []T{[]T{[]T{}}} }