X7ROOT File Manager
Current Path:
/opt/alt/ruby26/lib64/ruby/2.6.0/bundler
opt
/
alt
/
ruby26
/
lib64
/
ruby
/
2.6.0
/
bundler
/
ðŸ“
..
📄
build_metadata.rb
(1.61 KB)
📄
capistrano.rb
(879 B)
ðŸ“
cli
📄
cli.rb
(35.12 KB)
ðŸ“
compact_index_client
📄
compact_index_client.rb
(3.27 KB)
📄
compatibility_guard.rb
(518 B)
📄
constants.rb
(212 B)
📄
current_ruby.rb
(2.19 KB)
📄
definition.rb
(36.44 KB)
📄
dep_proxy.rb
(827 B)
📄
dependency.rb
(4.43 KB)
📄
deployment.rb
(3.19 KB)
📄
deprecate.rb
(876 B)
📄
dsl.rb
(21.46 KB)
📄
endpoint_specification.rb
(3.91 KB)
📄
env.rb
(5.22 KB)
📄
environment_preserver.rb
(1.31 KB)
📄
errors.rb
(4.59 KB)
📄
feature_flag.rb
(3.07 KB)
ðŸ“
fetcher
📄
fetcher.rb
(10.83 KB)
📄
friendly_errors.rb
(4.33 KB)
📄
gem_helper.rb
(5.88 KB)
📄
gem_helpers.rb
(3.19 KB)
📄
gem_remote_fetcher.rb
(1.46 KB)
📄
gem_tasks.rb
(137 B)
📄
gem_version_promoter.rb
(6.52 KB)
📄
gemdeps.rb
(423 B)
📄
graph.rb
(5 KB)
📄
index.rb
(5.24 KB)
📄
injector.rb
(8.61 KB)
📄
inline.rb
(2.33 KB)
ðŸ“
installer
📄
installer.rb
(11.85 KB)
📄
lazy_specification.rb
(3.62 KB)
📄
lockfile_generator.rb
(2.18 KB)
📄
lockfile_parser.rb
(8.62 KB)
📄
match_platform.rb
(659 B)
📄
mirror.rb
(5.79 KB)
ðŸ“
plugin
📄
plugin.rb
(9.12 KB)
📄
process_lock.rb
(702 B)
📄
psyched_yaml.rb
(853 B)
📄
remote_specification.rb
(3.46 KB)
ðŸ“
resolver
📄
resolver.rb
(14.2 KB)
📄
retry.rb
(1.6 KB)
📄
ruby_dsl.rb
(761 B)
📄
ruby_version.rb
(4.96 KB)
📄
rubygems_ext.rb
(5.88 KB)
📄
rubygems_gem_installer.rb
(3.49 KB)
📄
rubygems_integration.rb
(25.01 KB)
📄
runtime.rb
(10.95 KB)
ðŸ“
settings
📄
settings.rb
(12.38 KB)
📄
setup.rb
(720 B)
📄
shared_helpers.rb
(12 KB)
📄
similarity_detector.rb
(1.84 KB)
ðŸ“
source
📄
source.rb
(2.66 KB)
📄
source_list.rb
(5.87 KB)
📄
spec_set.rb
(5.34 KB)
ðŸ“
ssl_certs
📄
stub_specification.rb
(2.78 KB)
ðŸ“
templates
ðŸ“
ui
📄
ui.rb
(198 B)
📄
uri_credentials_filter.rb
(1.2 KB)
ðŸ“
vendor
📄
vendored_fileutils.rb
(192 B)
📄
vendored_molinillo.rb
(100 B)
📄
vendored_persistent.rb
(1.61 KB)
📄
vendored_thor.rb
(193 B)
📄
version.rb
(821 B)
📄
version_ranges.rb
(2.86 KB)
📄
vlad.rb
(466 B)
📄
worker.rb
(2.57 KB)
📄
yaml_serializer.rb
(2.41 KB)
Editing: gem_version_promoter.rb
# frozen_string_literal: true module Bundler # This class contains all of the logic for determining the next version of a # Gem to update to based on the requested level (patch, minor, major). # Primarily designed to work with Resolver which will provide it the list of # available dependency versions as found in its index, before returning it to # to the resolution engine to select the best version. class GemVersionPromoter DEBUG = ENV["DEBUG_RESOLVER"] attr_reader :level, :locked_specs, :unlock_gems # By default, strict is false, meaning every available version of a gem # is returned from sort_versions. The order gives preference to the # requested level (:patch, :minor, :major) but in complicated requirement # cases some gems will by necessity by promoted past the requested level, # or even reverted to older versions. # # If strict is set to true, the results from sort_versions will be # truncated, eliminating any version outside the current level scope. # This can lead to unexpected outcomes or even VersionConflict exceptions # that report a version of a gem not existing for versions that indeed do # existing in the referenced source. attr_accessor :strict attr_accessor :prerelease_specified # Given a list of locked_specs and a list of gems to unlock creates a # GemVersionPromoter instance. # # @param locked_specs [SpecSet] All current locked specs. Unlike Definition # where this list is empty if all gems are being updated, this should # always be populated for all gems so this class can properly function. # @param unlock_gems [String] List of gem names being unlocked. If empty, # all gems will be considered unlocked. # @return [GemVersionPromoter] def initialize(locked_specs = SpecSet.new([]), unlock_gems = []) @level = :major @strict = false @locked_specs = locked_specs @unlock_gems = unlock_gems @sort_versions = {} @prerelease_specified = {} end # @param value [Symbol] One of three Symbols: :major, :minor or :patch. def level=(value) v = case value when String, Symbol value.to_sym end raise ArgumentError, "Unexpected level #{v}. Must be :major, :minor or :patch" unless [:major, :minor, :patch].include?(v) @level = v end # Given a Dependency and an Array of SpecGroups of available versions for a # gem, this method will return the Array of SpecGroups sorted (and possibly # truncated if strict is true) in an order to give preference to the current # level (:major, :minor or :patch) when resolution is deciding what versions # best resolve all dependencies in the bundle. # @param dep [Dependency] The Dependency of the gem. # @param spec_groups [SpecGroup] An array of SpecGroups for the same gem # named in the @dep param. # @return [SpecGroup] A new instance of the SpecGroup Array sorted and # possibly filtered. def sort_versions(dep, spec_groups) before_result = "before sort_versions: #{debug_format_result(dep, spec_groups).inspect}" if DEBUG @sort_versions[dep] ||= begin gem_name = dep.name # An Array per version returned, different entries for different platforms. # We only need the version here so it's ok to hard code this to the first instance. locked_spec = locked_specs[gem_name].first if strict filter_dep_specs(spec_groups, locked_spec) else sort_dep_specs(spec_groups, locked_spec) end.tap do |specs| if DEBUG STDERR.puts before_result STDERR.puts " after sort_versions: #{debug_format_result(dep, specs).inspect}" end end end end # @return [bool] Convenience method for testing value of level variable. def major? level == :major end # @return [bool] Convenience method for testing value of level variable. def minor? level == :minor end private def filter_dep_specs(spec_groups, locked_spec) res = spec_groups.select do |spec_group| if locked_spec && !major? gsv = spec_group.version lsv = locked_spec.version must_match = minor? ? [0] : [0, 1] matches = must_match.map {|idx| gsv.segments[idx] == lsv.segments[idx] } (matches.uniq == [true]) ? (gsv >= lsv) : false else true end end sort_dep_specs(res, locked_spec) end def sort_dep_specs(spec_groups, locked_spec) return spec_groups unless locked_spec @gem_name = locked_spec.name @locked_version = locked_spec.version result = spec_groups.sort do |a, b| @a_ver = a.version @b_ver = b.version unless @prerelease_specified[@gem_name] a_pre = @a_ver.prerelease? b_pre = @b_ver.prerelease? next -1 if a_pre && !b_pre next 1 if b_pre && !a_pre end if major? @a_ver <=> @b_ver elsif either_version_older_than_locked @a_ver <=> @b_ver elsif segments_do_not_match(:major) @b_ver <=> @a_ver elsif !minor? && segments_do_not_match(:minor) @b_ver <=> @a_ver else @a_ver <=> @b_ver end end post_sort(result) end def either_version_older_than_locked @a_ver < @locked_version || @b_ver < @locked_version end def segments_do_not_match(level) index = [:major, :minor].index(level) @a_ver.segments[index] != @b_ver.segments[index] end def unlocking_gem? unlock_gems.empty? || unlock_gems.include?(@gem_name) end # Specific version moves can't always reliably be done during sorting # as not all elements are compared against each other. def post_sort(result) # default :major behavior in Bundler does not do this return result if major? if unlocking_gem? result else move_version_to_end(result, @locked_version) end end def move_version_to_end(result, version) move, keep = result.partition {|s| s.version.to_s == version.to_s } keep.concat(move) end def debug_format_result(dep, spec_groups) a = [dep.to_s, spec_groups.map {|sg| [sg.version, sg.dependencies_for_activated_platforms.map {|dp| [dp.name, dp.requirement.to_s] }] }] last_map = a.last.map {|sg_data| [sg_data.first.version, sg_data.last.map {|aa| aa.join(" ") }] } [a.first, last_map, level, strict ? :strict : :not_strict] end end end
Upload File
Create Folder