From 1e508ac3046bdc9f5c2c7b96959ab55912f9a680 Mon Sep 17 00:00:00 2001 From: Robert Date: Thu, 7 Dec 2017 13:08:55 +0100 Subject: Refs #5006@0.5h; CR pass III / (i) - refact of NetexFile#frames --- lib/stif/netex_file.rb | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) (limited to 'lib') diff --git a/lib/stif/netex_file.rb b/lib/stif/netex_file.rb index b3e093727..e58f22f08 100644 --- a/lib/stif/netex_file.rb +++ b/lib/stif/netex_file.rb @@ -2,7 +2,7 @@ module STIF class NetexFile CALENDAR_FILE_NAME = 'calendriers.xml' - LINE_FILE_FORMAT = %r{\A offre_ (.*?) _ .* \. xml \z}x + LINE_FILE_FORMAT = %r{\A offre_ (? .*?) _ .* \. xml \z}x XML_NAME_SPACE = "http://www.netex.org.uk/netex" @@ -14,22 +14,29 @@ module STIF frames = Hash.new { |h,k| h[k] = NetexFile::Frame.new(k) } Zip::File.open(@file_name) do |zipfile| zipfile.each do |entry| - next unless entry.ftype == :file - - entry_dir_name, entry_file_name = File.split(entry.name) - case entry_file_name - when CALENDAR_FILE_NAME - entry.get_input_stream do |stream| - frames[entry_dir_name].parse_calendars(stream.read) - end - when LINE_FILE_FORMAT - frames[entry_dir_name].add_offer_file($1) - end + add_frame(to_frames: frames, from_entry: entry) if entry.ftype == :file + end end frames.values end + + private + + def add_frame(to_frames:, from_entry:) + entry_dir_name, entry_file_name = File.split(from_entry.name) + case entry_file_name + when CALENDAR_FILE_NAME + from_entry.get_input_stream do |stream| + to_frames[entry_dir_name].parse_calendars(stream.read) + end + when LINE_FILE_FORMAT + to_frames[entry_dir_name].add_offer_file($1) + end + end + + class Frame class << self -- cgit v1.2.3