• Dmitri Shuralyov's avatar
    cmd/go: copy missing bit of documentation about code generated comment · 8d2e65d2
    Dmitri Shuralyov authored
    This CL attempts to restore the clarity of the original specification
    at https://golang.org/s/generatedcode that the line may appear
    anywhere. It is preferable (for human readability), and most common
    for it to be early in the file, but that is merely a convention, not
    a strict well-specified requirement. Document it as so.
    
    Background
    
    Issue #13560 was a proposal define a standard for marking files as
    generated, one that is suitable to be recognized both by humans
    and machine tools. It was accepted, and the final specification
    was documented at https://golang.org/s/generatedcode. Its text,
    copied exactly:
    
    	Generated files are marked by a line of text that matches
    	the regular expression, in Go syntax:
    
    		^// Code generated .* DO NOT EDIT\.$
    
    	The .* means the tool can put whatever folderol it wants in there,
    	but the comment must be a single line and must start with Code generated
    	and end with DO NOT EDIT., with a period.
    
    	The text may appear anywhere in the file.
    
    The https://golang.org/s/generatedcode link points to a comment
    in a very large GitHub issue. That makes it harder to find.
    Issue #25433 was opened about moving that information somewhere else.
    It was resolved via CL 118756, which added text to cmd/go documentation
    at https://golang.org/cmd/go/#hdr-Generate_Go_files_by_processing_source:
    
    	To convey to humans and machine tools that code is generated,
    	generated source should have a line early in the file that
    	matches the following regular expression (in Go syntax):
    
    		^// Code generated .* DO NOT EDIT\.$
    
    The CL description noted that "This change merely moves that
    information to a more visible place." The intention was to preserve
    the specification unmodified.
    
    The original specification was very clear that "The text may appear
    anywhere in the file." The new text in cmd/go documentation wasn't
    very clear. "A line early in the file" is not a precise enough criteria
    to be recognized by a machine tool, because there isn't a precise
    definition of what lines are "early in the file".
    
    Updates #13560
    Updates #25433
    Updates #28089
    
    Change-Id: I4e374163b16c3f972f9591ec2647fd3d5a2dd5ae
    Reviewed-on: https://go-review.googlesource.com/c/158817Reviewed-by: 's avatarRob Pike <r@golang.org>
    8d2e65d2
Name
Last commit
Last update
..
archive Loading commit data...
bufio Loading commit data...
builtin Loading commit data...
bytes Loading commit data...
cmd Loading commit data...
compress Loading commit data...
container Loading commit data...
context Loading commit data...
crypto Loading commit data...
database/sql Loading commit data...
debug Loading commit data...
encoding Loading commit data...
errors Loading commit data...
expvar Loading commit data...
flag Loading commit data...
fmt Loading commit data...
go Loading commit data...
hash Loading commit data...
html Loading commit data...
image Loading commit data...
index/suffixarray Loading commit data...
internal Loading commit data...
io Loading commit data...
log Loading commit data...
math Loading commit data...
mime Loading commit data...
net Loading commit data...
os Loading commit data...
path Loading commit data...
plugin Loading commit data...
reflect Loading commit data...
regexp Loading commit data...
runtime Loading commit data...
sort Loading commit data...
strconv Loading commit data...
strings Loading commit data...
sync Loading commit data...
syscall Loading commit data...
testdata Loading commit data...
testing Loading commit data...
text Loading commit data...
time Loading commit data...
unicode Loading commit data...
unsafe Loading commit data...
Make.dist Loading commit data...
all.bash Loading commit data...
all.bat Loading commit data...
all.rc Loading commit data...
androidtest.bash Loading commit data...
bootstrap.bash Loading commit data...
buildall.bash Loading commit data...
clean.bash Loading commit data...
clean.bat Loading commit data...
clean.rc Loading commit data...
cmp.bash Loading commit data...
iostest.bash Loading commit data...
make.bash Loading commit data...
make.bat Loading commit data...
make.rc Loading commit data...
naclmake.bash Loading commit data...
nacltest.bash Loading commit data...
race.bash Loading commit data...
race.bat Loading commit data...
run.bash Loading commit data...
run.bat Loading commit data...
run.rc Loading commit data...