diff options
author | Tim Moore <tmoore@incrementalism.net> | 2014-10-11 19:54:23 +1100 |
---|---|---|
committer | Tim Moore <tmoore@incrementalism.net> | 2014-10-11 23:37:33 +1100 |
commit | 169fbf8016b56c8fdd3bae05cf4258f049e84447 (patch) | |
tree | 2cedb3c031f6970bdc19f5ccde6c94d7ecd65697 /lib/bundler/source_list.rb | |
parent | d61184468944248cf75ac2693a1299d79348863c (diff) | |
download | bundler-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.rb | 27 |
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 |