mirror of
https://github.com/weaveworks/scope.git
synced 2026-03-04 18:51:17 +00:00
Prefer WalkTopologies to apply a uniform action to every topology, reducing need to make multiple changes and risk of errors if you forget one.
26 lines
594 B
Go
26 lines
594 B
Go
package probe
|
|
|
|
import (
|
|
"github.com/weaveworks/scope/report"
|
|
)
|
|
|
|
type topologyTagger struct{}
|
|
|
|
// NewTopologyTagger tags each node with the topology that it comes from. It's
|
|
// kind of a proof-of-concept tagger, useful primarily for debugging.
|
|
func NewTopologyTagger() Tagger {
|
|
return &topologyTagger{}
|
|
}
|
|
|
|
func (topologyTagger) Name() string { return "Topology" }
|
|
|
|
// Tag implements Tagger
|
|
func (topologyTagger) Tag(r report.Report) (report.Report, error) {
|
|
for name, t := range r.TopologyMap() {
|
|
for _, node := range t.Nodes {
|
|
t.AddNode(node.WithTopology(name))
|
|
}
|
|
}
|
|
return r, nil
|
|
}
|