-
-
Notifications
You must be signed in to change notification settings - Fork 114
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
Discrepancies of the formatting in different scenarios #238
Comments
Please see https://github.com/mvdan/gofumpt#contributing; use the "diagnose" directive to see exactly how gofumpt is being run in each one of those cases. |
Interesting; With
which results in import (
"adrian/pkg/sql"
"adrian/pkg/redis"
"context"
"time"
) When running
Alongside the properly formatted code i.e. import (
"context"
"time"
"adrian/pkg/sql"
"adrian/pkg/redis"
) Then, if we get the same
Which also outputs the expected import order. Does this mean that the |
Correct. See https://pkg.go.dev/mvdan.cc/gofumpt/format#Options. I assume this is a bug in golangci-lint; if it runs inside a module, it should be setting the option just like the regular gofumpt tool. Our changelog also contains this information.
Ah, that's our fault - we don't really support printing gofumpt's own version when it is used as a library. I'll look into a fix. You should still be able to figure out manually what golangci-lint version you're using, and from that tell whether its gofumpt version is relatively old, but still. |
Yeah, unfortunately I'll let them know and hopefully they'll add an auto-default instead of empty. Nonetheless, thanks for the help and the quick replies! |
Hello,
I've been diving a bit into gofumpt as a result of this issue.
Let's say we have the following test file:
The output of the existing
format_test
which tests theformat.Source
function is as follows:While the out of another test I've written which uses the
format.File
function, seems to format the file as follows:I've found a bit of a stranger interaction when running the binary on the same
.go
file but in 2 different locations. I have a bigmain.go
file in a project where thestd imports
are sorted at the top, before the rest of the imports. I assume the rule that is followed here isstd imports must be in a separate group at the top
.However, when I copy the file, or try to replicate the import structure, the
std imports
no longer get put at the top, and instead, all the internal packages get put at the top, and then right after those the std imports are appended. It's really weird to have the same file get formatted differently based on location 🤔i.e. I'm getting the following after copy pasting the file in another location
instead of this which is what I get when the file is in the current existing project
It's vaguely similar to #225
It's odd since I see even files in the exact same repo sometimes have the
std imports
before everything else, and sometimes they do not, it's a bit of an unpredictable scenario but I'm not sure what's causing it or why.The text was updated successfully, but these errors were encountered: