]> Cypherpunks.ru repositories - gostls13.git/commit
all: treat all files as binary, but check in .bat with CRLF
authorDmitri Shuralyov <dmitshur@golang.org>
Thu, 4 Jun 2020 04:35:09 +0000 (00:35 -0400)
committerDmitri Shuralyov <dmitshur@golang.org>
Mon, 8 Jun 2020 15:31:43 +0000 (15:31 +0000)
commitee379d2b08ce12c24042da18d711e2a1bd7943f0
treebed1ac8a7211276dd170d071f91b9330d97d0af1
parent5c6b2b14db8264a8cdc3634e68c7ae65307df0ae
all: treat all files as binary, but check in .bat with CRLF

This is a followup to CL 96495.

It should be simpler and more robust to achieve .bat files having
CRLF line endings by treating it as a binary file, like all other
files, and checking it in with the desired CRLF line endings.

A test is used to check the entire Go tree, short of directories
starting with "." and named "testdata", for any .bat files that
have anything other than strict CRLF line endings. This will help
catch any accidental modifications to existing .bat files or check
ins of new .bat files.

Importantly, this is compatible with how Gerrit serves .tar.gz files,
making it so that CRLF line endings are preserved.

The Go project is supported on many different environments, some of
which may have limited git implementations available, or none at all.
Relying on fewer git features and special rules makes it easier to
have confidence in the exact content of all files. Additionally, Go
development started in Subversion, moved to Perforce, then Mercurial,
and now uses Git.¹ Reducing its reliance on git-specific features will
help if there will be another transition in the project's future.

There are only 5 .bat files in the entire Go source tree, so a new one
being added is a rare event, and we prefer to do things in Go instead.
We still have the option of improving the experience for developers by
adding a pre-commit converter for .bat files to the git-codereview tool.

¹ https://groups.google.com/d/msg/golang-dev/sckirqOWepg/YmyT7dWJiocJ

Fixes #39391.
For #37791.

Change-Id: I6e202216322872f0307ac96f1b8d3f57cb901e6b
Reviewed-on: https://go-review.googlesource.com/c/go/+/236437
Reviewed-by: Bryan C. Mills <bcmills@google.com>
.gitattributes
src/all.bat
src/clean.bat
src/make.bat
src/race.bat
src/run.bat
test/winbatch.go