X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/16358a1d39d96a2d04ab410731c9edcdf155606b..042388418411da6facdfe6ae590df6c17f85e88c:/app/models/trace.rb diff --git a/app/models/trace.rb b/app/models/trace.rb index ed0ba72e8..a2bebf1dd 100644 --- a/app/models/trace.rb +++ b/app/models/trace.rb @@ -73,7 +73,7 @@ class Trace < ActiveRecord::Base end def mime_type - filetype = `file -bz #{trace_name}`.chomp + filetype = `/usr/bin/file -bz #{trace_name}`.chomp gzipped = filetype =~ /gzip compressed/ bzipped = filetype =~ /bzip2 compressed/ zipped = filetype =~ /Zip archive/ @@ -92,7 +92,7 @@ class Trace < ActiveRecord::Base end def extension_name - filetype = `file -bz #{trace_name}`.chomp + filetype = `/usr/bin/file -bz #{trace_name}`.chomp gzipped = filetype =~ /gzip compressed/ bzipped = filetype =~ /bzip2 compressed/ zipped = filetype =~ /Zip archive/ @@ -141,7 +141,7 @@ class Trace < ActiveRecord::Base logger.info("GPX Import importing #{name} (#{id}) from #{user.email}") # TODO *nix specific, could do to work on windows... would be functionally inferior though - check for '.gz' - filetype = `file -bz #{trace_name}`.chomp + filetype = `/usr/bin/file -bz #{trace_name}`.chomp gzipped = filetype =~ /gzip compressed/ bzipped = filetype =~ /bzip2 compressed/ zipped = filetype =~ /Zip archive/ @@ -175,7 +175,12 @@ class Trace < ActiveRecord::Base f_lon = 0 first = true - Tracepoint.delete_all(['gpx_id = ?', self.id]) + # If there are any existing points for this trace then delete + # them - we check for existing points first to avoid locking + # the table in the common case where there aren't any. + if Tracepoint.exists?(['gpx_id = ?', self.id]) + Tracepoint.delete_all(['gpx_id = ?', self.id]) + end gpx.points do |point| if first @@ -188,7 +193,6 @@ class Trace < ActiveRecord::Base tp.lng = point['longitude'].to_f tp.altitude = point['altitude'].to_f tp.timestamp = point['timestamp'] - tp.user_id = user.id tp.gpx_id = id tp.trackid = point['segment'].to_i tp.save! @@ -211,7 +215,7 @@ class Trace < ActiveRecord::Base self.icon_picture = gpx.get_icon(min_lat, min_lon, max_lat, max_lon) self.size = gpx.actual_points self.inserted = true - self.save + self.save! end logger.info "done trace #{id}"