Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
neoppod
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
1
Issues
1
List
Boards
Labels
Milestones
Merge Requests
2
Merge Requests
2
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
neoppod
Commits
fc1fa022
Commit
fc1fa022
authored
Jul 04, 2017
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
dcf3f530
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
96 additions
and
16 deletions
+96
-16
go/xcommon/tracing/cmd/gotrace/gotrace.go
go/xcommon/tracing/cmd/gotrace/gotrace.go
+89
-10
go/xcommon/tracing/cmd/gotrace/gotrace_test.go
go/xcommon/tracing/cmd/gotrace/gotrace_test.go
+2
-2
go/xcommon/tracing/cmd/gotrace/testdata/src/b/pkg2/pkg2.go
go/xcommon/tracing/cmd/gotrace/testdata/src/b/pkg2/pkg2.go
+1
-4
go/xcommon/tracing/cmd/gotrace/testdata/src/c/pkg3/ztrace_test.s.ok
.../tracing/cmd/gotrace/testdata/src/c/pkg3/ztrace_test.s.ok
+2
-0
go/xcommon/tracing/cmd/gotrace/testdata/src/c/pkg3/ztrace_x_test.s.ok
...racing/cmd/gotrace/testdata/src/c/pkg3/ztrace_x_test.s.ok
+2
-0
No files found.
go/xcommon/tracing/cmd/gotrace/gotrace.go
View file @
fc1fa022
...
@@ -49,10 +49,13 @@ import (
...
@@ -49,10 +49,13 @@ import (
"text/template"
"text/template"
"golang.org/x/tools/go/loader"
"golang.org/x/tools/go/loader"
"lab.nexedi.com/kirr/go123/xerr"
)
)
// traceEvent represents 1 trace:event definition
// traceEvent represents 1 trace:event definition
type
traceEvent
struct
{
type
traceEvent
struct
{
Pos
token
.
Position
Pkgt
*
Package
// package this trace event is part of
Pkgt
*
Package
// package this trace event is part of
// declaration of function to signal the event
// declaration of function to signal the event
...
@@ -163,7 +166,7 @@ func (p *Package) parseTraceEvent(srcfile *ast.File, pos token.Position, text st
...
@@ -163,7 +166,7 @@ func (p *Package) parseTraceEvent(srcfile *ast.File, pos token.Position, text st
//println(buf.String())
//println(buf.String())
//println("---- 8< ----")
//println("---- 8< ----")
tf
,
err
:=
parser
.
ParseFile
(
p
.
traceFset
,
filename
,
buf
.
String
(),
0
)
tf
,
err
:=
parser
.
ParseFile
(
p
.
traceFset
,
filename
,
buf
.
String
(),
0
)
fmt
.
Println
(
"parse:"
,
err
)
//
fmt.Println("parse:", err)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
// should already have pos' as prefix
return
nil
,
err
// should already have pos' as prefix
}
}
...
@@ -189,12 +192,12 @@ func (p *Package) parseTraceEvent(srcfile *ast.File, pos token.Position, text st
...
@@ -189,12 +192,12 @@ func (p *Package) parseTraceEvent(srcfile *ast.File, pos token.Position, text st
// typecheck prepared file to get trace func argument types
// typecheck prepared file to get trace func argument types
// (type information lands into p.traceTypeInfo)
// (type information lands into p.traceTypeInfo)
err
=
p
.
traceChecker
.
Files
([]
*
ast
.
File
{
tf
})
err
=
p
.
traceChecker
.
Files
([]
*
ast
.
File
{
tf
})
fmt
.
Println
(
"typecheck:"
,
err
)
//
fmt.Println("typecheck:", err)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
// should already have pos' as prefix
return
nil
,
err
// should already have pos' as prefix
}
}
return
&
traceEvent
{
Pkgt
:
p
,
FuncDecl
:
declf
},
nil
return
&
traceEvent
{
P
os
:
pos
,
P
kgt
:
p
,
FuncDecl
:
declf
},
nil
}
}
// parseTraceImport parses trace import directive into traceImport
// parseTraceImport parses trace import directive into traceImport
...
@@ -235,6 +238,38 @@ func (p *Package) parseTraceImport(pos token.Position, text string) (*traceImpor
...
@@ -235,6 +238,38 @@ func (p *Package) parseTraceImport(pos token.Position, text string) (*traceImpor
return
&
traceImport
{
Pos
:
pos
,
PkgName
:
pkgname
,
PkgPath
:
pkgpath
},
nil
return
&
traceImport
{
Pos
:
pos
,
PkgName
:
pkgname
,
PkgPath
:
pkgpath
},
nil
}
}
// SplitTests splits package into main and test parts, each covering trace-related things accordingly
func
(
p
*
Package
)
SplitTests
()
(
testPkg
*
Package
)
{
__
:=
*
p
testPkg
=
&
__
// for tracing what is relevant is: we need to split only .Eventv & .Importv
eventv
:=
p
.
Eventv
importv
:=
p
.
Importv
p
.
Eventv
=
nil
p
.
Importv
=
nil
testPkg
.
Eventv
=
nil
testPkg
.
Importv
=
nil
for
_
,
e
:=
range
eventv
{
if
strings
.
HasSuffix
(
e
.
Pos
.
Filename
,
"_test.go"
)
{
testPkg
.
Eventv
=
append
(
testPkg
.
Eventv
,
e
)
}
else
{
p
.
Eventv
=
append
(
p
.
Eventv
,
e
)
}
}
for
_
,
i
:=
range
importv
{
if
strings
.
HasSuffix
(
i
.
Pos
.
Filename
,
"_test.go"
)
{
testPkg
.
Importv
=
append
(
testPkg
.
Importv
,
i
)
}
else
{
p
.
Importv
=
append
(
p
.
Importv
,
i
)
}
}
return
testPkg
}
// packageTrace returns tracing information about a package
// packageTrace returns tracing information about a package
func
packageTrace
(
prog
*
loader
.
Program
,
pkgi
*
loader
.
PackageInfo
)
(
*
Package
,
error
)
{
func
packageTrace
(
prog
*
loader
.
Program
,
pkgi
*
loader
.
PackageInfo
)
(
*
Package
,
error
)
{
// prepare Package with typechecker ready to typecheck trace files
// prepare Package with typechecker ready to typecheck trace files
...
@@ -302,7 +337,7 @@ func packageTrace(prog *loader.Program, pkgi *loader.PackageInfo) (*Package, err
...
@@ -302,7 +337,7 @@ func packageTrace(prog *loader.Program, pkgi *loader.PackageInfo) (*Package, err
directive
,
arg
:=
textv
[
0
],
textv
[
1
]
directive
,
arg
:=
textv
[
0
],
textv
[
1
]
switch
directive
{
switch
directive
{
case
"//trace:event"
:
case
"//trace:event"
:
fmt
.
Println
(
"*"
,
textv
)
//
fmt.Println("*", textv)
event
,
err
:=
p
.
parseTraceEvent
(
file
,
pos
,
arg
)
event
,
err
:=
p
.
parseTraceEvent
(
file
,
pos
,
arg
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
...
@@ -596,6 +631,26 @@ func (p *Program) Import(pkgpath string) (prog *loader.Program, pkgi *loader.Pac
...
@@ -596,6 +631,26 @@ func (p *Program) Import(pkgpath string) (prog *loader.Program, pkgi *loader.Pac
return
prog
,
pkgi
,
nil
return
prog
,
pkgi
,
nil
}
}
// ImportWithTests imports a package augmented with code from _test.go files +
// imports external test package (if any)
func
(
p
*
Program
)
ImportWithTests
(
pkgpath
string
)
(
prog
*
loader
.
Program
,
pkgi
*
loader
.
PackageInfo
,
xtestPkgi
*
loader
.
PackageInfo
,
err
error
)
{
// XXX always reimporting not to interfere with regular imports
p
.
loaderConf
.
ImportPkgs
=
nil
p
.
loaderConf
.
ImportWithTests
(
pkgpath
)
prog
,
err
=
p
.
loaderConf
.
Load
()
if
err
!=
nil
{
return
nil
,
nil
,
nil
,
err
}
pkgi
=
prog
.
InitialPackages
()[
0
]
if
len
(
prog
.
Created
)
>
0
{
xtestPkgi
=
prog
.
Created
[
0
]
}
return
prog
,
pkgi
,
xtestPkgi
,
nil
}
// tracegen generates code according to tracing directives in a package @ pkgpath
// tracegen generates code according to tracing directives in a package @ pkgpath
//
//
// ctxt is build context for discovering packages
// ctxt is build context for discovering packages
...
@@ -605,7 +660,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
...
@@ -605,7 +660,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
P
:=
NewProgram
(
ctxt
,
cwd
)
P
:=
NewProgram
(
ctxt
,
cwd
)
lprog
,
pkgi
,
err
:=
P
.
Import
(
pkgpath
)
lprog
,
pkgi
,
xtestPkgi
,
err
:=
P
.
ImportWithTests
(
pkgpath
)
if
err
!=
nil
{
if
err
!=
nil
{
return
err
return
err
}
}
...
@@ -627,8 +682,32 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
...
@@ -627,8 +682,32 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
return
err
// XXX err ctx
return
err
// XXX err ctx
}
}
// split everything related to tracing into plain and test (not xtest) packages
testTpkg
:=
tpkg
.
SplitTests
()
err1
:=
tracegen1
(
P
,
tpkg
,
pkgdir
,
""
)
err2
:=
tracegen1
(
P
,
testTpkg
,
pkgdir
,
"_test"
)
var
err3
error
if
xtestPkgi
!=
nil
{
xtestTpkg
,
err
:=
packageTrace
(
lprog
,
xtestPkgi
)
if
err
!=
nil
{
return
err
// XXX err ctx
}
err3
=
tracegen1
(
P
,
xtestTpkg
,
pkgdir
,
"_x_test"
)
}
return
xerr
.
Merge
(
err1
,
err2
,
err3
)
// return xerr.First(err1, err2, err3)
}
func
tracegen1
(
P
*
Program
,
tpkg
*
Package
,
pkgdir
string
,
kind
string
)
error
{
var
err
error
// write ztrace.go with code generated for trace events and imports
// write ztrace.go with code generated for trace events and imports
ztrace_go
:=
filepath
.
Join
(
pkgdir
,
"ztrace.go"
)
ztrace_go
:=
filepath
.
Join
(
pkgdir
,
"ztrace
"
+
kind
+
"
.go"
)
if
len
(
tpkg
.
Eventv
)
==
0
&&
len
(
tpkg
.
Importv
)
==
0
{
if
len
(
tpkg
.
Eventv
)
==
0
&&
len
(
tpkg
.
Importv
)
==
0
{
err
=
removeFile
(
ztrace_go
)
err
=
removeFile
(
ztrace_go
)
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -691,7 +770,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
...
@@ -691,7 +770,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
ImportSpec
*
traceImport
ImportSpec
*
traceImport
ImporterPkg
*
types
.
Package
ImporterPkg
*
types
.
Package
ImportedAs
map
[
string
]
string
ImportedAs
map
[
string
]
string
}
{
event
,
timport
,
p
kgi
.
Pkg
,
importedAs
}
}
{
event
,
timport
,
tpkg
.
P
kgi
.
Pkg
,
importedAs
}
err
=
traceEventImportTmpl
.
Execute
(
text
,
importedEvent
)
err
=
traceEventImportTmpl
.
Execute
(
text
,
importedEvent
)
if
err
!=
nil
{
if
err
!=
nil
{
panic
(
err
)
// XXX
panic
(
err
)
// XXX
...
@@ -702,7 +781,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
...
@@ -702,7 +781,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
// TODO check export hash
// TODO check export hash
// finish prologue with needed imports
// finish prologue with needed imports
needPkg
.
Delete
(
pkgpath
)
// our pkg - no need to import
needPkg
.
Delete
(
tpkg
.
Pkgi
.
Pkg
.
Path
()
)
// our pkg - no need to import
needPkgv
:=
needPkg
.
Itemv
()
needPkgv
:=
needPkg
.
Itemv
()
if
len
(
needPkgv
)
>
0
{
if
len
(
needPkgv
)
>
0
{
prologue
.
emit
(
""
)
prologue
.
emit
(
""
)
...
@@ -726,7 +805,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
...
@@ -726,7 +805,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
}
}
// write empty ztrace.s so go:linkname works, if there are trace imports
// write empty ztrace.s so go:linkname works, if there are trace imports
ztrace_s
:=
filepath
.
Join
(
pkgdir
,
"ztrace.s"
)
ztrace_s
:=
filepath
.
Join
(
pkgdir
,
"ztrace
"
+
kind
+
"
.s"
)
if
len
(
tpkg
.
Importv
)
==
0
{
if
len
(
tpkg
.
Importv
)
==
0
{
err
=
removeFile
(
ztrace_s
)
err
=
removeFile
(
ztrace_s
)
}
else
{
}
else
{
...
@@ -741,7 +820,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
...
@@ -741,7 +820,7 @@ func tracegen(pkgpath string, ctxt *build.Context, cwd string) error {
return
err
return
err
}
}
return
nil
// XXX
return
nil
}
}
func
main
()
{
func
main
()
{
...
...
go/xcommon/tracing/cmd/gotrace/gotrace_test.go
View file @
fc1fa022
...
@@ -137,8 +137,8 @@ func TestGoTraceGen(t *testing.T) {
...
@@ -137,8 +137,8 @@ func TestGoTraceGen(t *testing.T) {
}
}
// XXX autodetect (go list ?)
// XXX autodetect (go list ?)
testv
:=
[]
string
{
"a/pkg1"
,
"b/pkg2"
,
"c/pkg3"
,
"d/pkg4"
}
//
testv := []string{"a/pkg1", "b/pkg2", "c/pkg3", "d/pkg4"}
//testv := []string{"b/pkg2
"}
testv
:=
[]
string
{
"c/pkg3
"
}
for
_
,
tpkg
:=
range
testv
{
for
_
,
tpkg
:=
range
testv
{
err
=
tracegen
(
tpkg
,
tBuildCtx
,
""
/* = local imorts disabled */
)
err
=
tracegen
(
tpkg
,
tBuildCtx
,
""
/* = local imorts disabled */
)
...
...
go/xcommon/tracing/cmd/gotrace/testdata/src/b/pkg2/pkg2.go
View file @
fc1fa022
...
@@ -2,10 +2,7 @@ package pkg2
...
@@ -2,10 +2,7 @@ package pkg2
// trace-import another package
// trace-import another package
// NOTE "a/pkg1" is not regularly imported
// NOTE "a/pkg1" is not regularly imported
////trace:import "a/pkg1"
//trace:import "a/pkg1"
// XXX temp
//trace:import bbb "a/pkg1"
// additional tracepoint which pkg2 defines
// additional tracepoint which pkg2 defines
//trace:event traceDoSomething(i, j int, q string)
//trace:event traceDoSomething(i, j int, q string)
...
...
go/xcommon/tracing/cmd/gotrace/testdata/src/c/pkg3/ztrace_test.s.ok
0 → 100644
View file @
fc1fa022
// Code generated by lab.nexedi.com/kirr/go123/tracing/cmd/gotrace; DO NOT EDIT.
// empty .s so `go build` does not use -complete for go:linkname to work
go/xcommon/tracing/cmd/gotrace/testdata/src/c/pkg3/ztrace_x_test.s.ok
0 → 100644
View file @
fc1fa022
// Code generated by lab.nexedi.com/kirr/go123/tracing/cmd/gotrace; DO NOT EDIT.
// empty .s so `go build` does not use -complete for go:linkname to work
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