Sha256: 7628f1ccf7989d5ba51bf774e7cdd5b11aaf24a96614cffc48a51d2b0a8fd43b
Contents?: true
Size: 756 Bytes
Versions: 1
Compression:
Stored size: 756 Bytes
Contents
require 'tsort' module Dentaku class DependencyResolver include TSort def self.find_resolve_order(vars_to_dependencies_hash, case_sensitive = false) self.new(vars_to_dependencies_hash).sort end def initialize(vars_to_dependencies_hash) @key_mapping = Hash[vars_to_dependencies_hash.keys.map { |k| [k.downcase, k] }] # ensure variables are normalized strings @vars_to_deps = Hash[vars_to_dependencies_hash.map { |k, v| [k.downcase.to_s, v] }] end def sort tsort.map { |k| @key_mapping.fetch(k, k) } end def tsort_each_node(&block) @vars_to_deps.each_key(&block) end def tsort_each_child(node, &block) @vars_to_deps.fetch(node.to_s, []).each(&block) end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
dentaku-3.5.4 | lib/dentaku/dependency_resolver.rb |