Refactored Release and Track models, fixed tests
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
# -*- encoding: utf-8 -*-
|
||||
|
||||
module MusicBrainz
|
||||
class Release < MusicBrainz::Base
|
||||
class Release < Base
|
||||
|
||||
field :id, String
|
||||
field :title, String
|
||||
@@ -10,19 +11,32 @@ module MusicBrainz
|
||||
field :country, String
|
||||
|
||||
def tracks
|
||||
if @tracks.nil? and not self.id.nil?
|
||||
@tracks = []
|
||||
Nokogiri::XML(self.class.load(:release, :id => self.id, :inc => [:recordings, :media], :limit => 100)).css('medium-list > medium > track-list > track').each do |r|
|
||||
@tracks << MusicBrainz::Track.parse_xml(r)
|
||||
end
|
||||
@tracks ||= nil
|
||||
if @tracks.nil? and !id.nil?
|
||||
@tracks = self.class.load({
|
||||
:parser => :release_tracks,
|
||||
:create_models => MusicBrainz::Track
|
||||
}, {
|
||||
:resource => :release,
|
||||
:id => id,
|
||||
:inc => [:recordings, :media],
|
||||
:limit => 100
|
||||
})
|
||||
@tracks.sort{ |a, b| a.position <=> b.position }
|
||||
end
|
||||
@tracks.sort{ |a, b| a.position <=> b.position }
|
||||
@tracks
|
||||
end
|
||||
|
||||
class << self
|
||||
def find(mbid)
|
||||
xml = Nokogiri::XML(self.load(:release, :id => mbid, :inc => [:media])).css('release').first
|
||||
self.parse_xml(xml) unless xml.nil?
|
||||
load({
|
||||
:parser => :release_model,
|
||||
:create_model => MusicBrainz::Release
|
||||
}, {
|
||||
:resource => :release,
|
||||
:id => mbid,
|
||||
:inc => [:media]
|
||||
})
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
# -*- encoding: utf-8 -*-
|
||||
|
||||
module MusicBrainz
|
||||
class ReleaseGroup < MusicBrainz::Base
|
||||
class ReleaseGroup < Base
|
||||
|
||||
field :id, String
|
||||
field :type, String
|
||||
@@ -20,8 +21,9 @@ module MusicBrainz
|
||||
:inc => [:media],
|
||||
:limit => 100
|
||||
})
|
||||
@releases.sort!{ |a, b| a.date <=> b.date }
|
||||
end
|
||||
@releases.sort{ |a, b| a.date <=> b.date }
|
||||
@releases
|
||||
end
|
||||
|
||||
class << self
|
||||
|
||||
+16
-14
@@ -1,21 +1,23 @@
|
||||
# -*- encoding: utf-8 -*-
|
||||
|
||||
module MusicBrainz
|
||||
class Track < MusicBrainz::Base
|
||||
attr_accessor :position, :recording_id, :title, :length
|
||||
class Track < Base
|
||||
|
||||
def self.find mbid
|
||||
xml = Nokogiri::XML(self.load(:recording, :id => mbid))
|
||||
self.parse_xml(xml) unless xml.nil?
|
||||
end
|
||||
field :position, Integer
|
||||
field :recording_id, String
|
||||
field :title, String
|
||||
field :length, Integer
|
||||
|
||||
def self.parse_xml xml
|
||||
@track = MusicBrainz::Track.new
|
||||
@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
|
||||
class << self
|
||||
def find(mbid)
|
||||
load({
|
||||
:parser => :track_model,
|
||||
:create_model => MusicBrainz::Track
|
||||
}, {
|
||||
:resource => :recording,
|
||||
:id => mbid
|
||||
})
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user