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