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