mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
Added bundler as default gems. Revisit [Feature #12733]
* bin/*, lib/bundler/*, lib/bundler.rb, spec/bundler, man/*: Merge from latest stable branch of bundler/bundler repository and added workaround patches. I will backport them into upstream. * common.mk, defs/gmake.mk: Added `test-bundler` task for test suite of bundler. * tool/sync_default_gems.rb: Added sync task for bundler. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@65509 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
7deb37777a
commit
59c8d50653
855 changed files with 83604 additions and 1 deletions
81
lib/bundler/plugin/api.rb
Normal file
81
lib/bundler/plugin/api.rb
Normal file
|
@ -0,0 +1,81 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
module Bundler
|
||||
# This is the interfacing class represents the API that we intend to provide
|
||||
# the plugins to use.
|
||||
#
|
||||
# For plugins to be independent of the Bundler internals they shall limit their
|
||||
# interactions to methods of this class only. This will save them from breaking
|
||||
# when some internal change.
|
||||
#
|
||||
# Currently we are delegating the methods defined in Bundler class to
|
||||
# itself. So, this class acts as a buffer.
|
||||
#
|
||||
# If there is some change in the Bundler class that is incompatible to its
|
||||
# previous behavior or if otherwise desired, we can reimplement(or implement)
|
||||
# the method to preserve compatibility.
|
||||
#
|
||||
# To use this, either the class can inherit this class or use it directly.
|
||||
# For example of both types of use, refer the file `spec/plugins/command.rb`
|
||||
#
|
||||
# To use it without inheriting, you will have to create an object of this
|
||||
# to use the functions (except for declaration functions like command, source,
|
||||
# and hooks).
|
||||
module Plugin
|
||||
class API
|
||||
autoload :Source, "bundler/plugin/api/source"
|
||||
|
||||
# The plugins should declare that they handle a command through this helper.
|
||||
#
|
||||
# @param [String] command being handled by them
|
||||
# @param [Class] (optional) class that handles the command. If not
|
||||
# provided, the `self` class will be used.
|
||||
def self.command(command, cls = self)
|
||||
Plugin.add_command command, cls
|
||||
end
|
||||
|
||||
# The plugins should declare that they provide a installation source
|
||||
# through this helper.
|
||||
#
|
||||
# @param [String] the source type they provide
|
||||
# @param [Class] (optional) class that handles the source. If not
|
||||
# provided, the `self` class will be used.
|
||||
def self.source(source, cls = self)
|
||||
cls.send :include, Bundler::Plugin::API::Source
|
||||
Plugin.add_source source, cls
|
||||
end
|
||||
|
||||
def self.hook(event, &block)
|
||||
Plugin.add_hook(event, &block)
|
||||
end
|
||||
|
||||
# The cache dir to be used by the plugins for storage
|
||||
#
|
||||
# @return [Pathname] path of the cache dir
|
||||
def cache_dir
|
||||
Plugin.cache.join("plugins")
|
||||
end
|
||||
|
||||
# A tmp dir to be used by plugins
|
||||
# Accepts names that get concatenated as suffix
|
||||
#
|
||||
# @return [Pathname] object for the new directory created
|
||||
def tmp(*names)
|
||||
Bundler.tmp(["plugin", *names].join("-"))
|
||||
end
|
||||
|
||||
def method_missing(name, *args, &blk)
|
||||
return Bundler.send(name, *args, &blk) if Bundler.respond_to?(name)
|
||||
|
||||
return SharedHelpers.send(name, *args, &blk) if SharedHelpers.respond_to?(name)
|
||||
|
||||
super
|
||||
end
|
||||
|
||||
def respond_to_missing?(name, include_private = false)
|
||||
SharedHelpers.respond_to?(name, include_private) ||
|
||||
Bundler.respond_to?(name, include_private) || super
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue