aboutsummaryrefslogtreecommitdiffstats
path: root/activeresource/lib/active_resource/base.rb
diff options
context:
space:
mode:
Diffstat (limited to 'activeresource/lib/active_resource/base.rb')
-rw-r--r--activeresource/lib/active_resource/base.rb10
1 files changed, 7 insertions, 3 deletions
diff --git a/activeresource/lib/active_resource/base.rb b/activeresource/lib/active_resource/base.rb
index 0255eefc55..d33195e261 100644
--- a/activeresource/lib/active_resource/base.rb
+++ b/activeresource/lib/active_resource/base.rb
@@ -164,15 +164,19 @@ module ActiveResource
# The site variable is required ActiveResource's mapping to work.
def site=(site)
@connection = nil
- @site = create_site_uri_from(site)
+ @site = site.nil? ? nil : create_site_uri_from(site)
end
# An instance of ActiveResource::Connection that is the base connection to the remote service.
# The +refresh+ parameter toggles whether or not the connection is refreshed at every request
# or not (defaults to +false+).
def connection(refresh = false)
- @connection = Connection.new(site) if refresh || @connection.nil?
- @connection
+ if defined?(@connection) or superclass == Object
+ @connection = Connection.new(site) if refresh || @connection.nil?
+ @connection
+ else
+ superclass.connection
+ end
end
def headers