Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add gocognit linter #756

Merged
merged 7 commits into from
Oct 3, 2019
Merged

Add gocognit linter #756

merged 7 commits into from
Oct 3, 2019

Conversation

uudashr
Copy link
Contributor

@uudashr uudashr commented Sep 27, 2019

Add gocognit support

@CLAassistant
Copy link

CLAassistant commented Sep 27, 2019

CLA assistant check
All committers have signed the CLA.

@uudashr
Copy link
Contributor Author

uudashr commented Sep 27, 2019

This should close issue #721

@uudashr
Copy link
Contributor Author

uudashr commented Sep 27, 2019

FYI @jirfag at first I got this error

GOLANGCI_COM_RUN=1 golangci-lint run --out-format=json --issues-exit-code=0 --deadline=5m --new=false --new-from-rev= --new-from-patch=../changes.patch
    Running error: no such linter "gocognit"

It happen because the new linter doesn't exist yet on the GolangCI checks. Means new linter cannot be added to .golangci.yml.

@tpounds tpounds added the linter: new Support new linter label Sep 29, 2019
@jirfag
Copy link
Contributor

jirfag commented Oct 1, 2019

hi, it's the cool linter idea, thank you! Please, fix some comments in review

pkg/commands/run.go Outdated Show resolved Hide resolved
test/bench/bench_test.go Outdated Show resolved Hide resolved
pkg/lint/lintersdb/manager.go Outdated Show resolved Hide resolved
pkg/golinters/gocognit.go Outdated Show resolved Hide resolved
@uudashr uudashr requested a review from jirfag October 3, 2019 06:41
@uudashr
Copy link
Contributor Author

uudashr commented Oct 3, 2019

@jirfag done, please check

@jirfag jirfag merged commit 92ec1a1 into golangci:master Oct 3, 2019
@jirfag
Copy link
Contributor

jirfag commented Oct 3, 2019

thank you, merged

@bconway
Copy link

bconway commented Oct 3, 2019

In the absence of a .golangci.yml, it appears gocognit is using a default of 0:

$ golangci-lint run --disable-all -E gocognit
main.go:9:1: cognitive complexity 1 of func `main` is high (> 0) (gocognit) 
func main() {

In contrast, gocyclo retains a reasonable default of 30:

$ golangci-lint run --disable-all -E gocyclo
parse/fake.go:19:1: cyclomatic complexity 31 of func `Fake` is high (> 30) (gocyclo)
func Fake(b []byte) int {

This is with master.

@jirfag
Copy link
Contributor

jirfag commented Oct 4, 2019

@blocknonip thank you! fixed in #783

theckman pushed a commit to theckman/golangci-lint that referenced this pull request May 3, 2020
$ git cherry --abbrev -v 0af0999fabfb ee9bf5809ead
+ abd8436 all: enable Go modules on CI (golangci#753)
+ 3c9d0fb checkers: recognize //line and //nolint in commentFormatting (golangci#756)
+ 0b517d7 checkers: extend deprecatedComment patterns (golangci#757)
+ 09100f6 checkers: use astcast package instead of coerce.go (golangci#758)
+ 2e9e97f checker: simplify boolExprSimplify (golangci#759)
+ 575701e make: add go-consistent to CI checks list (golangci#761)
+ b55f431 checkers: fix unlambda handling of builtins (golangci#763)
+ 5a7dee3 checker: handle lambdas properly in boolExprSimplify (golangci#765)
+ 5ce3939 checkers: teach boolExprSimplify a few new tricks (golangci#766)
+ 04d160f checkers: add new patterns to boolExprSimplify (golangci#768)
+ 09582e2 make: collect coverprofile separately from goveralls (golangci#769)
+ d8d0ee4 checkers: recognize NOTE pattern in deprecatedComment (golangci#770)
+ 12f0f85 Update copyright notice to 2019 (golangci#771)
+ f54bdb6 checkers: add stringXbytes checker
+ 170d65c checkers: followup for golangci#773 (golangci#774)
+ 84e9e83 checkers: make stringXbytes more linear (golangci#775)
+ a800815 checkers: add Depreacted typo pattern (golangci#776)
+ 6751be9 checkers: add hexLiterals (golangci#772)
+ ac61906 checkers: add typeAssertChain checker (golangci#782)
+ d19dbf1 checkers: add codegenComment checker (golangci#783)
+ d82b576 checkers: proper pkg/obj check for flagName (golangci#786)
+ dfcf754 ci: enable integration tests (golangci#787)
+ 5dafc45 checkers: fix equalFold false positive (golangci#788)
+ ed5e8e7 checkers: refactor and fix hexLiteral checker (golangci#789)
+ e704e07 checkers: add argOrder checker (golangci#790)
+ 34c1dc8 checkers: add Split handling to argOrder checker (golangci#791)
+ cbe095d checkers: add math.Max and math.Min to dupArg (golangci#792)
+ c986ee5 checkers: add checkers info fields test (golangci#794)
+ 66e5832 cmd/makedocs: use lintpack, fix build (golangci#793)
+ 6bce9d0 cmd/makedocs: add enabled/disabled by default info (golangci#795)
+ 4adbf9a checkers: simplify flagName (golangci#799)
+ 07de34a checkers: add octalLiteral checker (golangci#798)
+ 765907a cmd/makedocs: add checker param docs (golangci#796)
+ ee9bf58 cmd/makedocs: fix headers formatting (golangci#803)
@ldez ldez added this to the v1.20 milestone Mar 6, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
linter: new Support new linter
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants