Class: Bundler::Plugin::API
- Inherits:
-
Object
- Object
- Bundler::Plugin::API
- Defined in:
- lib/bundler/plugin/api.rb,
lib/bundler/plugin/api/source.rb
Defined Under Namespace
Modules: Source
Class Method Summary collapse
-
.command(command, cls = self) ⇒ Object
The plugins should declare that they handle a command through this helper.
- .hook(event, &block) ⇒ Object
-
.source(source, cls = self) ⇒ Object
The plugins should declare that they provide a installation source through this helper.
Instance Method Summary collapse
-
#cache_dir ⇒ Pathname
The cache dir to be used by the plugins for storage.
- #method_missing(name, *args, &blk) ⇒ Object
- #respond_to_missing?(name, include_private = false) ⇒ Boolean
-
#tmp(*names) ⇒ Pathname
A tmp dir to be used by plugins Accepts names that get concatenated as suffix.
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(name, *args, &blk) ⇒ Object
67 68 69 70 71 72 73 |
# File 'lib/bundler/plugin/api.rb', line 67 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 |
Class Method Details
.command(command, cls = self) ⇒ Object
The plugins should declare that they handle a command through this helper.
33 34 35 |
# File 'lib/bundler/plugin/api.rb', line 33 def self.command(command, cls = self) Plugin.add_command command, cls end |
Instance Method Details
#cache_dir ⇒ Pathname
The cache dir to be used by the plugins for storage
55 56 57 |
# File 'lib/bundler/plugin/api.rb', line 55 def cache_dir Plugin.cache.join("plugins") end |
#respond_to_missing?(name, include_private = false) ⇒ Boolean
75 76 77 78 |
# File 'lib/bundler/plugin/api.rb', line 75 def respond_to_missing?(name, include_private = false) SharedHelpers.respond_to?(name, include_private) || Bundler.respond_to?(name, include_private) || super end |