Module: SemanticPuppet::Dependency
- Extended by:
- Dependency
- Included in:
- Dependency
- Defined in:
- lib/semantic_puppet/dependency.rb,
lib/semantic_puppet/dependency/graph.rb,
lib/semantic_puppet/dependency/source.rb,
lib/semantic_puppet/dependency/graph_node.rb,
lib/semantic_puppet/dependency/module_release.rb,
lib/semantic_puppet/dependency/unsatisfiable_graph.rb
Defined Under Namespace
Modules: GraphNode Classes: Graph, ModuleRelease, Source, UnsatisfiableGraph
Sources collapse
-
#add_source(source) ⇒ void
Appends a new Source to the current list.
-
#clear_sources ⇒ void
Clears the current list of Sources.
-
#sources ⇒ Array<Source>
A frozen copy of the Source list.
Instance Method Summary collapse
-
#fetch_releases(name) ⇒ Array<ModuleRelease>
Fetches all available releases for the given module name.
-
#query(modules) ⇒ Graph
Fetches a graph of modules and their dependencies from the currently configured list of Sources.
-
#resolve(graph) ⇒ Array<ModuleRelease>
Given a graph result from #query, this method will resolve the graph of dependencies, if possible, into a flat list of the best suited modules.
-
#unsatisfiable ⇒ Object
Returns the unsatisfiable dependency, if any.
Instance Method Details
#add_source(source) ⇒ void
This method returns an undefined value.
Appends a new Source to the current list.
24 25 26 27 28 |
# File 'lib/semantic_puppet/dependency.rb', line 24 def add_source(source) sources @sources << source nil end |
#clear_sources ⇒ void
This method returns an undefined value.
Clears the current list of Sources.
32 33 34 35 36 |
# File 'lib/semantic_puppet/dependency.rb', line 32 def clear_sources sources @sources.clear nil end |
#fetch_releases(name) ⇒ Array<ModuleRelease>
Fetches all available releases for the given module name.
88 89 90 91 92 93 94 95 96 97 98 |
# File 'lib/semantic_puppet/dependency.rb', line 88 def fetch_releases(name) releases = {} sources.each do |source| source.fetch(name).each do |dependency| releases[dependency.version] ||= dependency end end return releases.values end |
#query(modules) ⇒ Graph
Return a specialized "Graph" object.
Allow for external constraints to be added to the graph.
Fetches a graph of modules and their dependencies from the currently configured list of Sources.
60 61 62 63 64 65 66 |
# File 'lib/semantic_puppet/dependency.rb', line 60 def query(modules) constraints = Hash[modules.map { |k, v| [ k, VersionRange.parse(v) ] }] graph = Graph.new(constraints) fetch_dependencies(graph) return graph end |
#resolve(graph) ⇒ Array<ModuleRelease>
Given a graph result from #query, this method will resolve the graph of dependencies, if possible, into a flat list of the best suited modules. If the dependency graph does not have a suitable resolution, this method will raise an exception to that effect.
75 76 77 78 79 80 81 82 |
# File 'lib/semantic_puppet/dependency.rb', line 75 def resolve(graph) @module_dependencies = @satisfieds = nil catch :next do return walk(graph, graph.dependencies.dup) end raise UnsatisfiableGraph.new(graph, unsatisfiable) end |
#sources ⇒ Array<Source>
Returns a frozen copy of the Source list.
17 18 19 |
# File 'lib/semantic_puppet/dependency.rb', line 17 def sources (@sources ||= []).dup.freeze end |
#unsatisfiable ⇒ Object
Returns the unsatisfiable dependency, if any.
42 43 44 45 46 47 |
# File 'lib/semantic_puppet/dependency.rb', line 42 def unsatisfiable @module_dependencies ||= [] @satisfieds ||= [] (@module_dependencies - @satisfieds).first end |