X7ROOT File Manager
Current Path:
/opt/alt/ruby32/share/gems/gems/bundler-2.4.19/lib/bundler
opt
/
alt
/
ruby32
/
share
/
gems
/
gems
/
bundler-2.4.19
/
lib
/
bundler
/
ðŸ“
..
📄
build_metadata.rb
(1.2 KB)
📄
capistrano.rb
(883 B)
ðŸ“
cli
📄
cli.rb
(41 KB)
ðŸ“
compact_index_client
📄
compact_index_client.rb
(3.36 KB)
📄
constants.rb
(224 B)
📄
current_ruby.rb
(2.43 KB)
📄
definition.rb
(32.33 KB)
📄
dependency.rb
(3.11 KB)
📄
deployment.rb
(3.19 KB)
📄
deprecate.rb
(876 B)
📄
digest.rb
(2.16 KB)
📄
dsl.rb
(19.97 KB)
📄
endpoint_specification.rb
(3.65 KB)
📄
env.rb
(5.01 KB)
📄
environment_preserver.rb
(1.94 KB)
📄
errors.rb
(5.17 KB)
📄
feature_flag.rb
(1.79 KB)
ðŸ“
fetcher
📄
fetcher.rb
(11.19 KB)
📄
force_platform.rb
(557 B)
📄
friendly_errors.rb
(3.75 KB)
📄
gem_helper.rb
(6.89 KB)
📄
gem_helpers.rb
(4.08 KB)
📄
gem_tasks.rb
(138 B)
📄
gem_version_promoter.rb
(4.76 KB)
📄
graph.rb
(4.99 KB)
📄
index.rb
(4.14 KB)
📄
injector.rb
(10.08 KB)
📄
inline.rb
(2.47 KB)
ðŸ“
installer
📄
installer.rb
(10.25 KB)
📄
lazy_specification.rb
(5.35 KB)
📄
lockfile_generator.rb
(2.18 KB)
📄
lockfile_parser.rb
(7.01 KB)
ðŸ“
man
📄
match_metadata.rb
(290 B)
📄
match_platform.rb
(583 B)
📄
match_remote_metadata.rb
(863 B)
📄
mirror.rb
(5.78 KB)
ðŸ“
plugin
📄
plugin.rb
(11.25 KB)
📄
process_lock.rb
(686 B)
📄
remote_specification.rb
(3.71 KB)
ðŸ“
resolver
📄
resolver.rb
(14.62 KB)
📄
retry.rb
(1.61 KB)
📄
ruby_dsl.rb
(961 B)
📄
ruby_version.rb
(4.17 KB)
📄
rubygems_ext.rb
(10.88 KB)
📄
rubygems_gem_installer.rb
(5.24 KB)
📄
rubygems_integration.rb
(15.82 KB)
📄
runtime.rb
(10.15 KB)
📄
safe_marshal.rb
(597 B)
📄
self_manager.rb
(4.76 KB)
ðŸ“
settings
📄
settings.rb
(13.19 KB)
📄
setup.rb
(963 B)
📄
shared_helpers.rb
(10.76 KB)
📄
similarity_detector.rb
(1.84 KB)
ðŸ“
source
📄
source.rb
(2.98 KB)
📄
source_list.rb
(6.18 KB)
📄
source_map.rb
(2.17 KB)
📄
spec_set.rb
(5.08 KB)
📄
stub_specification.rb
(2.79 KB)
ðŸ“
templates
ðŸ“
ui
📄
ui.rb
(255 B)
📄
uri_credentials_filter.rb
(1.28 KB)
📄
uri_normalizer.rb
(715 B)
ðŸ“
vendor
📄
vendored_fileutils.rb
(101 B)
📄
vendored_persistent.rb
(270 B)
📄
vendored_pub_grub.rb
(99 B)
📄
vendored_thor.rb
(180 B)
📄
vendored_tsort.rb
(93 B)
📄
vendored_uri.rb
(89 B)
📄
version.rb
(260 B)
📄
vlad.rb
(468 B)
📄
worker.rb
(2.85 KB)
📄
yaml_serializer.rb
(2.36 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 attr_reader :level attr_accessor :pre # 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 be 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 # Creates a GemVersionPromoter instance. # # @return [GemVersionPromoter] def initialize @level = :major @strict = false @pre = false 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 Resolver::Package and an Array of Specifications of available # versions for a gem, this method will return the Array of Specifications # 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 package [Resolver::Package] The package being resolved. # @param specs [Specification] An array of Specifications for the package. # @return [Specification] A new instance of the Specification Array sorted and # possibly filtered. def sort_versions(package, specs) specs = filter_dep_specs(specs, package) if strict sort_dep_specs(specs, package) 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 # @return [bool] Convenience method for testing value of pre variable. def pre? pre == true end private def filter_dep_specs(specs, package) locked_version = package.locked_version return specs if locked_version.nil? || major? specs.select do |spec| gsv = spec.version must_match = minor? ? [0] : [0, 1] all_match = must_match.all? {|idx| gsv.segments[idx] == locked_version.segments[idx] } all_match && gsv >= locked_version end end def sort_dep_specs(specs, package) locked_version = package.locked_version result = specs.sort do |a, b| unless package.prerelease_specified? || pre? a_pre = a.prerelease? b_pre = b.prerelease? next -1 if a_pre && !b_pre next 1 if b_pre && !a_pre end if major? a <=> b elsif either_version_older_than_locked?(a, b, locked_version) a <=> b elsif segments_do_not_match?(a, b, :major) b <=> a elsif !minor? && segments_do_not_match?(a, b, :minor) b <=> a else a <=> b end end post_sort(result, package.unlock?, locked_version) end def either_version_older_than_locked?(a, b, locked_version) locked_version && (a.version < locked_version || b.version < locked_version) end def segments_do_not_match?(a, b, level) index = [:major, :minor].index(level) a.segments[index] != b.segments[index] 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, unlock, locked_version) # default :major behavior in Bundler does not do this return result if major? if unlock || locked_version.nil? 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 end end
Upload File
Create Folder