Bug #7656
closedHandful of documentations
Description
This fixes documentation in ENV, adds a little for debug.rb, and completes PP
Files
        
           Updated by zzak (zzak _) almost 13 years ago
          Updated by zzak (zzak _) almost 13 years ago
          
          
        
        
      
      Awesome, thank you!!
        
           Updated by vbatts (Vincent Batts) almost 13 years ago
          Updated by vbatts (Vincent Batts) almost 13 years ago
          
          
        
        
      
      Is there anything I can do better?
        
           Updated by zzak (zzak _) almost 13 years ago
          Updated by zzak (zzak _) almost 13 years ago
          
          
        
        
      
      vbatts (Vincent Batts) wrote:
Is there anything I can do better?
These are good, for small changes I don't mind grouping them into one patch, though I'll probably commit them separately.
I noticed a few small spelling errors, like usage vs useage, but nothing I can't handle myself.
Sorry for dragging my feet on these, but you're doing a good job Vincent. Thank you!
        
           Updated by zzak (zzak _) over 12 years ago
          Updated by zzak (zzak _) over 12 years ago
          
          
        
        
      
      - Status changed from Open to Feedback
- Assignee changed from zzak (zzak _) to vbatts (Vincent Batts)
Hello Vincent,
I've committed your patch for lib/debug. as r39019, I was reviewing your patch for lib/pp.rb and noticed the example for PPMethods::check_inspect_key doesn't work in trunk.
::check_inspect_key(obj.object_id) returns nil
then ::push_inspect_key(obj.object_id) raises: NoMethodError: undefined method `[]=' for nil:NilClass
        
           Updated by vbatts (Vincent Batts) over 12 years ago
          Updated by vbatts (Vincent Batts) over 12 years ago
          
          
        
        
      
      interesting, doing a little bootleg debugging
diff --git a/lib/pp.rb b/lib/pp.rb
index 6e0c797..681956d 100644
--- a/lib/pp.rb
+++ b/lib/pp.rb
@@ -145,13 +145,16 @@ class PP < PrettyPrint
def pp(obj)
id = obj.object_id
- 
puts check_inspect_key(id) if check_inspect_key(id) group {obj.pretty_print_cycle self} return end begin
- 
push_inspect_key(id)
- 
puts push_inspect_key(id)
- 
puts check_inspect_key(id)
- 
p Thread.current[:__recursive_key__][:inspect] group {obj.pretty_print self} ensure pop_inspect_key(id) unless PP.sharing_detection
and running
<~/foo.rb>
class Foo
def pretty_print(q)
q.text 'foo'
end
end
f = Foo.new
pp f
</~/foo.rb>
I get the following results:
vbatts@satellite ~/src/ruby (trunk) $ ruby -I./lib -r pp  ~/foo.rb
false
true
true
{67976200=>true, 67976030=>true}
foo
        
           Updated by vbatts (Vincent Batts) over 12 years ago
          Updated by vbatts (Vincent Batts) over 12 years ago
          
          
        
        
      
      I see, the example added to the methods is misleading. I'll revamp the docs for PP, and create a new issue.
        
           Updated by vbatts (Vincent Batts) over 12 years ago
          Updated by vbatts (Vincent Batts) over 12 years ago
          
          
        
        
      
      Alrighty, since I don't have rights to close issues, I'll just add the updated PP/PrettyPrint patch here.
This patch fixes the confusing *_inspect_key example and also sets nodoc on the pretty print modifications to basic objects.
This patch also completes the documentation for PrettyPrint.
        
           Updated by zzak (zzak _) over 12 years ago
          Updated by zzak (zzak _) over 12 years ago
          
          
        
        
      
      - Status changed from Feedback to Assigned
- Assignee changed from vbatts (Vincent Batts) to zzak (zzak _)
Thanks Vincent! I will review this and commit tonight.
        
           Updated by zzak (zzak _) over 12 years ago
          Updated by zzak (zzak _) over 12 years ago
          
          
        
        
      
      - Status changed from Assigned to Closed
- % Done changed from 0 to 100
This issue was solved with changeset r39180.
Vincent, thank you for reporting this issue.
Your contribution to Ruby is greatly appreciated.
May Ruby be with you.
- lib/pp.rb, lib/prettyprint.rb: Documentation for PP and PrettyPrint
 Based on a patch by Vincent Batts [ruby-core:51253] [Bug #7656]