X7ROOT File Manager
Current Path:
/opt/alt/ruby32/share/rubygems/rubygems
opt
/
alt
/
ruby32
/
share
/
rubygems
/
rubygems
/
ðŸ“
..
📄
available_set.rb
(3.01 KB)
📄
basic_specification.rb
(7.65 KB)
📄
bundler_version_finder.rb
(1.96 KB)
📄
command.rb
(16.08 KB)
📄
command_manager.rb
(5.59 KB)
ðŸ“
commands
📄
compatibility.rb
(1 KB)
📄
config_file.rb
(14.03 KB)
ðŸ“
core_ext
ðŸ“
defaults
📄
defaults.rb
(6.96 KB)
📄
dependency.rb
(8.65 KB)
📄
dependency_installer.rb
(10.02 KB)
📄
dependency_list.rb
(5.54 KB)
📄
deprecate.rb
(4.89 KB)
📄
doctor.rb
(3.13 KB)
📄
errors.rb
(4.53 KB)
📄
exceptions.rb
(7.34 KB)
ðŸ“
ext
📄
ext.rb
(498 B)
📄
gem_runner.rb
(1.8 KB)
ðŸ“
gemcutter_utilities
📄
gemcutter_utilities.rb
(10.54 KB)
📄
indexer.rb
(10.91 KB)
📄
install_default_message.rb
(349 B)
📄
install_message.rb
(323 B)
📄
install_update_options.rb
(6.35 KB)
📄
installer.rb
(27.23 KB)
📄
installer_uninstaller_utils.rb
(773 B)
📄
local_remote_options.rb
(3.56 KB)
📄
mock_gem_ui.rb
(1.38 KB)
📄
name_tuple.rb
(2.39 KB)
📄
openssl.rb
(125 B)
ðŸ“
optparse
📄
optparse.rb
(72 B)
ðŸ“
package
📄
package.rb
(17.7 KB)
📄
package_task.rb
(3.79 KB)
📄
path_support.rb
(1.79 KB)
📄
platform.rb
(7.48 KB)
📄
psych_tree.rb
(795 B)
📄
query_utils.rb
(8.5 KB)
📄
rdoc.rb
(232 B)
📄
remote_fetcher.rb
(9.2 KB)
ðŸ“
request
📄
request.rb
(8.6 KB)
ðŸ“
request_set
📄
request_set.rb
(11.31 KB)
📄
requirement.rb
(6.89 KB)
ðŸ“
resolver
📄
resolver.rb
(9.64 KB)
📄
s3_uri_signer.rb
(5.92 KB)
📄
safe_yaml.rb
(1.54 KB)
ðŸ“
security
📄
security.rb
(21.95 KB)
📄
security_option.rb
(1.06 KB)
📄
shellwords.rb
(66 B)
ðŸ“
source
📄
source.rb
(5.58 KB)
📄
source_list.rb
(2.41 KB)
📄
spec_fetcher.rb
(6.36 KB)
📄
specification.rb
(70.45 KB)
📄
specification_policy.rb
(13.79 KB)
ðŸ“
ssl_certs
📄
stub_specification.rb
(4.46 KB)
📄
text.rb
(2.07 KB)
ðŸ“
tsort
📄
tsort.rb
(66 B)
📄
uninstaller.rb
(10.2 KB)
📄
unknown_command_spell_checker.rb
(411 B)
📄
update_suggestion.rb
(2.26 KB)
📄
uri.rb
(2.33 KB)
📄
uri_formatter.rb
(781 B)
📄
user_interaction.rb
(13.04 KB)
ðŸ“
util
📄
util.rb
(2.41 KB)
📄
validator.rb
(3.66 KB)
📄
version.rb
(12.57 KB)
📄
version_option.rb
(2.21 KB)
Editing: dependency_list.rb
# frozen_string_literal: true #-- # Copyright 2006 by Chad Fowler, Rich Kilmer, Jim Weirich and others. # All rights reserved. # See LICENSE.txt for permissions. #++ require_relative "tsort" require_relative "deprecate" ## # Gem::DependencyList is used for installing and uninstalling gems in the # correct order to avoid conflicts. #-- # TODO: It appears that all but topo-sort functionality is being duplicated # (or is planned to be duplicated) elsewhere in rubygems. Is the majority of # this class necessary anymore? Especially #ok?, #why_not_ok? class Gem::DependencyList attr_reader :specs include Enumerable include Gem::TSort ## # Allows enabling/disabling use of development dependencies attr_accessor :development ## # Creates a DependencyList from the current specs. def self.from_specs list = new list.add(*Gem::Specification.to_a) list end ## # Creates a new DependencyList. If +development+ is true, development # dependencies will be included. def initialize(development = false) @specs = [] @development = development end ## # Adds +gemspecs+ to the dependency list. def add(*gemspecs) @specs.concat gemspecs end def clear @specs.clear end ## # Return a list of the gem specifications in the dependency list, sorted in # order so that no gemspec in the list depends on a gemspec earlier in the # list. # # This is useful when removing gems from a set of installed gems. By # removing them in the returned order, you don't get into as many dependency # issues. # # If there are circular dependencies (yuck!), then gems will be returned in # order until only the circular dependents and anything they reference are # left. Then arbitrary gemspecs will be returned until the circular # dependency is broken, after which gems will be returned in dependency # order again. def dependency_order sorted = strongly_connected_components.flatten result = [] seen = {} sorted.each do |spec| if index = seen[spec.name] if result[index].version < spec.version result[index] = spec end else seen[spec.name] = result.length result << spec end end result.reverse end ## # Iterator over dependency_order def each(&block) dependency_order.each(&block) end def find_name(full_name) @specs.find {|spec| spec.full_name == full_name } end def inspect # :nodoc: "%s %p>" % [super[0..-2], map {|s| s.full_name }] end ## # Are all the dependencies in the list satisfied? def ok? why_not_ok?(:quick).empty? end def why_not_ok?(quick = false) unsatisfied = Hash.new {|h,k| h[k] = [] } each do |spec| spec.runtime_dependencies.each do |dep| inst = Gem::Specification.any? do |installed_spec| dep.name == installed_spec.name && dep.requirement.satisfied_by?(installed_spec.version) end unless inst || @specs.find {|s| s.satisfies_requirement? dep } unsatisfied[spec.name] << dep return unsatisfied if quick end end end unsatisfied end ## # It is ok to remove a gemspec from the dependency list? # # If removing the gemspec creates breaks a currently ok dependency, then it # is NOT ok to remove the gemspec. def ok_to_remove?(full_name, check_dev=true) gem_to_remove = find_name full_name # If the state is inconsistent, at least don't crash return true unless gem_to_remove siblings = @specs.find_all do |s| s.name == gem_to_remove.name && s.full_name != gem_to_remove.full_name end deps = [] @specs.each do |spec| check = check_dev ? spec.dependencies : spec.runtime_dependencies check.each do |dep| deps << dep if gem_to_remove.satisfies_requirement?(dep) end end deps.all? do |dep| siblings.any? do |s| s.satisfies_requirement? dep end end end ## # Remove everything in the DependencyList that matches but doesn't # satisfy items in +dependencies+ (a hash of gem names to arrays of # dependencies). def remove_specs_unsatisfied_by(dependencies) specs.reject! do |spec| dep = dependencies[spec.name] dep && !dep.requirement.satisfied_by?(spec.version) end end ## # Removes the gemspec matching +full_name+ from the dependency list def remove_by_name(full_name) @specs.delete_if {|spec| spec.full_name == full_name } end ## # Return a hash of predecessors. <tt>result[spec]</tt> is an Array of # gemspecs that have a dependency satisfied by the named gemspec. def spec_predecessors result = Hash.new {|h,k| h[k] = [] } specs = @specs.sort.reverse specs.each do |spec| specs.each do |other| next if spec == other other.dependencies.each do |dep| if spec.satisfies_requirement? dep result[spec] << other end end end end result end def tsort_each_node(&block) @specs.each(&block) end def tsort_each_child(node) specs = @specs.sort.reverse dependencies = node.runtime_dependencies dependencies.push(*node.development_dependencies) if @development dependencies.each do |dep| specs.each do |spec| if spec.satisfies_requirement? dep yield spec break end end end end private ## # Count the number of gemspecs in the list +specs+ that are not in # +ignored+. def active_count(specs, ignored) specs.count {|spec| ignored[spec.full_name].nil? } end end
Upload File
Create Folder