diff options
| author | Michael Stapelberg <stapelberg@debian.org> | 2013-03-04 21:27:43 +0100 | 
|---|---|---|
| committer | Michael Stapelberg <michael@stapelberg.de> | 2013-03-04 21:27:43 +0100 | 
| commit | ad47422646a18ffcb47cec916ef7393c923f2e76 (patch) | |
| tree | 7c7861fb3d9539d61c1dcfd5b8dadee974c25760 /src/cmd/cgo/ast.go | |
| parent | 2c8d5d584a79781ca41bb6f4b396893fbbac5b97 (diff) | |
| parent | 04b08da9af0c450d645ab7389d1467308cfc2db8 (diff) | |
| download | golang-ad47422646a18ffcb47cec916ef7393c923f2e76.tar.gz | |
Merge tag 'upstream/1.1_hg20130304' into debian-sid
Upstream version 1.1~hg20130304
Diffstat (limited to 'src/cmd/cgo/ast.go')
| -rw-r--r-- | src/cmd/cgo/ast.go | 26 | 
1 files changed, 25 insertions, 1 deletions
| diff --git a/src/cmd/cgo/ast.go b/src/cmd/cgo/ast.go index 381e606ef..dbae3b7b1 100644 --- a/src/cmd/cgo/ast.go +++ b/src/cmd/cgo/ast.go @@ -78,7 +78,7 @@ func (f *File) ReadGo(name string) {  			}  			if cg != nil {  				f.Preamble += fmt.Sprintf("#line %d %q\n", sourceLine(cg), name) -				f.Preamble += cg.Text() + "\n" +				f.Preamble += commentText(cg) + "\n"  			}  		}  	} @@ -131,6 +131,30 @@ func (f *File) ReadGo(name string) {  	f.AST = ast2  } +// Like ast.CommentGroup's Text method but preserves +// leading blank lines, so that line numbers line up. +func commentText(g *ast.CommentGroup) string { +	if g == nil { +		return "" +	} +	var pieces []string +	for _, com := range g.List { +		c := string(com.Text) +		// Remove comment markers. +		// The parser has given us exactly the comment text. +		switch c[1] { +		case '/': +			//-style comment (no newline at the end) +			c = c[2:] + "\n" +		case '*': +			/*-style comment */ +			c = c[2 : len(c)-2] +		} +		pieces = append(pieces, c) +	} +	return strings.Join(pieces, "") +} +  // Save references to C.xxx for later processing.  func (f *File) saveRef(x interface{}, context string) {  	n, ok := x.(*ast.Expr) | 
