Skip to content

Commit 9573d0d

Browse files
authored
use reflectutils.TypeName() for versioned type names (#58)
* use reflectutils.TypeName() for versioned type names * fix race
1 parent bfb9833 commit 9573d0d

File tree

7 files changed

+7
-55
lines changed

7 files changed

+7
-55
lines changed

error.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -49,7 +49,7 @@ func duplicateTypes() string {
4949
return duplicates
5050
}
5151
names := make(map[string]struct{})
52-
for i := 1; i <= typeCounter; i++ {
52+
for i := 1; i <= max; i++ {
5353
n := typeCode(i).String()
5454
if _, ok := names[n]; ok {
5555
if _, ok := duplicatesFound[n]; !ok {

go.mod

+1-1
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,7 @@ go 1.16
44

55
require (
66
github.com/kr/pretty v0.2.0 // indirect
7-
github.com/muir/reflectutils v0.6.0
7+
github.com/muir/reflectutils v0.7.0
88
github.com/stretchr/testify v1.8.1
99
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 // indirect
1010
)

go.sum

+2-2
Original file line numberDiff line numberDiff line change
@@ -6,8 +6,8 @@ github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfn
66
github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
77
github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE=
88
github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
9-
github.com/muir/reflectutils v0.6.0 h1:jXfbW60Nx+STn78vwUWVCUwInXkqAC5kWS5oeY/xPgM=
10-
github.com/muir/reflectutils v0.6.0/go.mod h1:l8W7iTj6zMdmsWcPfsdnaAYLEuipJ7baVROqpfuonIc=
9+
github.com/muir/reflectutils v0.7.0 h1:7ez7OLYTThDQ5kpEpxtOgFvJgtE4E11D6PVTVw+Lwl0=
10+
github.com/muir/reflectutils v0.7.0/go.mod h1:l8W7iTj6zMdmsWcPfsdnaAYLEuipJ7baVROqpfuonIc=
1111
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
1212
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
1313
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=

internal/foo/foo.go

-3
This file was deleted.

internal/foo/v2/foo.go

-3
This file was deleted.

type_codes.go

+3-17
Original file line numberDiff line numberDiff line change
@@ -3,11 +3,10 @@ package nject
33
// TODO: switch from typeCode to reflect.Type -- duplicate detection would be lost
44

55
import (
6-
"path"
76
"reflect"
8-
"regexp"
9-
"strings"
107
"sync"
8+
9+
"github.com/muir/reflectutils"
1110
)
1211

1312
type typeCode int
@@ -76,22 +75,9 @@ func (tc typeCode) Type() reflect.Type {
7675
return reverseMap[tc]
7776
}
7877

79-
var versionRE = regexp.MustCompile(`/v(\d+)$`)
80-
8178
// Type returns the reflect.Type for this typeCode
8279
func (tc typeCode) String() string {
83-
ts := tc.Type().String()
84-
if versionRE.MatchString(tc.Type().PkgPath()) {
85-
pp := tc.Type().PkgPath()
86-
version := path.Base(pp)
87-
pn := path.Base(path.Dir(pp))
88-
revised := strings.Replace(ts, pn, pn+"/"+version, 1)
89-
if revised != ts {
90-
return revised
91-
}
92-
return "(" + version + ")" + ts
93-
}
94-
return ts
80+
return reflectutils.TypeName(tc.Type())
9581
}
9682

9783
func (tcs typeCodes) Types() []reflect.Type {

type_codes_test.go

-28
This file was deleted.

0 commit comments

Comments
 (0)