Commit 294f9b88 authored by Rob Pike's avatar Rob Pike

cmd/go: document file types

Explain which files the go command looks at, and what they represent.
Fixes #6348.

LGTM=rsc
R=rsc, minux.ma
CC=golang-codereviews
https://golang.org/cl/96480043
parent 7ef0eb1c
...@@ -33,6 +33,7 @@ Use "go help [command]" for more information about a command. ...@@ -33,6 +33,7 @@ Use "go help [command]" for more information about a command.
Additional help topics: Additional help topics:
c calling between Go and C c calling between Go and C
filetype file types
gopath GOPATH environment variable gopath GOPATH environment variable
importpath import path syntax importpath import path syntax
packages description of package lists packages description of package lists
...@@ -69,7 +70,8 @@ name is the base name of the containing directory. ...@@ -69,7 +70,8 @@ name is the base name of the containing directory.
The -i flag installs the packages that are dependencies of the target. The -i flag installs the packages that are dependencies of the target.
The build flags are shared by the build, install, run, and test commands: The build flags are shared by the build, clean, get, install, list, run,
and test commands:
-a -a
force rebuilding of packages that are already up-to-date. force rebuilding of packages that are already up-to-date.
...@@ -144,6 +146,7 @@ source directories corresponding to the import paths: ...@@ -144,6 +146,7 @@ source directories corresponding to the import paths:
DIR(.exe) from go build DIR(.exe) from go build
DIR.test(.exe) from go test -c DIR.test(.exe) from go test -c
MAINFILE(.exe) from go build MAINFILE.go MAINFILE(.exe) from go build MAINFILE.go
*.so from SWIG
In the list, DIR represents the final path element of the In the list, DIR represents the final path element of the
directory, and MAINFILE is the base name of any Go source directory, and MAINFILE is the base name of any Go source
...@@ -238,8 +241,7 @@ The -u flag instructs get to use the network to update the named packages ...@@ -238,8 +241,7 @@ The -u flag instructs get to use the network to update the named packages
and their dependencies. By default, get uses the network to check out and their dependencies. By default, get uses the network to check out
missing packages but does not use it to look for updates to existing packages. missing packages but does not use it to look for updates to existing packages.
Get also accepts all the flags in the 'go build' and 'go install' commands, Get also accepts build flags to control the installation. See 'go help build'.
to control the installation. See 'go help build'.
When checking out or updating a package, get looks for a branch or tag When checking out or updating a package, get looks for a branch or tag
that matches the locally installed version of Go. The most important that matches the locally installed version of Go. The most important
...@@ -516,6 +518,43 @@ compiler. The CC or CXX environment variables may be set to determine ...@@ -516,6 +518,43 @@ compiler. The CC or CXX environment variables may be set to determine
the C or C++ compiler, respectively, to use. the C or C++ compiler, respectively, to use.
File types
The go command examines the contents of a restricted set of files
in each directory. It identifies which files to examine based on
the extension of the file name. These extensions are:
.go
Go source files.
.c, .h
C source files.
If the package uses cgo, these will be compiled with the
OS-native compiler (typically gcc); otherwise they will be
compiled with the Go-specific support compiler,
5c, 6c, or 8c, etc. as appropriate.
.cc, .cpp, .cxx, .hh, .hpp, .hxx
C++ source files. Only useful with cgo or SWIG, and always
compiled with the OS-native compiler.
.m
Objective-C source files. Only useful with cgo, and always
compiled with the OS-native compiler.
.s, .S
Assembler source files.
If the package uses cgo, these will be assembled with the
OS-native assembler (typically gcc (sic)); otherwise they
will be assembled with the Go-specific support assembler,
5a, 6a, or 8a, etc., as appropriate.
.swig, .swigcxx
SWIG definition files.
.syso
System object files.
Files of each of these types except .syso may contain build
constraints, but the go command stops scanning for build constraints
at the first item in the file that is not a blank line or //-style
line comment.
GOPATH environment variable GOPATH environment variable
The Go path is used to resolve import statements. The Go path is used to resolve import statements.
......
...@@ -295,3 +295,43 @@ but new packages are always downloaded into the first directory ...@@ -295,3 +295,43 @@ but new packages are always downloaded into the first directory
in the list. in the list.
`, `,
} }
var helpFileType = &Command{
UsageLine: "filetype",
Short: "file types",
Long: `
The go command examines the contents of a restricted set of files
in each directory. It identifies which files to examine based on
the extension of the file name. These extensions are:
.go
Go source files.
.c, .h
C source files.
If the package uses cgo, these will be compiled with the
OS-native compiler (typically gcc); otherwise they will be
compiled with the Go-specific support compiler,
5c, 6c, or 8c, etc. as appropriate.
.cc, .cpp, .cxx, .hh, .hpp, .hxx
C++ source files. Only useful with cgo or SWIG, and always
compiled with the OS-native compiler.
.m
Objective-C source files. Only useful with cgo, and always
compiled with the OS-native compiler.
.s, .S
Assembler source files.
If the package uses cgo, these will be assembled with the
OS-native assembler (typically gcc (sic)); otherwise they
will be assembled with the Go-specific support assembler,
5a, 6a, or 8a, etc., as appropriate.
.swig, .swigcxx
SWIG definition files.
.syso
System object files.
Files of each of these types except .syso may contain build
constraints, but the go command stops scanning for build constraints
at the first item in the file that is not a blank line or //-style
line comment.
`,
}
...@@ -89,6 +89,7 @@ var commands = []*Command{ ...@@ -89,6 +89,7 @@ var commands = []*Command{
cmdVet, cmdVet,
helpC, helpC,
helpFileType,
helpGopath, helpGopath,
helpImportPath, helpImportPath,
helpPackages, helpPackages,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment