tree: 7ef8a4eaa7d8a5272307ae3106035721d96aa515 [path history] [tgz]
  1. .gitignore
  2. .gitlab-ci.params.yml
  3. .gitlab-ci.yml
  4. analyzer.go
  5. LICENSE.md
  6. Makefile
  7. README.md
  8. renovate.json
vendor/gitlab.com/bosi/decorder/README.md

Decorder

A declaration order linter for Go. In case of this tool declarations are type, const, var and func.

Rules

This linter applies multiple rules where each can be disabled via cli parameter.

ruledescriptioncli-options
declaration orderEnforces the order of global declarations (e.g. all global constants are always defined before variables).
You can also define a subset of declarations if you don't want to enforce the order of all of them.
* disable all checks: -disable-dec-order-check
* disable type checks: -disable-type-dec-order-check
* disable const checks: -disable-const-dec-order-check
* disable var checks: -disable-var-dec-order-check
* custom order: -dec-order var,const,func,type
declaration numberEnforces that the statements const, var and type are only used once per file. You have to use parenthesis
to declare e.g multiple global types inside a file.
disable check: -disable-dec-num-check
init func firstEnforces the init func to be the first function in file.disable check: -disable-init-func-first-check

You may find the implementation of the rules inside analyzer.go.

Underscore var declarations can be ignored via -ignore-underscore-vars.

Installation

go install gitlab.com/bosi/decorder/cmd/decorder

You can use the linter via golangci-lint as well: https://golangci-lint.run/usage/linters/#decorder.

Usage

# with default options
decorder ./...

# custom declaration order
decorder -dec-order var,const,func,type ./...

# disable declaration order check
decorder -disable-dec-order-check ./...

# disable check for multiple declarations statements
decorder -disable-dec-num-check ./...

# disable check for multiple declarations (var only) statements
decorder -disable-var-dec-num-check ./...

# disable check that init func is always first function
decorder -disable-init-func-first-check ./...

# ignore underscore variables for all checks
decorder -ignore-underscore-vars ./...