diff --git a/lib/geocoder/orms/active_record.rb b/lib/geocoder/orms/active_record.rb index b1bac032aa8a6b9d53c64635c6722c6bcfba624e..90e54067b1c5b7e17367ef880f10dbee25ef795f 100644 --- a/lib/geocoder/orms/active_record.rb +++ b/lib/geocoder/orms/active_record.rb @@ -149,11 +149,11 @@ module Geocoder::Orm # coordinates as an array: <tt>[lat, lon]</tt>. # def fetch_coordinates(save = false) - geocode do |r| + geocode do |o,r| unless r.latitude.nil? or r.longitude.nil? method = (save ? "update" : "write") + "_attribute" - send method, self.class.geocoder_options[:latitude], r.latitude - send method, self.class.geocoder_options[:longitude], r.longitude + o.send method, self.class.geocoder_options[:latitude], r.latitude + o.send method, self.class.geocoder_options[:longitude], r.longitude end r.coordinates end @@ -171,10 +171,10 @@ module Geocoder::Orm # address as a string. # def fetch_address(save = false) - geocode do |r| + geocode do |o,r| unless r.address.nil? method = (save ? "update" : "write") + "_attribute" - send method, self.class.geocoder_options[:fetched_address], r.address + o.send method, self.class.geocoder_options[:fetched_address], r.address end r.address end diff --git a/lib/geocoder/orms/base.rb b/lib/geocoder/orms/base.rb index 1edf7e458b057dec41064803869b04815eb61d96..dedeefe4cc97f8df39fa2d0147e93761feaaeed3 100644 --- a/lib/geocoder/orms/base.rb +++ b/lib/geocoder/orms/base.rb @@ -52,9 +52,9 @@ module Geocoder # passing a block to this method overrides the one given in the model if result = Geocoder.search(*args).first if block_given? - yield(result) + yield(self, result) else - self.class.geocoder_options[:block].call(result) + self.class.geocoder_options[:block].call(self, result) end end end