1- # Copyright (c) HashiCorp, Inc.
1+ # Copyright IBM Corp. 2013, 2026
22# SPDX-License-Identifier: MPL-2.0
33
4- issues :
5- # List of regexps of issue texts to exclude, empty list by default.
6- # But independently from this option we use default exclude patterns,
7- # it can be disabled by `exclude-use-default: false`. To list all
8- # excluded by default patterns execute `golangci-lint run --help`
9-
10- exclude-rules :
11- # Exclude gosimple bool check
12- - linters :
13- - gosimple
14- text : " S(1002|1008|1021)"
15- # Exclude failing staticchecks for now
16- - linters :
17- - staticcheck
18- text : " SA(1006|1019|4006|4010|4017|5007|6005|9004):"
19- # Exclude lll issues for long lines with go:generate
20- - linters :
21- - lll
22- source : " ^//go:generate "
23- - linters :
24- - errcheck
25- path : " .*_test.go"
26-
27- # Maximum issues count per one linter. Set to 0 to disable. Default is 50.
28- max-issues-per-linter : 0
29-
30- # Maximum count of issues with the same text. Set to 0 to disable. Default is 3.
31- max-same-issues : 0
4+ version : " 2"
325
336linters :
34- disable-all : true
357 enable :
36- - errcheck
37- - goimports
38- - gosimple
8+ - asasalint
9+ - asciicheck
10+ - bidichk
11+ - decorder
12+ - dupword
3913 - govet
4014 - ineffassign
15+ - misspell
16+ - nilerr
17+ - reassign
4118 - staticcheck
4219 - unconvert
4320 - unused
44- fast : true
21+ settings :
22+ errcheck :
23+ # report about not checking of errors in type assertions: `a := b.(MyStruct)`;
24+ # default is false: such cases aren't reported by default.
25+ check-type-assertions : false
26+
27+ # report about assignment of errors to blank identifier: `num, _ := strconv.Atoi(numStr)`;
28+ # default is false: such cases aren't reported by default.
29+ check-blank : false
30+ staticcheck :
31+ # SAxxxx checks in https://staticcheck.dev/docs/configuration/options/#checks
32+ # Example (to disable some checks): [ "all", "-SA1000", "-SA1001"]
33+ # Run `GL_DEBUG=staticcheck golangci-lint run --enable=staticcheck` to see all available checks and enabled by config checks.
34+ checks : ["all", "-SA4006", "-ST1000", "-ST1003", "-ST1005", "-ST1012", "-ST1016", "-ST1020", "-ST1021", "-ST1022", "-QF1001", "-QF1004", "-QF1008", "-QF1012"]
4535
4636# options for analysis running
4737run :
5747 # include test files or not, default is true
5848 tests : true
5949
60- # list of build tags, all linters use it. Default is empty list.
61- # build-tags:
62- # - mytag
63-
64- # which dirs to skip: issues from them won't be reported;
65- # can use regexp here: generated.*, regexp is applied on full path;
66- # default value is empty list, but default dirs are skipped independently
67- # from this option's value (see skip-dirs-use-default).
68- # skip-dirs:
69- # - src/external_libs
70- # - autogenerated_by_my_lib
71-
72- # default is true. Enables skipping of directories:
73- # vendor$, third_party$, testdata$, examples$, Godeps$, builtin$
74- skip-dirs-use-default : true
75-
7650 # which files to skip: they will be analyzed, but issues from them
7751 # won't be reported. Default value is empty list, but there is
7852 # no need to include all autogenerated files, we confidently recognize
7953 # autogenerated files. If it's not please let us know.
80- exclude -files :
81- - " .*\\ .hcl2spec\\ .go$"
54+ # skip -files:
55+ # - ".*\\.hcl2spec\\.go$"
8256 # - lib/bad.go
8357
84- # by default isn't set. If set we pass it to "go list -mod={option}". From "go help modules":
85- # If invoked with -mod=readonly, the go command is disallowed from the implicit
86- # automatic updating of go.mod described above. Instead, it fails when any changes
87- # to go.mod are needed. This setting is most useful to check that go.mod does
88- # not need updates, such as in a continuous integration and testing system.
89- # If invoked with -mod=vendor, the go command assumes that the vendor
90- # directory holds the correct copies of dependencies and ignores
91- # the dependency descriptions in go.mod.
92- modules-download-mode : readonly
93-
94- # output configuration options
95- output :
96- # colored-line-number|line-number|json|tab|checkstyle|code-climate, default is "colored-line-number"
97- formats : colored-line-number
98-
99- # print lines of code with issue, default is true
100- print-issued-lines : true
101-
102- # print linter name in the end of issue text, default is true
103- print-linter-name : true
104-
105- # make issues output unique by line, default is true
106- uniq-by-line : true
107-
108-
109- # all available settings of specific linters
110- linters-settings :
111- errcheck :
112- # report about not checking of errors in type assetions: `a := b.(MyStruct)`;
113- # default is false: such cases aren't reported by default.
114- check-type-assertions : false
115-
116- # report about assignment of errors to blank identifier: `num, _ := strconv.Atoi(numStr)`;
117- # default is false: such cases aren't reported by default.
118- check-blank : false
119-
120- # [deprecated] comma-separated list of pairs of the form pkg:regex
121- # the regex is used to ignore names within pkg. (default "fmt:.*").
122- # see https://github.com/kisielk/errcheck#the-deprecated-method for details
123- exclude-functions : fmt:.*,io/ioutil:^Read.*,io:Close
124-
125- # path to a file containing a list of functions to exclude from checking
126- # see https://github.com/kisielk/errcheck#excluding-functions for details
127- # exclude: /path/to/file.txt
58+ formatters :
59+ enable :
60+ - gofmt
61+ - goimports
0 commit comments