Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type DependencyGraph ¶
type DependencyGraph struct {
// contains filtered or unexported fields
}
DependencyGraph represents a dependency graph encoded within a resource snapshot.
func NewDependencyGraph ¶
func NewDependencyGraph(resources []*resource.State) *DependencyGraph
NewDependencyGraph creates a new DependencyGraph from a list of resources. The resources should be in topological order with respect to their dependencies.
func (*DependencyGraph) DependenciesOf ¶
func (dg *DependencyGraph) DependenciesOf(res *resource.State) ResourceSet
DependenciesOf returns a ResourceSet of resources upon which the given resource depends. The resource's parent is included in the returned set.
func (*DependencyGraph) DependingOn ¶
func (dg *DependencyGraph) DependingOn(res *resource.State) []*resource.State
DependingOn returns a slice containing all resources that directly or indirectly depend upon the given resource. The returned slice is guaranteed to be in topological order with respect to the snapshot dependency graph.
The time complexity of DependingOn is linear with respect to the number of resources.
type ResourceSet ¶
ResourceSet represents a set of Resources.
func (ResourceSet) Intersect ¶
func (s ResourceSet) Intersect(other ResourceSet) ResourceSet
Intersect returns a new set that is the intersection of the two given resource sets.