From 82843524366aaca76cdb58b6f7ecb25e0af769fb Mon Sep 17 00:00:00 2001 From: Tom Hughes Date: Thu, 21 Jun 2007 10:50:18 +0000 Subject: [PATCH] Support tar archives of traces, with optional gzip or bzip2 compression. --- app/models/trace.rb | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/app/models/trace.rb b/app/models/trace.rb index f2dcf9ad9..ba255e85d 100644 --- a/app/models/trace.rb +++ b/app/models/trace.rb @@ -90,12 +90,22 @@ 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 -b #{trace_name}`.chomp - gzipped = filetype =~ /^gzip/ - bzipped = filetype =~ /^bzip2/ - zipped = filetype =~ /^Zip/ + filetype = `file -bz #{trace_name}`.chomp + gzipped = filetype =~ /gzip compressed/ + bzipped = filetype =~ /bzip2 compressed/ + zipped = filetype =~ /Zip archive/ + tarred = filetype =~ /tar archive/ - if gzipped + if tarred and gzipped then + filename = tempfile = "/tmp/#{rand}" + system("tar -zxOf #{trace_name} > #{filename}") + elsif tarred and bzipped then + filename = tempfile = "/tmp/#{rand}" + system("tar -jxOf #{trace_name} > #{filename}") + elsif tarred + filename = tempfile = "/tmp/#{rand}" + system("tar -xOf #{trace_name} > #{filename}") + elsif gzipped filename = tempfile = "/tmp/#{rand}" system("gunzip -c #{trace_name} > #{filename}") elsif bzipped -- 2.43.2