Russian warship, go f*ck yourself!
goimports-reviser data:image/s3,"s3://crabby-images/ff3fa/ff3faff867eeba728675da9ac767e4f42a38547c" alt="Tweet"
data:image/s3,"s3://crabby-images/75b7f/75b7ff52f8c5707017679a0e624cc2e4a0c58aa5" alt="Mentioned in Awesome Go"
data:image/s3,"s3://crabby-images/4724f/4724f9e75533708d80e10fe8dda13259249fc42c" alt="'logo'"
Tool for Golang to sort goimports by 3-4 groups(with own linter): std, general, local(which is optional) and project dependencies.
Also, formatting for your code will be prepared(so, you don't need to use gofmt
or goimports
separately).
Use additional options -rm-unused
to remove unused imports and -set-alias
to rewrite import aliases for versioned packages or for packages with additional prefix/suffix(example: opentracing "github.com/opentracing/opentracing-go"
).
-local
- will create group for local imports. Values should be comma-separated.
Configuration:
Cmd
goimports-reviser -file-path ./reviser/reviser.go -rm-unused -set-alias -format
Example, to configure it with JetBrains IDEs (via file watcher plugin):
data:image/s3,"s3://crabby-images/43f28/43f2811fe7d25a6bd348140ca18e5e02b5daeb9b" alt="example"
Options:
Usage of goimports-reviser:
-file-path string
File path to fix imports(ex.: ./reviser/reviser.go). Required parameter.
-format
Option will perform additional formatting. Optional parameter.
-list-diff
Option will list-diff files whose formatting differs from goimports-reviser. Optional parameter.
-local string
Local package prefixes which will be placed after 3rd-party group(if defined). Values should be comma-separated. Optional parameters.
-output string
Can be "file", "write" or "stdout". Whether to write the formatted content back to the file or to stdout. When "write" together with "-list-diff" will list the file name and write back to the file. Optional parameter. (default "file")
-project-name string
Your project name(ex.: github.com/incu6us/goimports-reviser). Optional parameter.
-rm-unused
Remove unused imports. Optional parameter.
-set-alias
Set alias for versioned package names, like 'github.com/go-pg/pg/v9'. In this case import will be set as 'pg "github.com/go-pg/pg/v9"'. Optional parameter.
-set-exit-status
set the exit status to 1 if a change is needed/made. Optional parameter.
Install
With Brew
brew tap incu6us/homebrew-tap
brew install incu6us/homebrew-tap/goimports-reviser
With Snap
snap install goimports-reviser
Examples
Before usage:
package testdata
import (
"log"
"github.com/incu6us/goimports-reviser/testdata/innderpkg"
"bytes"
"github.com/pkg/errors"
)
After usage:
package testdata
import (
"bytes"
"log"
"github.com/pkg/errors"
"github.com/incu6us/goimports-reviser/testdata/innderpkg"
)
Comments(not Docs) for imports is acceptable. Example:
package testdata
import (
"fmt"
)
Example with -local
-option
Before usage:
package testdata
import (
"fmt"
"github.com/pkg/errors"
"github.com/incu6us/goimports-reviser/pkg"
"goimports-reviser/pkg"
)
After usage:
package testdata
import (
"fmt"
"github.com/pkg/errors"
"github.com/incu6us/goimports-reviser/pkg"
"goimports-reviser/pkg"
)
Example with -format
-option
Before usage:
package main
func test(){
}
func additionalTest(){
}
After usage:
package main
func test(){
}
func additionalTest(){
}
If you like the project
data:image/s3,"s3://crabby-images/2d5a2/2d5a22738a80127bd463b38c970ae643d76a1ab6" alt="Buy Me A Coffee"
Stargazers
data:image/s3,"s3://crabby-images/d5566/d5566e8da333d8d1cb3b9abb0517b1736c6e549a" alt="Stargazers over time"