forked from dstepanov-yadro/log-export
export logs by function name and args
This commit is contained in:
parent
2a1c8e4980
commit
e232bfeef4
4 changed files with 113 additions and 0 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -17,6 +17,8 @@
|
||||||
|
|
||||||
# Dependency directories (remove the comment below to include it)
|
# Dependency directories (remove the comment below to include it)
|
||||||
# vendor/
|
# vendor/
|
||||||
|
.vscode
|
||||||
|
bin/
|
||||||
|
|
||||||
# Go workspace file
|
# Go workspace file
|
||||||
go.work
|
go.work
|
||||||
|
|
5
Makefile
Normal file
5
Makefile
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
#!/usr/bin/make -f
|
||||||
|
SHELL = bash
|
||||||
|
|
||||||
|
build:
|
||||||
|
CGO_ENABLED=0 go build -v -trimpath -o ./bin/log-export ./cmd/main.go
|
103
cmd/main.go
Normal file
103
cmd/main.go
Normal file
|
@ -0,0 +1,103 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"go/ast"
|
||||||
|
"go/parser"
|
||||||
|
"go/token"
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
if len(os.Args) != 2 {
|
||||||
|
log.Fatalln("directory must be provided")
|
||||||
|
}
|
||||||
|
|
||||||
|
directories, err := getAllSubdirectories(os.Args[1])
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("failed to list subdirs: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, dir := range directories {
|
||||||
|
fset := token.NewFileSet()
|
||||||
|
packages, err := parser.ParseDir(fset, dir, nil, 0)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("failed to parse directory %s: %v", dir, err)
|
||||||
|
}
|
||||||
|
for _, p := range packages {
|
||||||
|
for _, f := range p.Files {
|
||||||
|
ast.Inspect(f, func(n ast.Node) bool {
|
||||||
|
expr, ok := n.(*ast.CallExpr)
|
||||||
|
if !ok {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
if isLogDot(expr.Fun) && len(expr.Args) > 0 && isStringValue(expr.Args[0]) {
|
||||||
|
position := fset.Position(expr.Pos())
|
||||||
|
fmt.Printf("%v %s\n", position, stringValue(expr.Args[0]))
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func getAllSubdirectories(dir string) ([]string, error) {
|
||||||
|
result := make([]string, 0)
|
||||||
|
|
||||||
|
stack := make([]string, 0)
|
||||||
|
stack = append(stack, dir)
|
||||||
|
|
||||||
|
for len(stack) > 0 {
|
||||||
|
current := stack[len(stack)-1]
|
||||||
|
stack = stack[:len(stack)-1]
|
||||||
|
|
||||||
|
entities, err := os.ReadDir(current)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, e := range entities {
|
||||||
|
if e.IsDir() {
|
||||||
|
path := filepath.Join(current, e.Name())
|
||||||
|
result = append(result, path)
|
||||||
|
stack = append(stack, path)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return result, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func isLogDot(expr ast.Expr) bool {
|
||||||
|
sel, ok := expr.(*ast.SelectorExpr)
|
||||||
|
return ok && (isIdent(sel.Sel, "Debug") ||
|
||||||
|
isIdent(sel.Sel, "Info") ||
|
||||||
|
isIdent(sel.Sel, "Warn") ||
|
||||||
|
isIdent(sel.Sel, "Error"))
|
||||||
|
}
|
||||||
|
|
||||||
|
func isIdent(expr ast.Expr, ident string) bool {
|
||||||
|
id, ok := expr.(*ast.Ident)
|
||||||
|
if !ok {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if id.Name == ident {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func isStringValue(expr ast.Expr) bool {
|
||||||
|
basicLit, ok := expr.(*ast.BasicLit)
|
||||||
|
return ok && basicLit.Kind == token.STRING
|
||||||
|
}
|
||||||
|
|
||||||
|
func stringValue(expr ast.Expr) string {
|
||||||
|
basicLit, _ := expr.(*ast.BasicLit)
|
||||||
|
return basicLit.Value
|
||||||
|
}
|
3
go.mod
Normal file
3
go.mod
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
module git.frostfs.info/dstepanov-yadro/log-export
|
||||||
|
|
||||||
|
go 1.20
|
Loading…
Reference in a new issue