X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/2f55a3f0a80974922678d7677902d169b3481693..4fd689b03551a5d03cd7843504e277fc7078ad1a:/app/models/old_way.rb diff --git a/app/models/old_way.rb b/app/models/old_way.rb index 4a5362bc1..e4df25816 100644 --- a/app/models/old_way.rb +++ b/app/models/old_way.rb @@ -5,6 +5,7 @@ class OldWay < ActiveRecord::Base def self.from_way(way) old_way = OldWay.new + old_way.visible = way.visible old_way.user_id = way.user_id old_way.timestamp = way.timestamp old_way.id = way.id @@ -13,7 +14,7 @@ class OldWay < ActiveRecord::Base return old_way end - def save_with_dependencies + def save_with_dependencies! # dont touch this unless you really have figured out why it's called # (Rails doesn't deal well with the old ways table (called 'ways') because @@ -21,7 +22,7 @@ class OldWay < ActiveRecord::Base # id and get it back but we have that and we want to get the 'version' back # we could add another column but thats a lot of data. No, set_primary_key # doesn't work either. - save() + save! clear_aggregation_cache clear_association_cache @attributes.update(OldWay.find(:first, :conditions => ['id = ? AND timestamp = ?', self.id, self.timestamp]).instance_variable_get('@attributes')) @@ -34,25 +35,36 @@ class OldWay < ActiveRecord::Base tag.v = v tag.id = self.id tag.version = self.version - tag.save + tag.save! end - i = 0 + i = 1 self.segs.each do |n| seg = OldWaySegment.new seg.id = self.id seg.segment_id = n seg.version = self.version - seg.save + seg.save! end end def segs - @segs = Array.new unless @segs + unless @segs + @segs = Array.new + OldWaySegment.find(:all, :conditions => ["id = ? AND version = ?", self.id, self.version], :order => "sequence_id").each do |seg| + @segs += [seg.segment_id] + end + end @segs end def tags + unless @tags + @tags = Hash.new + OldWayTag.find(:all, :conditions => ["id = ? AND version = ?", self.id, self.version]).each do |tag| + @tags[tag.k] = tag.v + end + end @tags = Hash.new unless @tags @tags end