summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHomu <homu@barosl.com>2016-06-25 06:39:00 +0900
committerSamuel Giddins <segiddins@segiddins.me>2016-06-27 16:17:38 -0500
commit63622905967db5766305df374d19eda9d4045776 (patch)
tree9d92e8bd20c1c4300df437cf70c9e319ef4e137b
parent9585f87217e89e4f4776f6f20d5369a7d8e7313d (diff)
downloadbundler-63622905967db5766305df374d19eda9d4045776.tar.gz
Auto merge of #4712 - bundler:seg-skip-reresolve, r=indirect
[Definition] Add a #change_reason printed in debug @indirect this might make your debugging a bit easier? (cherry picked from commit 378602f073f808046741a829903d6ea6104f619a)
-rw-r--r--lib/bundler/definition.rb25
-rw-r--r--lib/bundler/spec_set.rb2
2 files changed, 24 insertions, 3 deletions
diff --git a/lib/bundler/definition.rb b/lib/bundler/definition.rb
index bf83d70d30..7932d2d7e2 100644
--- a/lib/bundler/definition.rb
+++ b/lib/bundler/definition.rb
@@ -92,7 +92,7 @@ module Bundler
end
@ruby_version.diff(locked_ruby_version_object)
end
- @unlocking ||= @unlock[:ruby] || (!@locked_ruby_version ^ !@ruby_version)
+ @unlocking ||= @unlock[:ruby] ||= (!@locked_ruby_version ^ !@ruby_version)
current_platform = Bundler.rubygems.platforms.map {|p| generic(p) }.compact.last
add_platform(current_platform)
@@ -220,7 +220,7 @@ module Bundler
last_resolve
else
# Run a resolve against the locally available gems
- Bundler.ui.debug("Found changes from the lockfile, re-resolving dependencies")
+ Bundler.ui.debug("Found changes from the lockfile, re-resolving dependencies because #{change_reason}")
last_resolve.merge Resolver.resolve(expanded_dependencies, index, source_requirements, last_resolve, ruby_version)
end
end
@@ -462,6 +462,27 @@ module Bundler
!@source_changes && !@dependency_changes && !@new_platform && !@path_changes && !@local_changes
end
+ def change_reason
+ if @unlocking
+ unlock_reason = @unlock.reject {|_k, v| Array(v).empty? }.map do |k, v|
+ if v == true
+ k.to_s
+ else
+ v = Array(v)
+ "#{k}: (#{v.join(", ")})"
+ end
+ end.join(", ")
+ return "bundler is unlocking #{unlock_reason}"
+ end
+ [
+ [@source_changes, "the list of sources changed"],
+ [@dependency_changes, "the dependencies in your gemfile changed"],
+ [@new_platform, "you added a new platform to your gemfile"],
+ [@path_changes, "the gemspecs for path gems changed"],
+ [@local_changes, "the gemspecs for git local gems changed"],
+ ].select(&:first).map(&:last).join(", ")
+ end
+
def pretty_dep(dep, source = false)
msg = String.new(dep.name)
msg << " (#{dep.requirement})" unless dep.requirement == Gem::Requirement.default
diff --git a/lib/bundler/spec_set.rb b/lib/bundler/spec_set.rb
index 3133ff269a..bfc5a23ba7 100644
--- a/lib/bundler/spec_set.rb
+++ b/lib/bundler/spec_set.rb
@@ -18,7 +18,7 @@ module Bundler
handled = {}
deps = dependencies.dup
specs = []
- skip << "bundler"
+ skip += ["bundler"]
until deps.empty?
dep = deps.shift