lib/models/music_brainz/release.rb in musicbrainz-0.4.1 vs lib/models/music_brainz/release.rb in musicbrainz-0.4.2

- old
+ new

@@ -8,11 +8,11 @@ @tracks = [] Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release/' + self.id + '?inc=recordings&limit=100')).css('medium-list > medium > track-list > track').each do |r| @tracks << MusicBrainz::Track.parse_xml(r) end end - @tracks + @tracks.sort{ |a, b| a.position <=> b.position } end def self.find mbid xml = Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release/' + mbid)).css('release').first self.parse_xml(xml) unless xml.nil? @@ -21,20 +21,19 @@ def self.parse_xml xml @release = MusicBrainz::Release.new @release.id = xml.attr('id') @release.title = xml.css('title').text unless xml.css('title').empty? @release.status = xml.css('status').text unless xml.css('status').empty? - date = nil - date = xml.css('date').text unless xml.css('date').empty? - unless date.nil? or date.empty? - if date.length == 4 - date += '-01-01' - elsif date.length == 7 - date += '-01' - end - date = Time.parse(date) + date = xml.css('date').empty? ? '9999-12-31' : xml.css('date').text + if date.length == 0 + date = '9999-12-31' + elsif date.length == 4 + date += '-12-31' + elsif date.length == 7 + date += '-31' end - @release.date = date + date = date.split('-') + @release.date = Time.utc(date[0], date[1], date[2]) @release.country = xml.css('country').text unless xml.css('country').empty? @release end end end