AwesomePrint::MongoMapper

Public Class Methods

included(base) click to toggle source
# File lib/awesome_print/ext/mongo_mapper.rb, line 9
def self.included(base)
  base.send :alias_method, :cast_without_mongo_mapper, :cast
  base.send :alias_method, :cast, :cast_with_mongo_mapper
end

Public Instance Methods

awesome_mongo_mapper_association(object) click to toggle source

Format MongoMapper association object.

# File lib/awesome_print/ext/mongo_mapper.rb, line 92
def awesome_mongo_mapper_association(object)
  return object.inspect if !defined?(::ActiveSupport::OrderedHash)
  return awesome_object(object) if @options[:raw]

  association = object.class.name.split('::').last.titleize.downcase.sub(/ association$/,'')
  association = "embeds #{association}" if object.embeddable?
  class_name = object.class_name

  "#{colorize(association, :assoc)} #{colorize(class_name, :class)}"
end
awesome_mongo_mapper_bson_id(object) click to toggle source

Format BSON::ObjectId

# File lib/awesome_print/ext/mongo_mapper.rb, line 105
def awesome_mongo_mapper_bson_id(object)
  object.inspect
end
awesome_mongo_mapper_class(object) click to toggle source

Format MongoMapper class object.

# File lib/awesome_print/ext/mongo_mapper.rb, line 37
def awesome_mongo_mapper_class(object)
  return object.inspect if !defined?(::ActiveSupport::OrderedHash) || !object.respond_to?(:keys)

  data = object.keys.sort.inject(::ActiveSupport::OrderedHash.new) do |hash, c|
    hash[c.first] = (c.last.type || "undefined").to_s.underscore.intern
    hash
  end

  # Add in associations
  if @options[:mongo_mapper][:show_associations]
    object.associations.each do |name, assoc|
      data[name.to_s] = assoc
    end
  end

  "class #{object} < #{object.superclass} " << awesome_hash(data)
end
awesome_mongo_mapper_instance(object) click to toggle source

Format MongoMapper instance object.

NOTE: by default only instance attributes (i.e. keys) are shown. To format MongoMapper instance as regular object showing its instance variables and accessors use :raw => true option:

ap record, :raw => true

# File lib/awesome_print/ext/mongo_mapper.rb, line 64
def awesome_mongo_mapper_instance(object)
  return object.inspect if !defined?(::ActiveSupport::OrderedHash)
  return awesome_object(object) if @options[:raw]

  data = object.keys.keys.sort_by{|k| k}.inject(::ActiveSupport::OrderedHash.new) do |hash, name|
    hash[name] = object[name]
    hash
  end

  # Add in associations
  if @options[:mongo_mapper][:show_associations]
    object.associations.each do |name, assoc|
      if @options[:mongo_mapper][:inline_embedded] and assoc.embeddable?
        data[name.to_s] = object.send(name)
      else
        data[name.to_s] = assoc
      end
    end
  end

  label = object.to_s
  label = "#{colorize('embedded', :assoc)} #{label}" if object.is_a?(::MongoMapper::EmbeddedDocument)

  "#{label} " << awesome_hash(data)
end
cast_with_mongo_mapper(object, type) click to toggle source

Add MongoMapper class names to the dispatcher pipeline.

# File lib/awesome_print/ext/mongo_mapper.rb, line 16
def cast_with_mongo_mapper(object, type)
  apply_default_mongo_mapper_options
  cast = cast_without_mongo_mapper(object, type)

  if defined?(::MongoMapper::Document)
    if object.is_a?(Class) && (object.ancestors & [ ::MongoMapper::Document, ::MongoMapper::EmbeddedDocument ]).size > 0
      cast = :mongo_mapper_class
    elsif object.is_a?(::MongoMapper::Document) || object.is_a?(::MongoMapper::EmbeddedDocument)
      cast = :mongo_mapper_instance
    elsif object.is_a?(::MongoMapper::Plugins::Associations::Base)
      cast = :mongo_mapper_association
    elsif object.is_a?(::BSON::ObjectId)
      cast = :mongo_mapper_bson_id
    end
  end

  cast
end

[Validate]

Generated with the Darkfish Rdoc Generator 2.