Merged
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
module MusicBrainz
|
||||
class Artist < MusicBrainz::Base
|
||||
attr_accessor :id, :type, :name, :country, :date_begin, :date_end
|
||||
attr_accessor :id, :type, :name, :country, :date_begin, :date_end, :urls
|
||||
@release_groups
|
||||
|
||||
def release_groups
|
||||
@@ -14,7 +14,7 @@ module MusicBrainz
|
||||
end
|
||||
|
||||
def self.find mbid
|
||||
res = MusicBrainz.load :artist, :id => mbid
|
||||
res = MusicBrainz.load :artist, :id => mbid, :inc => [:url_rels]
|
||||
return nil if res.nil?
|
||||
@artist = self.parse_xml(Nokogiri::XML(res))
|
||||
end
|
||||
@@ -27,6 +27,10 @@ module MusicBrainz
|
||||
@artist.country = self.safe_get_value(xml, 'artist > country')
|
||||
@artist.date_begin = self.safe_get_value(xml, 'artist > life-span > begin')
|
||||
@artist.date_end = self.safe_get_value(xml, 'artist > life-span > end')
|
||||
@artist.urls = {}
|
||||
xml.css('relation-list[target-type="url"] > relation').each do |rel|
|
||||
@artist.urls[rel.attr('type').downcase.split(' ').join('_').to_sym] = rel.css('target').text
|
||||
end
|
||||
@artist
|
||||
end
|
||||
|
||||
|
||||
@@ -1,12 +1,12 @@
|
||||
module MusicBrainz
|
||||
class Release < MusicBrainz::Base
|
||||
attr_accessor :id, :title, :status, :date, :country
|
||||
attr_accessor :id, :title, :status, :format, :date, :country
|
||||
@tracks
|
||||
|
||||
def tracks
|
||||
if @tracks.nil? and not self.id.nil?
|
||||
@tracks = []
|
||||
Nokogiri::XML(MusicBrainz.load(:release, :id => self.id, :inc => [:recordings], :limit => 100)).css('medium-list > medium > track-list > track').each do |r|
|
||||
Nokogiri::XML(MusicBrainz.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
|
||||
end
|
||||
@@ -14,7 +14,7 @@ module MusicBrainz
|
||||
end
|
||||
|
||||
def self.find mbid
|
||||
xml = Nokogiri::XML(MusicBrainz.load(:release, :id => mbid)).css('release').first
|
||||
xml = Nokogiri::XML(MusicBrainz.load(:release, :id => mbid, :inc => [:media])).css('release').first
|
||||
self.parse_xml(xml) unless xml.nil?
|
||||
end
|
||||
|
||||
@@ -23,6 +23,7 @@ module MusicBrainz
|
||||
@release.id = self.safe_get_attr(xml, nil, 'id')
|
||||
@release.title = self.safe_get_value(xml, 'title')
|
||||
@release.status = self.safe_get_value(xml, 'status')
|
||||
@release.format = self.safe_get_value(xml, 'medium-list > medium > format')
|
||||
date = xml.css('date').empty? ? '2030-12-31' : xml.css('date').text
|
||||
if date.length == 0
|
||||
date = '2030-12-31'
|
||||
|
||||
Reference in New Issue
Block a user