Commit fce7640c authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 85fdae69
...@@ -21,11 +21,11 @@ ...@@ -21,11 +21,11 @@
package task package task
import ( import (
"context" "context"
"fmt" "fmt"
taskctx "lab.nexedi.com/kirr/neo/go/internal/xcontext/task" taskctx "lab.nexedi.com/kirr/neo/go/internal/xcontext/task"
"lab.nexedi.com/kirr/neo/go/internal/log" "lab.nexedi.com/kirr/neo/go/internal/log"
) )
// Running is syntactic sugar to push new task to operational stack, log it and // Running is syntactic sugar to push new task to operational stack, log it and
...@@ -35,34 +35,28 @@ import ( ...@@ -35,34 +35,28 @@ import (
// //
// defer task.Running(&ctx, "my task")(&err) // defer task.Running(&ctx, "my task")(&err)
func Running(ctxp *context.Context, name string) func(*error) { func Running(ctxp *context.Context, name string) func(*error) {
return running(ctxp, name) return running(ctxp, name)
} }
// Runningf is Running cousin with formatting support // Runningf is Running cousin with formatting support
func Runningf(ctxp *context.Context, format string, argv ...interface{}) func(*error) { func Runningf(ctxp *context.Context, format string, argv ...interface{}) func(*error) {
return running(ctxp, fmt.Sprintf(format, argv...)) return running(ctxp, fmt.Sprintf(format, argv...))
} }
func running(ctxp *context.Context, name string) func(*error) { func running(ctxp *context.Context, name string) func(*error) {
ctx := taskctx.Running(*ctxp, name) ctx := taskctx.Running(*ctxp, name)
*ctxp = ctx *ctxp = ctx
log.Depth(2).Info(ctx, "start") // XXX log -> trace log.Depth(2).Info(ctx, "[") // XXX log -> trace, don't put ":" before "["
return func(errp *error) { return func(errp *error) {
if *errp != nil { err := ""
// XXX is it good idea to log to error here? (not in above layer) if e := *errp; e != nil {
// XXX what is error here could be not so error above err = fmt.Sprintf(" (%s)", e)
// XXX or we still want to log all errors - right? }
// log.Depth(1).Info(ctx, "]" + err) // XXX log -> trace, don't put ":" before "]"
// -> yes, we do want to trace unconditionally when a task is finished
// here it is tracing, just with trace sink being hardcoded to log. // NOTE not *ctxp here - as context pointed by ctxp could be
log.Depth(1).Warning(ctx, "## ", *errp) // XXX "##" temp // changed when this deferred function is run
} else { taskctx.ErrContext(errp, ctx)
log.Depth(1).Info(ctx, "done") }
}
// NOTE not *ctxp here - as context pointed by ctxp could be
// changed when this deferred function is run
taskctx.ErrContext(errp, ctx)
}
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment