Class: Bundler::ConnectionPool::Wrapper

Inherits:
BasicObject
Defined in:
lib/bundler/vendor/connection_pool/lib/connection_pool.rb

Constant Summary collapse

METHODS =
[:with, :pool_shutdown]

Instance Method Summary collapse

Constructor Details

#initialize(options = {}, &block) ⇒ Wrapper

Returns a new instance of Wrapper.



131
132
133
# File 'lib/bundler/vendor/connection_pool/lib/connection_pool.rb', line 131

def initialize(options = {}, &block)
  @pool = options.fetch(:pool) { ::Bundler::ConnectionPool.new(options, &block) }
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(name, *args, &block) ⇒ Object



155
156
157
158
159
# File 'lib/bundler/vendor/connection_pool/lib/connection_pool.rb', line 155

def method_missing(name, *args, &block)
  with do |connection|
    connection.send(name, *args, &block)
  end
end

Instance Method Details

#pool_availableObject



147
148
149
# File 'lib/bundler/vendor/connection_pool/lib/connection_pool.rb', line 147

def pool_available
  @pool.available
end

#pool_shutdown(&block) ⇒ Object



139
140
141
# File 'lib/bundler/vendor/connection_pool/lib/connection_pool.rb', line 139

def pool_shutdown(&block)
  @pool.shutdown(&block)
end

#pool_sizeObject



143
144
145
# File 'lib/bundler/vendor/connection_pool/lib/connection_pool.rb', line 143

def pool_size
  @pool.size
end

#respond_to?(id, *args) ⇒ Boolean

Returns:

  • (Boolean)


151
152
153
# File 'lib/bundler/vendor/connection_pool/lib/connection_pool.rb', line 151

def respond_to?(id, *args)
  METHODS.include?(id) || with { |c| c.respond_to?(id, *args) }
end

#with(&block) ⇒ Object



135
136
137
# File 'lib/bundler/vendor/connection_pool/lib/connection_pool.rb', line 135

def with(&block)
  @pool.with(&block)
end