OXIESEC PANEL
- Current Dir:
/
/
usr
/
lib
/
ruby
/
2.5.0
/
irb
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📁
cmd
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
completion.rb
6.49 KB
12/16/2015 05:07:31 AM
rw-r--r--
📄
context.rb
12.36 KB
04/20/2017 09:11:36 AM
rw-r--r--
📁
ext
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
extend-command.rb
9.62 KB
04/20/2017 09:11:36 AM
rw-r--r--
📄
frame.rb
1.92 KB
12/16/2015 05:07:31 AM
rw-r--r--
📄
help.rb
705 bytes
12/16/2015 05:07:31 AM
rw-r--r--
📄
init.rb
7.58 KB
12/12/2017 03:01:07 PM
rw-r--r--
📄
input-method.rb
4.63 KB
12/16/2015 05:07:31 AM
rw-r--r--
📄
inspector.rb
3.61 KB
12/16/2015 05:07:31 AM
rw-r--r--
📁
lc
-
05/09/2024 07:14:11 AM
rwxr-xr-x
📄
locale.rb
4.64 KB
12/12/2017 11:56:25 AM
rw-r--r--
📄
magic-file.rb
928 bytes
06/15/2017 10:43:17 AM
rw-r--r--
📄
notifier.rb
7.18 KB
10/07/2016 05:18:57 AM
rw-r--r--
📄
output-method.rb
2.44 KB
10/07/2016 05:18:57 AM
rw-r--r--
📄
ruby-lex.rb
24.21 KB
04/20/2017 11:07:02 AM
rw-r--r--
📄
ruby-token.rb
7.37 KB
12/16/2015 05:07:31 AM
rw-r--r--
📄
slex.rb
6.83 KB
01/09/2017 02:45:28 AM
rw-r--r--
📄
src_encoding.rb
147 bytes
06/15/2017 10:43:17 AM
rw-r--r--
📄
version.rb
282 bytes
12/16/2015 05:07:31 AM
rw-r--r--
📄
workspace.rb
3.89 KB
11/24/2017 11:00:10 AM
rw-r--r--
📄
ws-for-case-2.rb
226 bytes
12/16/2015 05:07:31 AM
rw-r--r--
📄
xmp.rb
4.02 KB
12/16/2015 05:07:31 AM
rw-r--r--
Editing: inspector.rb
Close
# frozen_string_literal: false # # irb/inspector.rb - inspect methods # $Release Version: 0.9.6$ # $Revision: 1.19 $ # $Date: 2002/06/11 07:51:31 $ # by Keiju ISHITSUKA(keiju@ruby-lang.org) # # -- # # # module IRB # :nodoc: # Convenience method to create a new Inspector, using the given +inspect+ # proc, and optional +init+ proc and passes them to Inspector.new # # irb(main):001:0> ins = IRB::Inspector(proc{ |v| "omg! #{v}" }) # irb(main):001:0> IRB.CurrentContext.inspect_mode = ins # => omg! #<IRB::Inspector:0x007f46f7ba7d28> # irb(main):001:0> "what?" #=> omg! what? # def IRB::Inspector(inspect, init = nil) Inspector.new(inspect, init) end # An irb inspector # # In order to create your own custom inspector there are two things you # should be aware of: # # Inspector uses #inspect_value, or +inspect_proc+, for output of return values. # # This also allows for an optional #init+, or +init_proc+, which is called # when the inspector is activated. # # Knowing this, you can create a rudimentary inspector as follows: # # irb(main):001:0> ins = IRB::Inspector.new(proc{ |v| "omg! #{v}" }) # irb(main):001:0> IRB.CurrentContext.inspect_mode = ins # => omg! #<IRB::Inspector:0x007f46f7ba7d28> # irb(main):001:0> "what?" #=> omg! what? # class Inspector # Default inspectors available to irb, this includes: # # +:pp+:: Using Kernel#pretty_inspect # +:yaml+:: Using YAML.dump # +:marshal+:: Using Marshal.dump INSPECTORS = {} # Determines the inspector to use where +inspector+ is one of the keys passed # during inspector definition. def self.keys_with_inspector(inspector) INSPECTORS.select{|k,v| v == inspector}.collect{|k, v| k} end # Example # # Inspector.def_inspector(key, init_p=nil){|v| v.inspect} # Inspector.def_inspector([key1,..], init_p=nil){|v| v.inspect} # Inspector.def_inspector(key, inspector) # Inspector.def_inspector([key1,...], inspector) def self.def_inspector(key, arg=nil, &block) if block_given? inspector = IRB::Inspector(block, arg) else inspector = arg end case key when Array for k in key def_inspector(k, inspector) end when Symbol INSPECTORS[key] = inspector INSPECTORS[key.to_s] = inspector when String INSPECTORS[key] = inspector INSPECTORS[key.intern] = inspector else INSPECTORS[key] = inspector end end # Creates a new inspector object, using the given +inspect_proc+ when # output return values in irb. def initialize(inspect_proc, init_proc = nil) @init = init_proc @inspect = inspect_proc end # Proc to call when the inspector is activated, good for requiring # dependent libraries. def init @init.call if @init end # Proc to call when the input is evaluated and output in irb. def inspect_value(v) @inspect.call(v) end end Inspector.def_inspector([false, :to_s, :raw]){|v| v.to_s} Inspector.def_inspector([true, :p, :inspect]){|v| begin v.inspect rescue NoMethodError puts "(Object doesn't support #inspect)" end } Inspector.def_inspector([:pp, :pretty_inspect], proc{require "pp"}){|v| v.pretty_inspect.chomp} Inspector.def_inspector([:yaml, :YAML], proc{require "yaml"}){|v| begin YAML.dump(v) rescue puts "(can't dump yaml. use inspect)" v.inspect end } Inspector.def_inspector([:marshal, :Marshal, :MARSHAL, Marshal]){|v| Marshal.dump(v) } end