mirror of
https://github.com/mjl-/mox.git
synced 2025-01-28 07:15:55 +03:00
5817e87a32
so mox doesn't have to be running when you run it. will be useful for testing in the near future. this also moves cpuprof and memprof cli flags to top-level flag parsing, so all commands can use them.
45 lines
840 B
Go
45 lines
840 B
Go
package main
|
|
|
|
import (
|
|
"log"
|
|
"os"
|
|
"runtime"
|
|
"runtime/pprof"
|
|
)
|
|
|
|
func memprofile(mempath string) {
|
|
if mempath == "" {
|
|
return
|
|
}
|
|
|
|
f, err := os.Create(mempath)
|
|
xcheckf(err, "creating memory profile")
|
|
defer func() {
|
|
if err := f.Close(); err != nil {
|
|
log.Printf("closing memory profile: %v", err)
|
|
}
|
|
}()
|
|
runtime.GC() // get up-to-date statistics
|
|
err = pprof.WriteHeapProfile(f)
|
|
xcheckf(err, "writing memory profile")
|
|
}
|
|
|
|
func profile(cpupath, mempath string) func() {
|
|
if cpupath == "" {
|
|
return func() {
|
|
memprofile(mempath)
|
|
}
|
|
}
|
|
|
|
f, err := os.Create(cpupath)
|
|
xcheckf(err, "creating CPU profile")
|
|
err = pprof.StartCPUProfile(f)
|
|
xcheckf(err, "start CPU profile")
|
|
return func() {
|
|
pprof.StopCPUProfile()
|
|
if err := f.Close(); err != nil {
|
|
log.Printf("closing cpu profile: %v", err)
|
|
}
|
|
memprofile(mempath)
|
|
}
|
|
}
|