lib/ruby-tmdb/tmdb_cast.rb in ruby-tmdb-0.1.0 vs lib/ruby-tmdb/tmdb_cast.rb in ruby-tmdb-0.1.1

- old
+ new

@@ -1,8 +1,12 @@ class TmdbCast def self.find(options) + options = { + :expand_results => true + }.merge(options) + raise ArgumentError, "At least one of: id, name, should be supplied" if(options[:id].nil? && options[:name].nil?) results = [] unless(options[:id].nil? || options[:id].to_s.empty?) results << Tmdb.api_call('Person.getInfo', options[:id]) @@ -16,57 +20,21 @@ unless(options[:limit].nil?) raise ArgumentError, ":limit must be an integer greater than 0" unless(options[:limit].is_a?(Fixnum) && options[:limit] > 0) results = results.slice(0, options[:limit]) end - results.map!{|c| TmdbCast.new(c) } + results.map!{|c| TmdbCast.new(c, options[:expand_results]) } if(results.length == 1) return results[0] else return results end end - def initialize(raw_data) - @raw_data = raw_data - @raw_data = Tmdb.api_call('Person.getInfo', @raw_data["id"]).first - @raw_data["profiles"] = @raw_data["profile"] - @raw_data.delete("profile") - @raw_data.each_pair do |key, value| - instance_eval <<-EOD - def #{key} - @raw_data["#{key}"] - end - EOD - if(value.is_a?(Array)) - value.each_index do |x| - if(value[x].is_a?(Hash) && value[x].length == 1) - if(value[x].keys[0] == "image") - value[x][value[x].keys[0]].instance_eval <<-EOD - def self.data - Tmdb.get_url(self["url"]).body - end - EOD - end - value[x] = value[x][value[x].keys[0]] - end - if(value[x].is_a?(Hash)) - value[x].each_pair do |key2, value2| - value[x].instance_eval <<-EOD - def self.#{key2} - self["#{key2}"] - end - EOD - end - end - end - end - end - end - - def raw_data - @raw_data + def self.new(raw_data, expand_results = false) + raw_data = Tmdb.api_call('Person.getInfo', raw_data["id"]).first + return Tmdb.data_to_object(raw_data) end def ==(other) return false unless(other.is_a?(TmdbCast)) @raw_data == other.raw_data \ No newline at end of file