Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
go
Commits
b6e2d6b7
Commit
b6e2d6b7
authored
Feb 17, 2012
by
Robert Griesemer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
go/doc: move Example code from go/ast to go/doc.
Fixes #3048. R=rsc CC=golang-dev
https://golang.org/cl/5672081
parent
c4c92ebe
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
17 additions
and
13 deletions
+17
-13
src/cmd/dist/build.c
src/cmd/dist/build.c
+2
-0
src/cmd/go/test.go
src/cmd/go/test.go
+2
-1
src/cmd/godoc/godoc.go
src/cmd/godoc/godoc.go
+4
-4
src/pkg/go/doc/example.go
src/pkg/go/doc/example.go
+9
-8
No files found.
src/cmd/dist/build.c
View file @
b6e2d6b7
...
...
@@ -1126,6 +1126,7 @@ static char *buildorder[] = {
"pkg/net/url"
,
"pkg/text/template/parse"
,
"pkg/text/template"
,
"pkg/go/doc"
,
"cmd/go"
,
};
...
...
@@ -1165,6 +1166,7 @@ static char *cleantab[] = {
"pkg/fmt"
,
"pkg/go/ast"
,
"pkg/go/build"
,
"pkg/go/doc"
,
"pkg/go/parser"
,
"pkg/go/scanner"
,
"pkg/go/token"
,
...
...
src/cmd/go/test.go
View file @
b6e2d6b7
...
...
@@ -9,6 +9,7 @@ import (
"fmt"
"go/ast"
"go/build"
"go/doc"
"go/parser"
"go/token"
"os"
...
...
@@ -719,7 +720,7 @@ func (t *testFuncs) load(filename, pkg string, seen *bool) error {
*
seen
=
true
}
}
for
_
,
e
:=
range
ast
.
Examples
(
f
)
{
for
_
,
e
:=
range
doc
.
Examples
(
f
)
{
if
e
.
Output
==
""
{
// Don't run examples with no output.
continue
...
...
src/cmd/godoc/godoc.go
View file @
b6e2d6b7
...
...
@@ -501,7 +501,7 @@ func startsWithUppercase(s string) bool {
var
exampleOutputRx
=
regexp
.
MustCompile
(
`(?i)//[[:space:]]*output:`
)
func
example_htmlFunc
(
funcName
string
,
examples
[]
*
ast
.
Example
,
fset
*
token
.
FileSet
)
string
{
func
example_htmlFunc
(
funcName
string
,
examples
[]
*
doc
.
Example
,
fset
*
token
.
FileSet
)
string
{
var
buf
bytes
.
Buffer
for
_
,
eg
:=
range
examples
{
name
:=
eg
.
Name
...
...
@@ -979,7 +979,7 @@ type PageInfo struct {
FSet
*
token
.
FileSet
// corresponding file set
PAst
*
ast
.
File
// nil if no single AST with package exports
PDoc
*
doc
.
Package
// nil if no single package documentation
Examples
[]
*
ast
.
Example
// nil if no example code
Examples
[]
*
doc
.
Example
// nil if no example code
Dirs
*
DirList
// nil if no directory information
DirTime
time
.
Time
// directory time stamp
DirFlat
bool
// if set, show directory in a flat (non-indented) manner
...
...
@@ -1128,7 +1128,7 @@ func (h *httpHandler) getPageInfo(abspath, relpath, pkgname string, mode PageInf
}
// get examples from *_test.go files
var
examples
[]
*
ast
.
Example
var
examples
[]
*
doc
.
Example
filter
=
func
(
d
os
.
FileInfo
)
bool
{
return
isGoFile
(
d
)
&&
strings
.
HasSuffix
(
d
.
Name
(),
"_test.go"
)
}
...
...
@@ -1140,7 +1140,7 @@ func (h *httpHandler) getPageInfo(abspath, relpath, pkgname string, mode PageInf
for
_
,
f
:=
range
testpkg
.
Files
{
files
=
append
(
files
,
f
)
}
examples
=
append
(
examples
,
ast
.
Examples
(
files
...
)
...
)
examples
=
append
(
examples
,
doc
.
Examples
(
files
...
)
...
)
}
}
...
...
src/pkg/go/
ast
/example.go
→
src/pkg/go/
doc
/example.go
View file @
b6e2d6b7
...
...
@@ -4,9 +4,10 @@
// Extract example functions from file ASTs.
package
ast
package
doc
import
(
"go/ast"
"go/token"
"regexp"
"sort"
...
...
@@ -18,23 +19,23 @@ import (
type
Example
struct
{
Name
string
// name of the item being exemplified
Doc
string
// example function doc string
Code
Node
Comments
[]
*
CommentGroup
Code
ast
.
Node
Comments
[]
*
ast
.
CommentGroup
Output
string
// expected output
}
func
Examples
(
files
...*
File
)
[]
*
Example
{
func
Examples
(
files
...*
ast
.
File
)
[]
*
Example
{
var
list
[]
*
Example
for
_
,
file
:=
range
files
{
hasTests
:=
false
// file contains tests or benchmarks
numDecl
:=
0
// number of non-import declarations in the file
var
flist
[]
*
Example
for
_
,
decl
:=
range
file
.
Decls
{
if
g
,
ok
:=
decl
.
(
*
GenDecl
);
ok
&&
g
.
Tok
!=
token
.
IMPORT
{
if
g
,
ok
:=
decl
.
(
*
ast
.
GenDecl
);
ok
&&
g
.
Tok
!=
token
.
IMPORT
{
numDecl
++
continue
}
f
,
ok
:=
decl
.
(
*
FuncDecl
)
f
,
ok
:=
decl
.
(
*
ast
.
FuncDecl
)
if
!
ok
{
continue
}
...
...
@@ -73,9 +74,9 @@ func Examples(files ...*File) []*Example {
var
outputPrefix
=
regexp
.
MustCompile
(
`(?i)^[[:space:]]*output:`
)
func
exampleOutput
(
fun
*
FuncDecl
,
comments
[]
*
CommentGroup
)
string
{
func
exampleOutput
(
fun
*
ast
.
FuncDecl
,
comments
[]
*
ast
.
CommentGroup
)
string
{
// find the last comment in the function
var
last
*
CommentGroup
var
last
*
ast
.
CommentGroup
for
_
,
cg
:=
range
comments
{
if
cg
.
Pos
()
<
fun
.
Pos
()
{
continue
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment