aboutsummaryrefslogtreecommitdiffstats
path: root/lib/bundler/source_list.rb
diff options
context:
space:
mode:
authorTim Moore <tmoore@incrementalism.net>2014-10-11 19:54:23 +1100
committerTim Moore <tmoore@incrementalism.net>2014-10-11 23:37:33 +1100
commit169fbf8016b56c8fdd3bae05cf4258f049e84447 (patch)
tree2cedb3c031f6970bdc19f5ccde6c94d7ecd65697 /lib/bundler/source_list.rb
parentd61184468944248cf75ac2693a1299d79348863c (diff)
downloadbundler-169fbf8016b56c8fdd3bae05cf4258f049e84447.tar.gz
Fix deployment from cache with source blocks.
Diffstat (limited to 'lib/bundler/source_list.rb')
-rw-r--r--lib/bundler/source_list.rb27
1 files changed, 22 insertions, 5 deletions
diff --git a/lib/bundler/source_list.rb b/lib/bundler/source_list.rb
index c0eeaf3a..05e2251f 100644
--- a/lib/bundler/source_list.rb
+++ b/lib/bundler/source_list.rb
@@ -1,14 +1,13 @@
module Bundler
class SourceList
attr_reader :path_sources,
- :git_sources,
- :rubygems_sources
+ :git_sources
def initialize
@path_sources = []
@git_sources = []
@rubygems_aggregate = Source::Rubygems.new
- @rubygems_sources = [@rubygems_aggregate]
+ @rubygems_sources = []
end
def add_path_source(options = {})
@@ -28,6 +27,14 @@ module Bundler
@rubygems_aggregate
end
+ def rubygems_sources
+ @rubygems_sources + [@rubygems_aggregate]
+ end
+
+ def rubygems_remotes
+ rubygems_sources.map(&:remotes).flatten.uniq
+ end
+
def all_sources
path_sources + git_sources + rubygems_sources
end
@@ -42,11 +49,21 @@ module Bundler
end
def replace_sources!(replacement_sources)
- [path_sources, git_sources, rubygems_sources].each do |source_list|
+ return true if replacement_sources.empty?
+
+ [path_sources, git_sources].each do |source_list|
source_list.map! do |source|
replacement_sources.find { |s| s == source } || source
end
end
+
+ replacement_rubygems =
+ replacement_sources.detect { |s| s.is_a?(Source::Rubygems) }
+ @rubygems_aggregate = replacement_rubygems
+
+ # Return true if there were changes
+ all_sources.to_set != replacement_sources.to_set ||
+ rubygems_remotes.to_set != replacement_rubygems.remotes.to_set
end
def cached!
@@ -74,7 +91,7 @@ module Bundler
end
def combine_rubygems_sources
- Source::Rubygems.new("remotes" => rubygems_sources.map(&:remotes).flatten.uniq)
+ Source::Rubygems.new("remotes" => rubygems_remotes)
end
end
end