Path
# File lib/bundler/source/git.rb, line 34 def self.from_lock(options) new(options.merge("uri" => options.delete("remote"))) end
# File lib/bundler/source/git.rb, line 13 def initialize(options) @options = options @glob = options["glob"] || DEFAULT_GLOB @allow_cached = false @allow_remote = false # Stringify options that could be set as symbols %(ref branch tag revision).each{|k| options[k] = options[k].to_s if options[k] } @uri = options["uri"] @branch = options["branch"] @ref = options["ref"] || options["branch"] || options["tag"] || 'master' @submodules = options["submodules"] @name = options["name"] @version = options["version"] @copied = false @local = false end
# File lib/bundler/source/git.rb, line 215 def allow_git_ops? @allow_remote || @allow_cached end
# File lib/bundler/source/git.rb, line 207 def app_cache_dirname "#{base_name}-#{shortref_for_path(cached_revision || revision)}" end
# File lib/bundler/source/git.rb, line 173 def cache(spec, custom_path = nil) app_cache_path = app_cache_path(custom_path) return unless Bundler.settings[:cache_all] return if path == app_cache_path cached! FileUtils.rm_rf(app_cache_path) git_proxy.checkout if requires_checkout? git_proxy.copy_to(app_cache_path, @submodules) serialize_gemspecs_in(app_cache_path) end
This is the path which is going to contain a cache of the git repository. When using the same git repository across different projects, this cache will be shared. When using local git repos, this is set to the local repo.
# File lib/bundler/source/git.rb, line 195 def cache_path @cache_path ||= begin git_scope = "#{base_name}-#{uri_hash}" if Bundler.requires_sudo? Bundler.user_bundle_path.join("cache/git", git_scope) else Bundler.cache.join("git", git_scope) end end end
# File lib/bundler/source/git.rb, line 49 def eql?(o) o.is_a?(Git) && uri == o.uri && ref == o.ref && branch == o.branch && name == o.name && version == o.version && submodules == o.submodules end
# File lib/bundler/source/git.rb, line 94 def extension_dir_name "#{base_name}-#{shortref_for_path(revision)}" end
# File lib/bundler/source/git.rb, line 158 def install(spec) debug = nil if requires_checkout? && !@copied debug = " * Checking out revision: #{ref}" git_proxy.copy_to(install_path, submodules) serialize_gemspecs_in(install_path) @copied = true end generate_bin(spec) if requires_checkout? && spec.post_install_message Installer.post_install_messages[spec.name] = spec.post_install_message end ["Using #{version_message(spec)} from #{to_s}", nil, debug] end
This is the path which is going to contain a specific checkout of the git repository. When using local git repos, this is set to the local repo.
# File lib/bundler/source/git.rb, line 79 def install_path @install_path ||= begin git_scope = "#{base_name}-#{shortref_for_path(revision)}" path = Bundler.install_path.join(git_scope) if !path.exist? && Bundler.requires_sudo? Bundler.user_bundle_path.join(Bundler.ruby_scope).join(git_scope) else path end end end
# File lib/bundler/source/git.rb, line 184 def load_spec_files super rescue PathError => e Bundler.ui.trace e raise GitError, "#{to_s} is not yet checked out. Run `bundle install` first." end
# File lib/bundler/source/git.rb, line 103 def local_override!(path) return false if local? path = Pathname.new(path) path = path.expand_path(Bundler.root) unless path.relative? unless options["branch"] || Bundler.settings[:disable_local_branch_check] raise GitError, "Cannot use local override for #{name} at #{path} because " ":branch is not specified in Gemfile. Specify a branch or use " "`bundle config --delete` to remove the local override" end unless path.exist? raise GitError, "Cannot use local override for #{name} because #{path} " "does not exist. Check `bundle config --delete` to remove the local override" end set_local!(path) # Create a new git proxy without the cached revision # so the Gemfile.lock always picks up the new revision. @git_proxy = GitProxy.new(path, uri, ref) if git_proxy.branch != options["branch"] && !Bundler.settings[:disable_local_branch_check] raise GitError, "Local override for #{name} at #{path} is using branch " "#{git_proxy.branch} but Gemfile specifies #{options["branch"]}" end changed = cached_revision && cached_revision != git_proxy.revision if changed && !@unlocked && !git_proxy.contains?(cached_revision) raise GitError, "The Gemfile lock is pointing to revision #{shortref_for_display(cached_revision)} " "but the current branch in your local override for #{name} does not contain such commit. " "Please make sure your branch is up to date." end changed end
# File lib/bundler/source/git.rb, line 72 def name File.basename(@uri, '.git') end
# File lib/bundler/source/git.rb, line 211 def revision git_proxy.revision end
TODO: actually cache git specs
# File lib/bundler/source/git.rb, line 143 def specs(*) if has_app_cache? && !local? set_local!(app_cache_path) end if requires_checkout? && !@copied git_proxy.checkout git_proxy.copy_to(install_path, submodules) serialize_gemspecs_in(install_path) @copied = true end local_specs end
# File lib/bundler/source/git.rb, line 38 def to_lock out = "GIT\n" out << " remote: #{@uri}\n" out << " revision: #{revision}\n" %(ref branch tag submodules).each do |opt| out << " #{opt}: #{options[opt]}\n" if options[opt] end out << " glob: #{@glob}\n" unless @glob == DEFAULT_GLOB out << " specs:\n" end
Generated with the Darkfish Rdoc Generator 2.