exhaustive: upgrade to v0.3.6; add new flags and deprecate old ones (#2344)
This commit is contained in:
		
							parent
							
								
									65c47cbfd6
								
							
						
					
					
						commit
						054fc3ff50
					
				| @ -136,10 +136,16 @@ linters-settings: | ||||
|   exhaustive: | ||||
|     # check switch statements in generated files also | ||||
|     check-generated: false | ||||
|     # indicates that switch statements are to be considered exhaustive if a | ||||
|     # 'default' case is present, even if all enum members aren't listed in the | ||||
|     # switch | ||||
|     # presence of "default" case in switch statements satisfies exhaustiveness, | ||||
|     # even if all enum members are not listed | ||||
|     default-signifies-exhaustive: false | ||||
|     # enum members matching the supplied regex do not have to be listed in | ||||
|     # switch statements to satisfy exhaustiveness | ||||
|     ignore-enum-members: "" | ||||
|     # strategy to use when checking exhaustiveness of switch statements; one of: | ||||
|     # "name", "value"; see documentation for details: | ||||
|     # https://pkg.go.dev/github.com/nishanths/exhaustive#section-documentation | ||||
|     checking-strategy: "value" | ||||
| 
 | ||||
|   exhaustivestruct: | ||||
|     # Struct Patterns is list of expressions to match struct packages and names | ||||
|  | ||||
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -59,7 +59,7 @@ require ( | ||||
| 	github.com/mitchellh/go-ps v1.0.0 | ||||
| 	github.com/moricho/tparallel v0.2.1 | ||||
| 	github.com/nakabonne/nestif v0.3.1 | ||||
| 	github.com/nishanths/exhaustive v0.2.3 | ||||
| 	github.com/nishanths/exhaustive v0.3.6 | ||||
| 	github.com/nishanths/predeclared v0.2.1 | ||||
| 	github.com/pkg/errors v0.9.1 | ||||
| 	github.com/polyfloyd/go-errorlint v0.0.0-20210722154253-910bb7978349 | ||||
|  | ||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
										generated
									
									
									
								
							| @ -550,8 +550,8 @@ github.com/nbutton23/zxcvbn-go v0.0.0-20210217022336-fa2cb2858354 h1:4kuARK6Y6Fx | ||||
| github.com/nbutton23/zxcvbn-go v0.0.0-20210217022336-fa2cb2858354/go.mod h1:KSVJerMDfblTH7p5MZaTt+8zaT2iEk3AkVb9PQdZuE8= | ||||
| github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e h1:fD57ERR4JtEqsWbfPhv4DMiApHyliiK5xCTNVSPiaAs= | ||||
| github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= | ||||
| github.com/nishanths/exhaustive v0.2.3 h1:+ANTMqRNrqwInnP9aszg/0jDo+zbXa4x66U19Bx/oTk= | ||||
| github.com/nishanths/exhaustive v0.2.3/go.mod h1:bhIX678Nx8inLM9PbpvK1yv6oGtoP8BfaIeMzgBNKvc= | ||||
| github.com/nishanths/exhaustive v0.3.6 h1:uRVZUfvWqSsPv+w4Qv30WgWdJwGOqR1P7QCwyhiKbOs= | ||||
| github.com/nishanths/exhaustive v0.3.6/go.mod h1:gX+MP7DWMKJmNa1HfMozK+u04hQd3na9i0hyqf3/dOI= | ||||
| github.com/nishanths/predeclared v0.0.0-20190419143655-18a43bb90ffc/go.mod h1:62PewwiQTlm/7Rj+cxVYqZvDIUc+JjZq6GHAC1fsObQ= | ||||
| github.com/nishanths/predeclared v0.2.1 h1:1TXtjmy4f3YCFjTxRd8zcFHOmoUir+gp0ESzjFzG2sw= | ||||
| github.com/nishanths/predeclared v0.2.1/go.mod h1:HvkGJcA3naj4lOwnFXFDkFxVtSqQMB9sbB1usJ+xjQE= | ||||
|  | ||||
| @ -57,6 +57,8 @@ var defaultLintersSettings = LintersSettings{ | ||||
| 	Exhaustive: ExhaustiveSettings{ | ||||
| 		CheckGenerated:             false, | ||||
| 		DefaultSignifiesExhaustive: false, | ||||
| 		IgnoreEnumMembers:          "", | ||||
| 		CheckingStrategy:           "value", | ||||
| 	}, | ||||
| 	Gofumpt: GofumptSettings{ | ||||
| 		LangVersion: "", | ||||
| @ -184,7 +186,9 @@ type ErrorLintSettings struct { | ||||
| type ExhaustiveSettings struct { | ||||
| 	CheckGenerated             bool   `mapstructure:"check-generated"` | ||||
| 	DefaultSignifiesExhaustive bool   `mapstructure:"default-signifies-exhaustive"` | ||||
| 	IgnorePattern              string `mapstructure:"ignore-pattern"` | ||||
| 	IgnorePattern              string `mapstructure:"ignore-pattern"` // Deprecated: this setting has no effect; see IgnoreEnumMembers instead. | ||||
| 	IgnoreEnumMembers          string `mapstructure:"ignore-enum-members"` | ||||
| 	CheckingStrategy           string `mapstructure:"checking-strategy"` | ||||
| } | ||||
| 
 | ||||
| type ExhaustiveStructSettings struct { | ||||
|  | ||||
| @ -18,6 +18,8 @@ func NewExhaustive(settings *config.ExhaustiveSettings) *goanalysis.Linter { | ||||
| 				exhaustive.CheckGeneratedFlag:             settings.CheckGenerated, | ||||
| 				exhaustive.DefaultSignifiesExhaustiveFlag: settings.DefaultSignifiesExhaustive, | ||||
| 				exhaustive.IgnorePatternFlag:              settings.IgnorePattern, | ||||
| 				exhaustive.IgnoreEnumMembersFlag:          settings.IgnoreEnumMembers, | ||||
| 				exhaustive.CheckingStrategyFlag:           settings.CheckingStrategy, | ||||
| 			}, | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
							
								
								
									
										3
									
								
								test/testdata/configs/exhaustive_checking_strategy_name.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								test/testdata/configs/exhaustive_checking_strategy_name.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| linters-settings: | ||||
|   exhaustive: | ||||
|     checking-strategy: "name" | ||||
							
								
								
									
										3
									
								
								test/testdata/configs/exhaustive_checking_strategy_value.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								test/testdata/configs/exhaustive_checking_strategy_value.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| linters-settings: | ||||
|   exhaustive: | ||||
|     checking-strategy: "value" | ||||
							
								
								
									
										3
									
								
								test/testdata/configs/exhaustive_ignore_enum_members.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								test/testdata/configs/exhaustive_ignore_enum_members.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| linters-settings: | ||||
|   exhaustive: | ||||
|     ignore-enum-members: "West$" | ||||
							
								
								
									
										18
									
								
								test/testdata/exhaustive_checking_strategy_name.go
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								test/testdata/exhaustive_checking_strategy_name.go
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | ||||
| //args: -Eexhaustive | ||||
| //config_path: testdata/configs/exhaustive_checking_strategy_name.yml | ||||
| package testdata | ||||
| 
 | ||||
| type AccessControl string | ||||
| 
 | ||||
| const ( | ||||
| 	AccessPublic  AccessControl = "public" | ||||
| 	AccessPrivate AccessControl = "private" | ||||
| 	AccessDefault AccessControl = AccessPublic | ||||
| ) | ||||
| 
 | ||||
| func example(v AccessControl) { | ||||
| 	switch v { // ERROR "missing cases in switch of type AccessControl: AccessDefault" | ||||
| 	case AccessPublic: | ||||
| 	case AccessPrivate: | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										22
									
								
								test/testdata/exhaustive_checking_strategy_value.go
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								test/testdata/exhaustive_checking_strategy_value.go
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| //args: -Eexhaustive | ||||
| //config_path: testdata/configs/exhaustive_checking_strategy_value.yml | ||||
| package testdata | ||||
| 
 | ||||
| type AccessControl string | ||||
| 
 | ||||
| const ( | ||||
| 	AccessPublic  AccessControl = "public" | ||||
| 	AccessPrivate AccessControl = "private" | ||||
| 	AccessDefault AccessControl = AccessPublic | ||||
| ) | ||||
| 
 | ||||
| // Expect no diagnostics for this switch statement, even though AccessDefault is | ||||
| // not listed, because AccessPublic (which is listed) has the same value as | ||||
| // AccessDefault. | ||||
| 
 | ||||
| func example(v AccessControl) { | ||||
| 	switch v { | ||||
| 	case AccessPublic: | ||||
| 	case AccessPrivate: | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										4
									
								
								test/testdata/exhaustive_default.go
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								test/testdata/exhaustive_default.go
									
									
									
									
										vendored
									
									
								
							| @ -11,6 +11,10 @@ const ( | ||||
| 	West | ||||
| ) | ||||
| 
 | ||||
| // Should not report missing cases in the switch statement below even though | ||||
| // some enum members (East, West) are not listed, because the switch statement | ||||
| // has a 'default' case and the default-signifies-exhaustive setting is true. | ||||
| 
 | ||||
| func processDirectionDefault(d Direction) { | ||||
| 	switch d { | ||||
| 	case North, South: | ||||
|  | ||||
							
								
								
									
										21
									
								
								test/testdata/exhaustive_ignore_enum_members.go
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								test/testdata/exhaustive_ignore_enum_members.go
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| //args: -Eexhaustive | ||||
| //config_path: testdata/configs/exhaustive_ignore_enum_members.yml | ||||
| package testdata | ||||
| 
 | ||||
| type Direction int | ||||
| 
 | ||||
| const ( | ||||
| 	North Direction = iota | ||||
| 	East | ||||
| 	South | ||||
| 	West | ||||
| ) | ||||
| 
 | ||||
| // Should only report East as missing because the enum member West is ignored | ||||
| // using the ignore-enum-members setting. | ||||
| 
 | ||||
| func processDirectionIgnoreEnumMembers(d Direction) { | ||||
| 	switch d { // ERROR "missing cases in switch of type Direction: East" | ||||
| 	case North, South: | ||||
| 	} | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Nishanth Shanmugham
						Nishanth Shanmugham