/
task3.go
76 lines (61 loc) · 1.37 KB
/
task3.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// Copyright ©2017 The go-hep Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package main
import (
"reflect"
"go-hep.org/x/hep/fads"
"go-hep.org/x/hep/fwk"
)
type task3 struct {
fwk.TaskBase
parts string
}
func (tsk *task3) Configure(ctx fwk.Context) error {
var err error
msg := ctx.Msg()
msg.Infof("configure...\n")
msg.Infof("configure... [done]\n")
return err
}
func (tsk *task3) StartTask(ctx fwk.Context) error {
msg := ctx.Msg()
msg.Infof("start...\n")
return nil
}
func (tsk *task3) StopTask(ctx fwk.Context) error {
msg := ctx.Msg()
msg.Infof("stop...\n")
return nil
}
func (tsk *task3) Process(ctx fwk.Context) error {
msg := ctx.Msg()
msg.Infof("proc...\n")
store := ctx.Store()
parts := make([]fads.Candidate, 0)
err := store.Put(tsk.parts, parts)
if err != nil {
return err
}
return nil
}
func init() {
fwk.Register(reflect.TypeOf(task3{}),
func(typ, name string, mgr fwk.App) (fwk.Component, error) {
var err error
tsk := &task3{
TaskBase: fwk.NewTask(typ, name, mgr),
parts: "/fads/test/StableParticles",
}
err = tsk.DeclProp("Output", &tsk.parts)
if err != nil {
return nil, err
}
err = tsk.DeclOutPort(tsk.parts, reflect.TypeOf([]fads.Candidate{}))
if err != nil {
return nil, err
}
return tsk, err
},
)
}