Linux premium71.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
LiteSpeed
Server IP : 198.187.29.8 & Your IP : 3.145.26.35
Domains :
Cant Read [ /etc/named.conf ]
User : cleahvkv
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
ruby27 /
share /
ruby /
irb /
Delete
Unzip
Name
Size
Permission
Date
Action
cmd
[ DIR ]
drwxr-xr-x
2024-03-03 22:47
ext
[ DIR ]
drwxr-xr-x
2024-03-03 22:47
lc
[ DIR ]
drwxr-xr-x
2024-03-03 22:47
color.rb
7.74
KB
-rw-r--r--
2023-03-30 12:34
completion.rb
9.46
KB
-rw-r--r--
2023-03-30 12:34
context.rb
15.32
KB
-rw-r--r--
2023-03-30 12:34
easter-egg.rb
3.61
KB
-rw-r--r--
2023-03-30 12:34
extend-command.rb
10.13
KB
-rw-r--r--
2023-03-30 12:34
frame.rb
1.97
KB
-rw-r--r--
2023-03-30 12:34
help.rb
701
B
-rw-r--r--
2023-03-30 12:34
init.rb
8.6
KB
-rw-r--r--
2023-03-30 12:34
input-method.rb
8.96
KB
-rw-r--r--
2023-03-30 12:34
inspector.rb
3.92
KB
-rw-r--r--
2023-03-30 12:34
locale.rb
4.81
KB
-rw-r--r--
2023-03-30 12:34
magic-file.rb
928
B
-rw-r--r--
2023-03-30 12:34
notifier.rb
7.24
KB
-rw-r--r--
2023-03-30 12:34
output-method.rb
2.44
KB
-rw-r--r--
2023-03-30 12:34
ruby-lex.rb
16.6
KB
-rw-r--r--
2023-03-30 12:34
ruby_logo.aa
2.32
KB
-rw-r--r--
2023-03-30 12:34
src_encoding.rb
147
B
-rw-r--r--
2023-03-30 12:34
version.rb
296
B
-rw-r--r--
2023-03-30 12:34
workspace.rb
5.22
KB
-rw-r--r--
2023-03-30 12:34
ws-for-case-2.rb
218
B
-rw-r--r--
2023-03-30 12:34
xmp.rb
4.03
KB
-rw-r--r--
2023-03-30 12:34
Save
Rename
# frozen_string_literal: false # # xmp.rb - irb version of gotoken xmp # $Release Version: 0.9$ # $Revision$ # by Keiju ISHITSUKA(Nippon Rational Inc.) # # -- # # # require_relative "../irb" require_relative "frame" # An example printer for irb. # # It's much like the standard library PrettyPrint, that shows the value of each # expression as it runs. # # In order to use this library, you must first require it: # # require 'irb/xmp' # # Now, you can take advantage of the Object#xmp convenience method. # # xmp <<END # foo = "bar" # baz = 42 # END # #=> foo = "bar" # #==>"bar" # #=> baz = 42 # #==>42 # # You can also create an XMP object, with an optional binding to print # expressions in the given binding: # # ctx = binding # x = XMP.new ctx # x.puts # #=> today = "a good day" # #==>"a good day" # ctx.eval 'today # is what?' # #=> "a good day" class XMP # Creates a new XMP object. # # The top-level binding or, optional +bind+ parameter will be used when # creating the workspace. See WorkSpace.new for more information. # # This uses the +:XMP+ prompt mode, see IRB@Customizing+the+IRB+Prompt for # full detail. def initialize(bind = nil) IRB.init_config(nil) IRB.conf[:PROMPT_MODE] = :XMP bind = IRB::Frame.top(1) unless bind ws = IRB::WorkSpace.new(bind) @io = StringInputMethod.new @irb = IRB::Irb.new(ws, @io) @irb.context.ignore_sigint = false IRB.conf[:MAIN_CONTEXT] = @irb.context end # Evaluates the given +exps+, for example: # # require 'irb/xmp' # x = XMP.new # # x.puts '{:a => 1, :b => 2, :c => 3}' # #=> {:a => 1, :b => 2, :c => 3} # # ==>{:a=>1, :b=>2, :c=>3} # x.puts 'foo = "bar"' # # => foo = "bar" # # ==>"bar" def puts(exps) @io.puts exps if @irb.context.ignore_sigint begin trap_proc_b = trap("SIGINT"){@irb.signal_handle} catch(:IRB_EXIT) do @irb.eval_input end ensure trap("SIGINT", trap_proc_b) end else catch(:IRB_EXIT) do @irb.eval_input end end end # A custom InputMethod class used by XMP for evaluating string io. class StringInputMethod < IRB::InputMethod # Creates a new StringInputMethod object def initialize super @exps = [] end # Whether there are any expressions left in this printer. def eof? @exps.empty? end # Reads the next expression from this printer. # # See IO#gets for more information. def gets while l = @exps.shift next if /^\s+$/ =~ l l.concat "\n" print @prompt, l break end l end # Concatenates all expressions in this printer, separated by newlines. # # An Encoding::CompatibilityError is raised of the given +exps+'s encoding # doesn't match the previous expression evaluated. def puts(exps) if @encoding and exps.encoding != @encoding enc = Encoding.compatible?(@exps.join("\n"), exps) if enc.nil? raise Encoding::CompatibilityError, "Encoding in which the passed expression is encoded is not compatible to the preceding's one" else @encoding = enc end else @encoding = exps.encoding end @exps.concat exps.split(/\n/) end # Returns the encoding of last expression printed by #puts. attr_reader :encoding end end # A convenience method that's only available when the you require the IRB::XMP standard library. # # Creates a new XMP object, using the given expressions as the +exps+ # parameter, and optional binding as +bind+ or uses the top-level binding. Then # evaluates the given expressions using the +:XMP+ prompt mode. # # For example: # # require 'irb/xmp' # ctx = binding # xmp 'foo = "bar"', ctx # #=> foo = "bar" # #==>"bar" # ctx.eval 'foo' # #=> "bar" # # See XMP.new for more information. def xmp(exps, bind = nil) bind = IRB::Frame.top(1) unless bind xmp = XMP.new(bind) xmp.puts exps xmp end