lib/models/music_brainz/track.rb in musicbrainz-0.4.10 vs lib/models/music_brainz/track.rb in musicbrainz-0.5.0
- old
+ new
@@ -1,20 +1,20 @@
module MusicBrainz
- class Track
+ class Track < MusicBrainz::Base
attr_accessor :position, :recording_id, :title, :length
def self.find mbid
- xml = Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/recording/' + mbid + '?limit=100'))
+ xml = Nokogiri::XML(MusicBrainz.load(:recording, :id => mbid))
self.parse_xml(xml) unless xml.nil?
end
def self.parse_xml xml
@track = MusicBrainz::Track.new
- @track.position = xml.css('position').text.to_i unless xml.css('position').empty?
- @track.recording_id = xml.css('recording').attr('id').value unless xml.css('recording').empty?
- @track.title = xml.css('recording > title').text unless xml.css('recording > title').empty?
- @track.length = xml.css('length').first.text.to_i unless xml.css('length').empty?
- @track.length = xml.css('recording > length').first.text.to_i unless xml.css('recording > length').empty?
+ @track.position = self.safe_get_value(xml, 'position').to_i
+ @track.recording_id = self.safe_get_attr(xml, 'recording', 'id')
+ @track.title = self.safe_get_value(xml, 'recording > title')
+ @track.length = self.safe_get_value(xml, 'length').to_i
+ @track.length = self.safe_get_value(xml, 'recording > length').to_i
@track
end
end
end