class Bundler::PubGrub::Strategy

def initialize(source)

def initialize(source)
  @source = source
  @root_package = Package.root
  @root_version = Package.root_version
  @version_indexes = Hash.new do |h,k|
    if k == @root_package
      h[k] = { @root_version => 0 }
    else
      h[k] = @source.all_versions_for(k).each.with_index.to_h
    end
  end
end

def most_preferred_version_of(package, range)

def most_preferred_version_of(package, range)
  versions = @source.versions_for(package, range)
  indexes = @version_indexes[package]
  versions.min_by { |version| indexes[version] }
end

def next_package_and_version(unsatisfied)

def next_package_and_version(unsatisfied)
  package, range = next_term_to_try_from(unsatisfied)
  [package, most_preferred_version_of(package, range)]
end

def next_term_to_try_from(unsatisfied)

def next_term_to_try_from(unsatisfied)
  unsatisfied.min_by do |package, range|
    matching_versions = @source.versions_for(package, range)
    higher_versions = @source.versions_for(package, range.upper_invert)
    [matching_versions.count <= 1 ? 0 : 1, higher_versions.count]
  end
end