????JFIF??x?x????'
| Server IP : 172.67.174.47  /  Your IP : 216.73.216.145 Web Server : LiteSpeed System : Linux premium151.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 User : tempvsty ( 647) PHP Version : 8.0.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /././././proc/thread-self/root/opt/alt/ruby24/lib64/ruby/2.4.0/rubygems/resolver/ | 
| Upload File : | 
# frozen_string_literal: true
##
# A GitSet represents gems that are sourced from git repositories.
#
# This is used for gem dependency file support.
#
# Example:
#
#   set = Gem::Resolver::GitSet.new
#   set.add_git_gem 'rake', 'git://example/rake.git', tag: 'rake-10.1.0'
class Gem::Resolver::GitSet < Gem::Resolver::Set
  ##
  # The root directory for git gems in this set.  This is usually Gem.dir, the
  # installation directory for regular gems.
  attr_accessor :root_dir
  ##
  # Contains repositories needing submodules
  attr_reader :need_submodules # :nodoc:
  ##
  # A Hash containing git gem names for keys and a Hash of repository and
  # git commit reference as values.
  attr_reader :repositories # :nodoc:
  ##
  # A hash of gem names to Gem::Resolver::GitSpecifications
  attr_reader :specs # :nodoc:
  def initialize # :nodoc:
    super()
    @git             = ENV['git'] || 'git'
    @need_submodules = {}
    @repositories    = {}
    @root_dir        = Gem.dir
    @specs           = {}
  end
  def add_git_gem name, repository, reference, submodules # :nodoc:
    @repositories[name] = [repository, reference]
    @need_submodules[repository] = submodules
  end
  ##
  # Adds and returns a GitSpecification with the given +name+ and +version+
  # which came from a +repository+ at the given +reference+.  If +submodules+
  # is true they are checked out along with the repository.
  #
  # This fills in the prefetch information as enough information about the gem
  # is present in the arguments.
  def add_git_spec name, version, repository, reference, submodules # :nodoc:
    add_git_gem name, repository, reference, submodules
    source = Gem::Source::Git.new name, repository, reference
    source.root_dir = @root_dir
    spec = Gem::Specification.new do |s|
      s.name    = name
      s.version = version
    end
    git_spec = Gem::Resolver::GitSpecification.new self, spec, source
    @specs[spec.name] = git_spec
    git_spec
  end
  ##
  # Finds all git gems matching +req+
  def find_all req
    prefetch nil
    specs.values.select do |spec|
      req.match? spec
    end
  end
  ##
  # Prefetches specifications from the git repositories in this set.
  def prefetch reqs
    return unless @specs.empty?
    @repositories.each do |name, (repository, reference)|
      source = Gem::Source::Git.new name, repository, reference
      source.root_dir = @root_dir
      source.remote = @remote
      source.specs.each do |spec|
        git_spec = Gem::Resolver::GitSpecification.new self, spec, source
        @specs[spec.name] = git_spec
      end
    end
  end
  def pretty_print q # :nodoc:
    q.group 2, '[GitSet', ']' do
      next if @repositories.empty?
      q.breakable
      repos = @repositories.map do |name, (repository, reference)|
        "#{name}: #{repository}@#{reference}"
      end
      q.seplist repos do |repo|
        q.text repo
      end
    end
  end
end