class PP
Ein Pretty-Printer für Ruby-Objekte.
Was PP tut
Standardausgabe von p gibt dies zurück
#<PP:0x81fedf0 @genspace=#<Proc:0x81feda0>, @group_queue=#<PrettyPrint::GroupQueue:0x81fed3c @queue=[[#<PrettyPrint::Group:0x81fed78 @breakables=[], @depth=0, @break=false>], []]>, @buffer=[], @newline="\n", @group_stack=[#<PrettyPrint::Group:0x81fed78 @breakables=[], @depth=0, @break=false>], @buffer_width=0, @indent=0, @maxwidth=79, @output_width=2, @output=#<IO:0x8114ee4>>
Schön formatierte Ausgabe gibt dies zurück
#<PP:0x81fedf0
@buffer=[],
@buffer_width=0,
@genspace=#<Proc:0x81feda0>,
@group_queue=
#<PrettyPrint::GroupQueue:0x81fed3c
@queue=
[[#<PrettyPrint::Group:0x81fed78 @break=false, @breakables=[], @depth=0>],
[]]>,
@group_stack=
[#<PrettyPrint::Group:0x81fed78 @break=false, @breakables=[], @depth=0>],
@indent=0,
@maxwidth=79,
@newline="\n",
@output=#<IO:0x8114ee4>,
@output_width=2>
Verwendung
pp(obj) #=> obj pp obj #=> obj pp(obj1, obj2, ...) #=> [obj1, obj2, ...] pp() #=> nil
Gibt obj(s) in schön formatiertem Format an $> aus.
Gibt obj(s) zurück.
Anpassung der Ausgabe
Um eine angepasste schön formatierte Druckfunktion für Ihre Klassen zu definieren, überschreiben Sie die Methode pretty_print(pp) in der Klasse. Beachten Sie, dass require 'pp' benötigt wird, bevor Sie pretty_print(pp) überschreiben.
pretty_print nimmt das pp-Argument, bei dem es sich um eine Instanz der PP-Klasse handelt. Die Methode verwendet text, breakable, nest, group und pp, um das Objekt zu drucken.
Schön formatierte Ausgabe JSON
Für die schön formatierte Ausgabe von JSON siehe JSON#pretty_generate.
Autor
Tanaka Akira <akr@fsij.org>
Constants
- VERSION
-
Die Versionszeichenfolge
Öffentliche Klassenmethoden
Source
# File lib/pp.rb, line 96 def PP.pp(obj, out=$>, width=width_for(out)) q = new(out, width) q.guard_inspect_key {q.pp obj} q.flush #$pp = q out << "\n" end
Source
# File lib/pp.rb, line 125 def sharing_detection Ractor.current[:pp_sharing_detection] end
Gibt das Flag zur Erkennung von Duplikaten als booleschen Wert zurück. Es ist standardmäßig false (nil).
Source
# File lib/pp.rb, line 129 def sharing_detection=(b) Ractor.current[:pp_sharing_detection] = b end
Setzt das Flag zur Erkennung von Duplikaten auf b.
Source
# File lib/pp.rb, line 108 def PP.singleline_pp(obj, out=$>) q = SingleLine.new(out) q.guard_inspect_key {q.pp obj} q.flush out end
Gibt obj an out aus, ähnlich wie PP.pp, jedoch ohne Einrückung und Zeilenumbruch.
PP.singleline_pp gibt out zurück.
Source
# File lib/pp.rb, line 79 def PP.width_for(out) begin require 'io/console' _, width = out.winsize rescue LoadError, NoMethodError, SystemCallError end (width || ENV['COLUMNS']&.to_i&.nonzero? || 80) - 1 end
Gibt die nutzbare Breite für out zurück. Da die Breite von out
-
Wenn
outeinem TTY-Gerät zugewiesen ist, wird dessen Breite verwendet. -
Andernfalls, oder wenn der Wert nicht abgerufen werden kann, wird die Umgebungsvariable
COLUMNauf die Breite gesetzt angenommen. -
Wenn
COLUMNnicht auf eine Zahl ungleich Null gesetzt ist, wird 80 angenommen.
Und schließlich wird der obige Breitenwert - 1 zurückgegeben.
-
Dieses -1 ist für die Windows-Kommandozeile, die den Cursor zur nächsten Zeile bewegt, wenn die letzte Spalte erreicht wird.