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.144.235.50
Domains :
Cant Read [ /etc/named.conf ]
User : cleahvkv
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
ruby22 /
lib64 /
ruby /
2.2.0 /
Delete
Unzip
Name
Size
Permission
Date
Action
cgi
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
digest
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
drb
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
fiddle
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
io
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
irb
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
json
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
matrix
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
net
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
openssl
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
optparse
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
psych
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
racc
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
rake
[ DIR ]
drwxr-xr-x
2024-03-03 22:53
rbconfig
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
rdoc
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
rexml
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
rinda
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
ripper
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
rss
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
rubygems
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
shell
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
syslog
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
unicode_normalize
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
uri
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
webrick
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
x86_64-linux
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
xmlrpc
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
yaml
[ DIR ]
drwxr-xr-x
2024-03-03 22:43
English.rb
6.42
KB
-rw-r--r--
2014-05-31 19:54
abbrev.rb
3.46
KB
-rw-r--r--
2014-07-11 08:16
base64.rb
2.63
KB
-rw-r--r--
2013-05-19 03:10
benchmark.rb
17.73
KB
-rw-r--r--
2014-09-11 08:09
cgi.rb
9.77
KB
-rw-r--r--
2014-08-07 06:14
cmath.rb
9.34
KB
-rw-r--r--
2015-07-03 19:31
csv.rb
82.45
KB
-rw-r--r--
2014-11-04 03:21
date.rb
980
B
-rw-r--r--
2023-07-26 14:31
debug.rb
29.08
KB
-rw-r--r--
2013-12-14 14:48
delegate.rb
10.71
KB
-rw-r--r--
2014-07-26 17:11
digest.rb
2.79
KB
-rw-r--r--
2023-07-26 14:31
drb.rb
19
B
-rw-r--r--
2009-10-02 10:45
e2mmap.rb
3.77
KB
-rw-r--r--
2014-08-24 07:16
erb.rb
26.35
KB
-rw-r--r--
2014-12-12 10:48
expect.rb
2.14
KB
-rw-r--r--
2023-07-26 14:31
fiddle.rb
1.65
KB
-rw-r--r--
2023-07-26 14:31
fileutils.rb
47.46
KB
-rw-r--r--
2017-03-25 18:24
find.rb
2.48
KB
-rw-r--r--
2014-10-13 07:34
forwardable.rb
8.22
KB
-rw-r--r--
2017-03-25 14:43
getoptlong.rb
15.38
KB
-rw-r--r--
2013-05-19 14:50
ipaddr.rb
17.06
KB
-rw-r--r--
2015-11-24 15:49
irb.rb
20.03
KB
-rw-r--r--
2016-03-28 15:07
json.rb
1.74
KB
-rw-r--r--
2023-07-26 14:31
kconv.rb
5.74
KB
-rw-r--r--
2023-07-26 14:31
logger.rb
20.33
KB
-rw-r--r--
2016-10-27 07:47
mathn.rb
3.84
KB
-rw-r--r--
2014-08-26 12:07
matrix.rb
53.14
KB
-rw-r--r--
2014-11-27 01:03
mkmf.rb
82.59
KB
-rw-r--r--
2023-07-26 14:29
monitor.rb
6.93
KB
-rw-r--r--
2012-11-16 16:55
mutex_m.rb
2
KB
-rw-r--r--
2013-02-20 02:51
observer.rb
5.8
KB
-rw-r--r--
2014-08-27 12:21
open-uri.rb
24.58
KB
-rw-r--r--
2014-12-24 09:11
open3.rb
20.55
KB
-rw-r--r--
2014-11-04 03:09
openssl.rb
528
B
-rw-r--r--
2023-07-26 14:31
optionparser.rb
28
B
-rw-r--r--
2014-05-26 03:25
optparse.rb
52.05
KB
-rw-r--r--
2017-03-25 18:28
ostruct.rb
8.66
KB
-rw-r--r--
2017-03-25 18:35
pathname.rb
15.58
KB
-rw-r--r--
2023-07-26 14:31
pp.rb
14.16
KB
-rw-r--r--
2014-12-05 19:35
prettyprint.rb
15.85
KB
-rw-r--r--
2014-08-22 02:38
prime.rb
13.11
KB
-rw-r--r--
2014-12-10 20:38
profile.rb
205
B
-rw-r--r--
2009-10-02 10:45
profiler.rb
4.51
KB
-rw-r--r--
2013-05-19 23:04
pstore.rb
14.55
KB
-rw-r--r--
2014-07-23 19:31
psych.rb
14.88
KB
-rw-r--r--
2023-07-26 14:31
rake.rb
2.23
KB
-rw-r--r--
2014-12-06 00:22
rdoc.rb
4.96
KB
-rw-r--r--
2014-12-07 01:22
resolv-replace.rb
1.73
KB
-rw-r--r--
2013-03-11 13:47
resolv.rb
72.06
KB
-rw-r--r--
2015-05-19 17:05
ripper.rb
2.53
KB
-rw-r--r--
2023-07-26 14:31
rss.rb
2.84
KB
-rw-r--r--
2011-05-11 10:22
rubygems.rb
31.85
KB
-rw-r--r--
2018-02-16 16:27
scanf.rb
23.54
KB
-rw-r--r--
2014-02-15 01:33
securerandom.rb
9.2
KB
-rw-r--r--
2016-04-22 09:17
set.rb
19.15
KB
-rw-r--r--
2014-08-06 11:28
shell.rb
11.3
KB
-rw-r--r--
2014-08-24 07:16
shellwords.rb
5.96
KB
-rw-r--r--
2014-09-05 10:00
singleton.rb
4.02
KB
-rw-r--r--
2011-05-18 14:09
socket.rb
25.6
KB
-rw-r--r--
2023-07-26 14:31
sync.rb
7.25
KB
-rw-r--r--
2013-05-19 03:10
tempfile.rb
11.11
KB
-rw-r--r--
2014-09-21 01:40
thwait.rb
3.31
KB
-rw-r--r--
2014-08-27 12:10
time.rb
22.25
KB
-rw-r--r--
2015-08-03 19:11
timeout.rb
3.64
KB
-rw-r--r--
2015-08-10 17:08
tmpdir.rb
4.13
KB
-rw-r--r--
2018-03-28 14:34
tracer.rb
6.4
KB
-rw-r--r--
2013-07-18 13:50
tsort.rb
14.27
KB
-rw-r--r--
2014-11-26 10:46
ubygems.rb
268
B
-rw-r--r--
2009-10-02 10:45
un.rb
8.87
KB
-rw-r--r--
2013-07-05 13:43
unicode_normalize.rb
3.16
KB
-rw-r--r--
2015-01-16 02:06
uri.rb
3.07
KB
-rw-r--r--
2014-11-03 00:33
weakref.rb
2.92
KB
-rw-r--r--
2014-07-26 17:12
webrick.rb
6.69
KB
-rw-r--r--
2013-10-05 23:39
xmlrpc.rb
8.49
KB
-rw-r--r--
2013-12-12 03:09
yaml.rb
1.7
KB
-rw-r--r--
2014-06-26 02:52
Save
Rename
# # shell.rb - # $Release Version: 0.7 $ # $Revision: 1.9 $ # by Keiju ISHITSUKA(keiju@ruby-lang.org) # # -- # # # require "e2mmap" require "thread" unless defined?(Mutex) require "forwardable" require "shell/error" require "shell/command-processor" require "shell/process-controller" # Shell implements an idiomatic Ruby interface for common UNIX shell commands. # # It provides users the ability to execute commands with filters and pipes, # like +sh+/+csh+ by using native facilities of Ruby. # # == Examples # # === Temp file creation # # In this example we will create three +tmpFile+'s in three different folders # under the +/tmp+ directory. # # sh = Shell.cd("/tmp") # Change to the /tmp directory # sh.mkdir "shell-test-1" unless sh.exists?("shell-test-1") # # make the 'shell-test-1' directory if it doesn't already exist # sh.cd("shell-test-1") # Change to the /tmp/shell-test-1 directory # for dir in ["dir1", "dir3", "dir5"] # if !sh.exists?(dir) # sh.mkdir dir # make dir if it doesn't already exist # sh.cd(dir) do # # change to the `dir` directory # f = sh.open("tmpFile", "w") # open a new file in write mode # f.print "TEST\n" # write to the file # f.close # close the file handler # end # print sh.pwd # output the process working directory # end # end # # === Temp file creation with self # # This example is identical to the first, except we're using # CommandProcessor#transact. # # CommandProcessor#transact executes the given block against self, in this case # +sh+; our Shell object. Within the block we can substitute +sh.cd+ to +cd+, # because the scope within the block uses +sh+ already. # # sh = Shell.cd("/tmp") # sh.transact do # mkdir "shell-test-1" unless exists?("shell-test-1") # cd("shell-test-1") # for dir in ["dir1", "dir3", "dir5"] # if !exists?(dir) # mkdir dir # cd(dir) do # f = open("tmpFile", "w") # f.print "TEST\n" # f.close # end # print pwd # end # end # end # # === Pipe /etc/printcap into a file # # In this example we will read the operating system file +/etc/printcap+, # generated by +cupsd+, and then output it to a new file relative to the +pwd+ # of +sh+. # # sh = Shell.new # sh.cat("/etc/printcap") | sh.tee("tee1") > "tee2" # (sh.cat < "/etc/printcap") | sh.tee("tee11") > "tee12" # sh.cat("/etc/printcap") | sh.tee("tee1") >> "tee2" # (sh.cat < "/etc/printcap") | sh.tee("tee11") >> "tee12" # class Shell include Error extend Exception2MessageMapper # debug: true -> normal debug # debug: 1 -> eval definition debug # debug: 2 -> detail inspect debug @debug = false @verbose = true @debug_display_process_id = false @debug_display_thread_id = true @debug_output_mutex = Mutex.new class << Shell extend Forwardable attr_accessor :cascade, :debug, :verbose alias debug? debug alias verbose? verbose @verbose = true def debug=(val) @debug = val @verbose = val if val end # call-seq: # Shell.cd(path) # # Creates a new Shell instance with the current working directory # set to +path+. def cd(path) new(path) end # Returns the directories in the current shell's PATH environment variable # as an array of directory names. This sets the system_path for all # instances of Shell. # # Example: If in your current shell, you did: # # $ echo $PATH # /usr/bin:/bin:/usr/local/bin # # Running this method in the above shell would then return: # # ["/usr/bin", "/bin", "/usr/local/bin"] # def default_system_path if @default_system_path @default_system_path else ENV["PATH"].split(":") end end # Sets the system_path that new instances of Shell should have as their # initial system_path. # # +path+ should be an array of directory name strings. def default_system_path=(path) @default_system_path = path end def default_record_separator if @default_record_separator @default_record_separator else $/ end end def default_record_separator=(rs) @default_record_separator = rs end # os resource mutex mutex_methods = ["unlock", "lock", "locked?", "synchronize", "try_lock", "exclusive_unlock"] for m in mutex_methods def_delegator("@debug_output_mutex", m, "debug_output_"+m.to_s) end end # call-seq: # Shell.new(pwd, umask) -> obj # # Creates a Shell object which current directory is set to the process # current directory, unless otherwise specified by the +pwd+ argument. def initialize(pwd = Dir.pwd, umask = nil) @cwd = File.expand_path(pwd) @dir_stack = [] @umask = umask @system_path = Shell.default_system_path @record_separator = Shell.default_record_separator @command_processor = CommandProcessor.new(self) @process_controller = ProcessController.new(self) @verbose = Shell.verbose @debug = Shell.debug end # Returns the command search path in an array attr_reader :system_path # Sets the system path (the Shell instance's PATH environment variable). # # +path+ should be an array of directory name strings. def system_path=(path) @system_path = path rehash end # Returns the umask attr_accessor :umask attr_accessor :record_separator attr_accessor :verbose, :debug def debug=(val) @debug = val @verbose = val if val end alias verbose? verbose alias debug? debug attr_reader :command_processor attr_reader :process_controller def expand_path(path) File.expand_path(path, @cwd) end # Most Shell commands are defined via CommandProcessor # # Dir related methods # # Shell#cwd/dir/getwd/pwd # Shell#chdir/cd # Shell#pushdir/pushd # Shell#popdir/popd # Shell#mkdir # Shell#rmdir # Returns the current working directory. attr_reader :cwd alias dir cwd alias getwd cwd alias pwd cwd attr_reader :dir_stack alias dirs dir_stack # call-seq: # Shell.chdir(path) # # Creates a Shell object which current directory is set to +path+. # # If a block is given, it restores the current directory when the block ends. # # If called as iterator, it restores the current directory when the # block ends. def chdir(path = nil, verbose = @verbose) check_point if iterator? notify("chdir(with block) #{path}") if verbose cwd_old = @cwd begin chdir(path, nil) yield ensure chdir(cwd_old, nil) end else notify("chdir #{path}") if verbose path = "~" unless path @cwd = expand_path(path) notify "current dir: #{@cwd}" rehash Void.new(self) end end alias cd chdir # call-seq: # pushdir(path) # pushdir(path) { &block } # # Pushes the current directory to the directory stack, changing the current # directory to +path+. # # If +path+ is omitted, it exchanges its current directory and the top of its # directory stack. # # If a block is given, it restores the current directory when the block ends. def pushdir(path = nil, verbose = @verbose) check_point if iterator? notify("pushdir(with block) #{path}") if verbose pushdir(path, nil) begin yield ensure popdir end elsif path notify("pushdir #{path}") if verbose @dir_stack.push @cwd chdir(path, nil) notify "dir stack: [#{@dir_stack.join ', '}]" self else notify("pushdir") if verbose if pop = @dir_stack.pop @dir_stack.push @cwd chdir pop notify "dir stack: [#{@dir_stack.join ', '}]" self else Shell.Fail DirStackEmpty end end Void.new(self) end alias pushd pushdir # Pops a directory from the directory stack, and sets the current directory # to it. def popdir check_point notify("popdir") if pop = @dir_stack.pop chdir pop notify "dir stack: [#{@dir_stack.join ', '}]" self else Shell.Fail DirStackEmpty end Void.new(self) end alias popd popdir # Returns a list of scheduled jobs. def jobs @process_controller.jobs end # call-seq: # kill(signal, job) # # Sends the given +signal+ to the given +job+ def kill(sig, command) @process_controller.kill_job(sig, command) end # call-seq: # def_system_command(command, path = command) # # Convenience method for Shell::CommandProcessor.def_system_command. # Defines an instance method which will execute the given shell command. # If the executable is not in Shell.default_system_path, you must # supply the path to it. # # Shell.def_system_command('hostname') # Shell.new.hostname # => localhost # # # How to use an executable that's not in the default path # # Shell.def_system_command('run_my_program', "~/hello") # Shell.new.run_my_program # prints "Hello from a C program!" # def Shell.def_system_command(command, path = command) CommandProcessor.def_system_command(command, path) end # Convenience method for Shell::CommandProcessor.undef_system_command def Shell.undef_system_command(command) CommandProcessor.undef_system_command(command) end # call-seq: # alias_command(alias, command, *opts, &block) # # Convenience method for Shell::CommandProcessor.alias_command. # Defines an instance method which will execute a command under # an alternative name. # # Shell.def_system_command('date') # Shell.alias_command('date_in_utc', 'date', '-u') # Shell.new.date_in_utc # => Sat Jan 25 16:59:57 UTC 2014 # def Shell.alias_command(ali, command, *opts, &block) CommandProcessor.alias_command(ali, command, *opts, &block) end # Convenience method for Shell::CommandProcessor.unalias_command def Shell.unalias_command(ali) CommandProcessor.unalias_command(ali) end # call-seq: # install_system_commands(pre = "sys_") # # Convenience method for Shell::CommandProcessor.install_system_commands. # Defines instance methods representing all the executable files found in # Shell.default_system_path, with the given prefix prepended to their # names. # # Shell.install_system_commands # Shell.new.sys_echo("hello") # => hello # def Shell.install_system_commands(pre = "sys_") CommandProcessor.install_system_commands(pre) end # def inspect if debug.kind_of?(Integer) && debug > 2 super else to_s end end def self.notify(*opts) Shell::debug_output_synchronize do if opts[-1].kind_of?(String) yorn = verbose? else yorn = opts.pop end return unless yorn if @debug_display_thread_id if @debug_display_process_id prefix = "shell(##{Process.pid}:#{Thread.current.to_s.sub("Thread", "Th")}): " else prefix = "shell(#{Thread.current.to_s.sub("Thread", "Th")}): " end else prefix = "shell: " end _head = true STDERR.print opts.collect{|mes| mes = mes.dup yield mes if iterator? if _head _head = false prefix + mes else " "* prefix.size + mes end }.join("\n")+"\n" end end CommandProcessor.initialize CommandProcessor.run_config end