Module: SemanticPuppet::Dependency::GraphNode

Includes:
Comparable
Included in:
Graph, ModuleRelease
Defined in:
lib/semantic_puppet/dependency/graph_node.rb

Instance Method Summary collapse

Instance Method Details

#<<(nodes) ⇒ Object



101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 101

def << (nodes)
  Array(nodes).group_by(&:name).each_pair do |name, nodes|
    changed = false
    next unless dependencies.key?(name)

    nodes.each do |node|
      if satisfies_dependency?(node)
        dependencies[name] << node
        changed = true
      end
    end
    dependencies[name].sort! if changed
  end

  return self
end

#<=>(other) ⇒ Object



118
119
120
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 118

def <=>(other)
  name <=> other.name
end

#add_constraint(source, mod, desc) {|node| ... } ⇒ void

This method returns an undefined value.

Constrains the named module to suitable releases, as determined by the given block.

Examples:

Version-locking currently installed modules

installed_modules.each do |m|
  @graph.add_constraint('installed', m.name, m.version) do |node|
    m.version == node.version
  end
end

Parameters:

  • source (String, Symbol)

    a name describing the source of the constraint

  • mod (String)

    the name of the module

  • desc (String)

    a description of the enforced constraint

Yield Parameters:

  • node (GraphNode)

    the node to test the constraint against

Yield Returns:

  • (Boolean)

    whether the node passed the constraint



88
89
90
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 88

def add_constraint(source, mod, desc, &block)
  constraints["#{mod}"] << [ source, desc, block ]
end

#add_dependency(name) ⇒ void

This method returns an undefined value.

Adds the given dependency name to the list of dependencies.

Parameters:

  • name (String)

    the dependency name



46
47
48
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 46

def add_dependency(name)
  dependencies[name]
end

#childrenObject



20
21
22
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 20

def children
  @_children ||= {}
end

#constraintsObject



55
56
57
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 55

def constraints
  @_constraints ||= Hash.new { |h, k| h[k] = [] }
end

#constraints_for(name) ⇒ Object



59
60
61
62
63
64
65
66
67
68
69
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 59

def constraints_for(name)
  return [] unless constraints.has_key?(name)

  constraints[name].map do |constraint|
    {
      :source      => constraint[0],
      :description => constraint[1],
      :test        => constraint[2],
    }
  end
end

#dependencies{ String => Array<GraphNode> }

Returns the satisfactory dependency nodes.

Returns:

  • ({ String => Array<GraphNode> })

    the satisfactory dependency nodes



38
39
40
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 38

def dependencies
  @_dependencies ||= Hash.new { |h, k| h[k] = Array.new }
end

#dependency_namesArray<String>

Returns the list of dependency names.

Returns:

  • (Array<String>)

    the list of dependency names



51
52
53
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 51

def dependency_names
  dependencies.keys
end

#nameObject



9
10
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 9

def name
end

#populate_children(nodes) ⇒ Object



24
25
26
27
28
29
30
31
32
33
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 24

def populate_children(nodes)
  if children.empty?
    nodes = nodes.select { |node| satisfies_dependency?(node) }
    nodes.each do |node|
      children[node.name] = node
      node.populate_children(nodes)
    end
    self.freeze
  end
end

#satisfied?Boolean

Determines whether the modules dependencies are satisfied by the known releases.

Returns:

  • (Boolean)

    true if all dependencies are satisfied



16
17
18
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 16

def satisfied?
  dependencies.none? { |_, v| v.empty? }
end

#satisfies_constraints?(release) ⇒ Boolean

Parameters:

Returns:

  • (Boolean)


97
98
99
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 97

def satisfies_constraints?(release)
  constraints_for(release.name).all? { |x| x[:test].call(release) }
end

#satisfies_dependency?(node) ⇒ Boolean

Returns:

  • (Boolean)


92
93
94
# File 'lib/semantic_puppet/dependency/graph_node.rb', line 92

def satisfies_dependency?(node)
  dependencies.key?(node.name) && satisfies_constraints?(node)
end