]> Cypherpunks repositories - gostls13.git/commit
cmd/gofmt: simplify logic to process arguments
authorDaniel Martí <mvdan@mvdan.cc>
Sat, 30 Aug 2025 17:54:43 +0000 (18:54 +0100)
committerDaniel Martí <mvdan@mvdan.cc>
Wed, 3 Sep 2025 14:26:07 +0000 (07:26 -0700)
commit4c4cefc19a16924f3aa7135d3fdc6d1687fe26c7
treec88c1123f836074fc1a8da61fbf519cd32e44402
parent925a3cdcd13472c8f78d51c9ce99a59e77d46eb4
cmd/gofmt: simplify logic to process arguments

Rather than stat-ing each argument and taking different code paths
depending on whether it's a directory or not, we can leverage
the fact that filepath.WalkDir works on regular files and already
has to figure out whether each file it walks is a directory or not.

We can then implement "always format non-directory arguments"
by looking at whether the path we are walking is the original argument,
meaning we are walking the top file.

For full clarity, we expand the skipping logic with a switch,
as before it was a bit confusing how we could `return err`
on directories and other non-Go files.

Given that we discard directories separately now,
simplify isGoFile to just be about filenames.

While here, also note that we called AddReport inside WalkDir;
this is unnecessary, as we can return the error for the same effect.

Change-Id: I50ab94710143f19bd8dd95a69e01a3dd228e397e
Reviewed-on: https://go-review.googlesource.com/c/go/+/700115
Reviewed-by: Sean Liao <sean@liao.dev>
Reviewed-by: Michael Pratt <mpratt@google.com>
Reviewed-by: Cherry Mui <cherryyz@google.com>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
src/cmd/gofmt/gofmt.go
src/cmd/gofmt/long_test.go