graph

package
v0.15.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 14, 2018 License: Apache-2.0 Imports: 1 Imported by: 0

Documentation

Overview

Package graph defines resource graphs. Each graph is directed and acyclic, and the nodes have been topologically sorted based on dependencies (edges) between them. Each node in the graph has a type and a set of properties.

There are two forms of graph: complete and incomplete. A complete graph is one in which all nodes and their property values are known. An incomplete graph is one where two uncertainties may arise: (1) an edge might be "conditional", indicating that its presence or absence is dependent on a piece of information not yet available (like an output property from a resource), and/or (2) a property may either be similarly conditional or computed as an output value.

In general, programs may be evaluated to produce graphs. These may then be compared to other graphs to produce and/or carry out deployment plans. This package therefore also exposes operations necessary for diffing graphs.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Edge

type Edge interface {
	Data() interface{} // arbitrary data associated with this edge.
	Label() string     // this edge's label.
	To() Vertex        // the vertex this edge connects to.
	From() Vertex      // the vertex this edge connects from.
	Color() string     // an optional color for this edge, for when this graph is displayed.
}

Edge is a directed edge from one vertex to another.

type Graph

type Graph interface {
	Roots() []Edge // the root edges.
}

Graph is an instance of a resource digraph. Each is associated with a single program input, along with a set of optional arguments used to evaluate it, along with the output DAG with node types and properties.

type Vertex

type Vertex interface {
	Data() interface{} // arbitrary data associated with this vertex.
	Label() string     // the vertex's label.
	Ins() []Edge       // incoming edges from other vertices within the graph to this vertex.
	Outs() []Edge      // outgoing edges from this vertex to other vertices within the graph.
}

Vertex is a single vertex within an overall resource graph.

func Topsort

func Topsort(g Graph) ([]Vertex, error)

Topsort topologically sorts the graph, yielding an array of nodes that are in dependency order, using a simple DFS-based algorithm. The graph must be acyclic, otherwise this function will return an error.

Directories

Path Synopsis
Package dotconv converts a resource graph into its DOT digraph equivalent.
Package dotconv converts a resource graph into its DOT digraph equivalent.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL