module AwesomePrint::Puppet

Public Class Methods

included(base) click to toggle source
# File lib/awesome_print/ext/awesome_puppet.rb, line 3
def self.included(base)
  base.send :alias_method, :cast_without_puppet_resource, :cast
  base.send :alias_method, :cast, :cast_with_puppet_resource
end

Public Instance Methods

awesome_puppet_resource(object) click to toggle source
# File lib/awesome_print/ext/awesome_puppet.rb, line 25
def awesome_puppet_resource(object)
  return '' if object.nil?
  awesome_puppet_type(object.to_ral)
end
awesome_puppet_type(object) click to toggle source
# File lib/awesome_print/ext/awesome_puppet.rb, line 30
def awesome_puppet_type(object)
  return '' if object.nil?
  return object.to_s unless object.respond_to?(:name) && object.respond_to?(:title)
  h = object.to_hash.merge(:name => object.name, :title => object.title)
  res_str = awesome_hash(h)
  "#{object.class} #{res_str.gsub(':', '')}"
end
cast_with_puppet_resource(object, type) click to toggle source

this tells ap how to cast our object so we can be specific about printing different puppet objects

# File lib/awesome_print/ext/awesome_puppet.rb, line 10
def cast_with_puppet_resource(object, type)
  cast = cast_without_puppet_resource(object, type)
  # check the object to see if it has an acestor (< ) of the specified type
  if (defined?(::Puppet::Type)) && (object.class < ::Puppet::Type)
    cast = :puppet_type
  elsif (defined?(::Puppet::Pops::Types)) && (object.class < ::Puppet::Pops::Types)
    cast = :puppet_type
  elsif (defined?(::Puppet::Parser::Resource)) && (object.class < ::Puppet::Parser::Resource)
    cast = :puppet_resource
  elsif /Puppet::Pops::Types/.match(object.class.to_s)
    cast = :puppet_type
  end
  cast
end