mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
5c52ff49e0
Remove the need for the wait group and avoid new locks Added utility to print the method name and the caller name Signed-off-by: Flavio Crisciani <flavio.crisciani@docker.com>
29 lines
560 B
Go
29 lines
560 B
Go
package common
|
|
|
|
import (
|
|
"runtime"
|
|
"strings"
|
|
)
|
|
|
|
func callerInfo(i int) string {
|
|
ptr, _, _, ok := runtime.Caller(i)
|
|
fName := "unknown"
|
|
if ok {
|
|
f := runtime.FuncForPC(ptr)
|
|
if f != nil {
|
|
// f.Name() is like: github.com/docker/libnetwork/common.MethodName
|
|
tmp := strings.Split(f.Name(), ".")
|
|
if len(tmp) > 0 {
|
|
fName = tmp[len(tmp)-1]
|
|
}
|
|
}
|
|
}
|
|
|
|
return fName
|
|
}
|
|
|
|
// CallerName returns the name of the function at the specified level
|
|
// level == 0 means current method name
|
|
func CallerName(level int) string {
|
|
return callerInfo(2 + level)
|
|
}
|