X7ROOT File Manager
Current Path:
/opt/alt/ruby23/lib64/ruby/2.3.0/rubygems
opt
/
alt
/
ruby23
/
lib64
/
ruby
/
2.3.0
/
rubygems
/
ðŸ“
..
📄
available_set.rb
(3.02 KB)
📄
basic_specification.rb
(7.23 KB)
📄
command.rb
(13.68 KB)
📄
command_manager.rb
(4.66 KB)
ðŸ“
commands
📄
compatibility.rb
(1.66 KB)
📄
config_file.rb
(12.66 KB)
ðŸ“
core_ext
📄
defaults.rb
(4.04 KB)
📄
dependency.rb
(8.55 KB)
📄
dependency_installer.rb
(14.07 KB)
📄
dependency_list.rb
(5.56 KB)
📄
deprecate.rb
(1.73 KB)
📄
doctor.rb
(3.06 KB)
📄
errors.rb
(3.15 KB)
📄
exceptions.rb
(6.23 KB)
ðŸ“
ext
📄
ext.rb
(461 B)
📄
gem_runner.rb
(1.99 KB)
📄
gemcutter_utilities.rb
(4.15 KB)
📄
indexer.rb
(11.04 KB)
📄
install_default_message.rb
(337 B)
📄
install_message.rb
(311 B)
📄
install_update_options.rb
(6.06 KB)
📄
installer.rb
(23.49 KB)
📄
installer_test_case.rb
(4.26 KB)
📄
local_remote_options.rb
(3.4 KB)
📄
mock_gem_ui.rb
(1.38 KB)
📄
name_tuple.rb
(2.41 KB)
ðŸ“
package
📄
package.rb
(15.99 KB)
📄
package_task.rb
(3.8 KB)
📄
path_support.rb
(1.93 KB)
📄
platform.rb
(6.26 KB)
📄
psych_additions.rb
(300 B)
📄
psych_tree.rb
(793 B)
📄
rdoc.rb
(7.74 KB)
📄
remote_fetcher.rb
(11.62 KB)
ðŸ“
request
📄
request.rb
(6.89 KB)
ðŸ“
request_set
📄
request_set.rb
(9.74 KB)
📄
requirement.rb
(6.52 KB)
ðŸ“
resolver
📄
resolver.rb
(7.75 KB)
📄
safe_yaml.rb
(1.11 KB)
ðŸ“
security
📄
security.rb
(21 KB)
📄
server.rb
(22.96 KB)
ðŸ“
source
📄
source.rb
(5.24 KB)
📄
source_list.rb
(2.5 KB)
📄
source_local.rb
(141 B)
📄
source_specific_file.rb
(123 B)
📄
spec_fetcher.rb
(6.34 KB)
📄
specification.rb
(80.27 KB)
ðŸ“
ssl_certs
📄
stub_specification.rb
(4.66 KB)
📄
syck_hack.rb
(2.12 KB)
📄
test_case.rb
(39.35 KB)
📄
test_utilities.rb
(8.63 KB)
📄
text.rb
(1.88 KB)
📄
uninstaller.rb
(8.74 KB)
📄
uri_formatter.rb
(792 B)
📄
user_interaction.rb
(14.48 KB)
ðŸ“
util
📄
util.rb
(2.6 KB)
📄
validator.rb
(4.21 KB)
📄
version.rb
(11.26 KB)
📄
version_option.rb
(1.86 KB)
Editing: resolver.rb
# frozen_string_literal: true require 'rubygems/dependency' require 'rubygems/exceptions' require 'rubygems/util' require 'rubygems/util/list' require 'uri' require 'net/http' ## # Given a set of Gem::Dependency objects as +needed+ and a way to query the # set of available specs via +set+, calculates a set of ActivationRequest # objects which indicate all the specs that should be activated to meet the # all the requirements. class Gem::Resolver require 'rubygems/resolver/molinillo' ## # If the DEBUG_RESOLVER environment variable is set then debugging mode is # enabled for the resolver. This will display information about the state # of the resolver while a set of dependencies is being resolved. DEBUG_RESOLVER = !ENV['DEBUG_RESOLVER'].nil? ## # Set to true if all development dependencies should be considered. attr_accessor :development ## # Set to true if immediate development dependencies should be considered. attr_accessor :development_shallow ## # When true, no dependencies are looked up for requested gems. attr_accessor :ignore_dependencies ## # List of dependencies that could not be found in the configured sources. attr_reader :missing attr_reader :stats ## # Hash of gems to skip resolution. Keyed by gem name, with arrays of # gem specifications as values. attr_accessor :skip_gems ## # When a missing dependency, don't stop. Just go on and record what was # missing. attr_accessor :soft_missing ## # Combines +sets+ into a ComposedSet that allows specification lookup in a # uniform manner. If one of the +sets+ is itself a ComposedSet its sets are # flattened into the result ComposedSet. def self.compose_sets *sets sets.compact! sets = sets.map do |set| case set when Gem::Resolver::BestSet then set when Gem::Resolver::ComposedSet then set.sets else set end end.flatten case sets.length when 0 then raise ArgumentError, 'one set in the composition must be non-nil' when 1 then sets.first else Gem::Resolver::ComposedSet.new(*sets) end end ## # Creates a Resolver that queries only against the already installed gems # for the +needed+ dependencies. def self.for_current_gems needed new needed, Gem::Resolver::CurrentSet.new end ## # Create Resolver object which will resolve the tree starting # with +needed+ Dependency objects. # # +set+ is an object that provides where to look for specifications to # satisfy the Dependencies. This defaults to IndexSet, which will query # rubygems.org. def initialize needed, set = nil @set = set || Gem::Resolver::IndexSet.new @needed = needed @development = false @development_shallow = false @ignore_dependencies = false @missing = [] @skip_gems = {} @soft_missing = false @stats = Gem::Resolver::Stats.new end def explain stage, *data # :nodoc: return unless DEBUG_RESOLVER d = data.map { |x| x.pretty_inspect }.join(", ") $stderr.printf "%10s %s\n", stage.to_s.upcase, d end def explain_list stage # :nodoc: return unless DEBUG_RESOLVER data = yield $stderr.printf "%10s (%d entries)\n", stage.to_s.upcase, data.size PP.pp data, $stderr unless data.empty? end ## # Creates an ActivationRequest for the given +dep+ and the last +possible+ # specification. # # Returns the Specification and the ActivationRequest def activation_request dep, possible # :nodoc: spec = possible.pop explain :activate, [spec.full_name, possible.size] explain :possible, possible activation_request = Gem::Resolver::ActivationRequest.new spec, dep, possible return spec, activation_request end def requests s, act, reqs=[] # :nodoc: return reqs if @ignore_dependencies s.fetch_development_dependencies if @development s.dependencies.reverse_each do |d| next if d.type == :development and not @development next if d.type == :development and @development_shallow and act.development? next if d.type == :development and @development_shallow and act.parent reqs << Gem::Resolver::DependencyRequest.new(d, act) @stats.requirement! end @set.prefetch reqs @stats.record_requirements reqs reqs end include Molinillo::UI def output @output ||= debug? ? $stdout : File.open(Gem::Util::NULL_DEVICE, 'w') end def debug? DEBUG_RESOLVER end include Molinillo::SpecificationProvider ## # Proceed with resolution! Returns an array of ActivationRequest objects. def resolve locking_dg = Molinillo::DependencyGraph.new Molinillo::Resolver.new(self, self).resolve(@needed.map { |d| DependencyRequest.new d, nil }, locking_dg).tsort.map(&:payload).compact rescue Molinillo::VersionConflict => e conflict = e.conflicts.values.first raise Gem::DependencyResolutionError, Conflict.new(conflict.requirement_trees.first.first, conflict.existing, conflict.requirement) ensure @output.close if @output and !debug? end ## # Extracts the specifications that may be able to fulfill +dependency+ and # returns those that match the local platform and all those that match. def find_possible dependency # :nodoc: all = @set.find_all dependency if (skip_dep_gems = skip_gems[dependency.name]) && !skip_dep_gems.empty? matching = all.select do |api_spec| skip_dep_gems.any? { |s| api_spec.version == s.version } end all = matching unless matching.empty? end matching_platform = select_local_platforms all return matching_platform, all end ## # Returns the gems in +specs+ that match the local platform. def select_local_platforms specs # :nodoc: specs.select do |spec| Gem::Platform.installable? spec end end def search_for(dependency) possibles, all = find_possible(dependency) if !@soft_missing && possibles.empty? @missing << dependency exc = Gem::UnsatisfiableDependencyError.new dependency, all exc.errors = @set.errors raise exc end possibles.sort_by { |s| [s.source, s.version, s.platform.to_s == Gem::Platform.local.to_s ? 1 : 0] }. map { |s| ActivationRequest.new s, dependency, [] } end def dependencies_for(specification) return [] if @ignore_dependencies spec = specification.spec requests(spec, specification) end def requirement_satisfied_by?(requirement, activated, spec) requirement.matches_spec? spec end def name_for(dependency) dependency.name end def allow_missing?(dependency) @missing << dependency @soft_missing end end ## # TODO remove in RubyGems 3 Gem::DependencyResolver = Gem::Resolver # :nodoc: require 'rubygems/resolver/activation_request' require 'rubygems/resolver/conflict' require 'rubygems/resolver/dependency_request' require 'rubygems/resolver/requirement_list' require 'rubygems/resolver/stats' require 'rubygems/resolver/set' require 'rubygems/resolver/api_set' require 'rubygems/resolver/composed_set' require 'rubygems/resolver/best_set' require 'rubygems/resolver/current_set' require 'rubygems/resolver/git_set' require 'rubygems/resolver/index_set' require 'rubygems/resolver/installer_set' require 'rubygems/resolver/lock_set' require 'rubygems/resolver/vendor_set' require 'rubygems/resolver/source_set' require 'rubygems/resolver/specification' require 'rubygems/resolver/spec_specification' require 'rubygems/resolver/api_specification' require 'rubygems/resolver/git_specification' require 'rubygems/resolver/index_specification' require 'rubygems/resolver/installed_specification' require 'rubygems/resolver/local_specification' require 'rubygems/resolver/lock_specification' require 'rubygems/resolver/vendor_specification'
Upload File
Create Folder