From 2382b3cb6a82b4fab167aee0fab77ffd024345ac Mon Sep 17 00:00:00 2001 From: Tony Novak Date: Mon, 1 Jun 2015 21:47:16 -0700 Subject: [PATCH] Zip::InputStream doesn't handle all zip files Excel files exported from Google, for example, aren't supported. Using Zip::CentralDirectory instead seems to do the trick. --- lib/roo/excelx.rb | 16 +++++----------- test/test_roo.rb | 2 +- 2 files changed, 6 insertions(+), 12 deletions(-) diff --git a/lib/roo/excelx.rb b/lib/roo/excelx.rb index d4e00ae3..5021ae2c 100644 --- a/lib/roo/excelx.rb +++ b/lib/roo/excelx.rb @@ -409,19 +409,13 @@ def process_zipfile(zipfilename_or_stream) @sheet_files = [] unless is_stream?(zipfilename_or_stream) - process_zipfile_entries Zip::File.open(zipfilename_or_stream).to_a.sort_by(&:name) + zip_file = Zip::File.open(zipfilename_or_stream) else - stream = Zip::InputStream.open zipfilename_or_stream - begin - entries = [] - while (entry = stream.get_next_entry) - entries << entry - end - process_zipfile_entries entries - ensure - stream.close - end + zip_file = Zip::CentralDirectory.new + zip_file.read_from_stream zipfilename_or_stream end + + process_zipfile_entries zip_file.to_a.sort_by(&:name) end def process_zipfile_entries(entries) diff --git a/test/test_roo.rb b/test/test_roo.rb index 08035906..ebb6adb7 100644 --- a/test/test_roo.rb +++ b/test/test_roo.rb @@ -2066,7 +2066,7 @@ def test_noexpand_merged_range def test_open_stream return unless EXCELX - file_contents = File.read File.join(TESTDIR, fixture_filename(:numbers1, :excelx)) + file_contents = File.read File.join(TESTDIR, fixture_filename(:numbers1, :excelx)), encoding: 'BINARY' stream = StringIO.new(file_contents) xlsx = Roo::Excelx.new(stream) assert_equal ["Tabelle1","Name of Sheet 2","Sheet3","Sheet4","Sheet5"], xlsx.sheets