diff --git a/README.md b/README.md index 7e608240..60425a41 100644 --- a/README.md +++ b/README.md @@ -42,6 +42,8 @@ raw: false, # Do not recursively format instance variables. sort_keys: false, # Do not sort hash keys. limit: false, # Limit arrays & hashes. Accepts bool or int. ruby19_syntax: false, # Use Ruby 1.9 hash syntax in output. +classname: :class, # Methods used to get Instance class name. +object_id: true, # Show object id. color: { args: :pale, array: :white, diff --git a/lib/awesome_print/formatters/object_formatter.rb b/lib/awesome_print/formatters/object_formatter.rb index 655a8e6a..aac774d5 100644 --- a/lib/awesome_print/formatters/object_formatter.rb +++ b/lib/awesome_print/formatters/object_formatter.rb @@ -60,7 +60,9 @@ def valid_instance_var?(variable_name) end def awesome_instance - "#{object.class}:0x%08x" % (object.__id__ * 2) + str = object.send(options[:classname]).to_s + str << ":0x%08x" % (object.__id__ * 2) if options[:object_id] + str end def left_aligned diff --git a/lib/awesome_print/inspector.rb b/lib/awesome_print/inspector.rb index 2a226b7b..e21f02c0 100644 --- a/lib/awesome_print/inspector.rb +++ b/lib/awesome_print/inspector.rb @@ -22,6 +22,8 @@ def initialize(options = {}) sort_keys: false, # Do not sort hash keys. limit: false, # Limit arrays & hashes. Accepts bool or int. ruby19_syntax: false, # Use Ruby 1.9 hash syntax in output. + classname: :class, # Method used to get Instance class name. + object_id: true, # Show object_id. color: { args: :pale, array: :white, diff --git a/spec/objects_spec.rb b/spec/objects_spec.rb index 3aaef901..165bb142 100644 --- a/spec/objects_spec.rb +++ b/spec/objects_spec.rb @@ -131,5 +131,55 @@ def initialize expect(out).to be_similar_to(str) expect(hello.ai(plain: true, raw: false)).to eq(hello.inspect) end + + it 'object_id' do + class Hello + def initialize + @abra = 1 + @ca = 2 + @dabra = 3 + end + end + + hello = Hello.new + out = hello.ai(plain: true, raw: true, object_id: false) + str = <<-EOS.strip +# +EOS + expect(out).to be_similar_to(str) + expect(hello.ai(plain: true, raw: false)).to eq(hello.inspect) + end + + it 'classname' do + class Hello + def initialize + @abra = 1 + @ca = 2 + @dabra = 3 + end + + def to_s + "CustomizedHello" + end + end + + hello = Hello.new + out = hello.ai(plain: true, raw: true, classname: :to_s) + str = <<-EOS.strip +# +EOS + expect(out).to be_similar_to(str) + expect(hello.ai(plain: true, raw: false)).to eq(hello.inspect) + end + + end end