GRAYBYTE WORDPRESS FILE MANAGER5210

Server IP : 198.54.121.189 / Your IP : 216.73.216.112
System : Linux premium69.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /opt/alt/ruby19/lib64/ruby/1.9.1/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/alt/ruby19/lib64/ruby/1.9.1//tracer.rb
##
# = Tracer
#
# Tracer outputs a source level execution trace of a Ruby program. It does
# this by registering an event handler with <code>Kernel#set_trace_func</code>
# for processing incoming events.  It also provides methods for filtering
# unwanted trace output (see Tracer.add_filter, Tracer.on, and Tracer.off).
#
# == Example
#
# Consider the following ruby script
#
#   class A
#     def square(a)
#       return a*a
#     end
#   end
#
#   a = A.new
#   a.square(5)
#
# Running the above script using <code>ruby -r tracer example.rb</code> will
# output the following trace to STDOUT (Note you can also explicitly
# <code>require 'tracer'</code>)
#
#   #0:<internal:lib/rubygems/custom_require>:38:Kernel:<: -
#   #0:example.rb:3::-: class A
#   #0:example.rb:3::C: class A
#   #0:example.rb:4::-:   def square(a)
#   #0:example.rb:7::E: end
#   #0:example.rb:9::-: a = A.new
#   #0:example.rb:10::-: a.square(5)
#   #0:example.rb:4:A:>:   def square(a)
#   #0:example.rb:5:A:-:     return a*a
#   #0:example.rb:6:A:<:   end
#    |  |         | |  |
#    |  |         | |   ---------------------+ event
#    |  |         |  ------------------------+ class
#    |  |          --------------------------+ line
#    |   ------------------------------------+ filename
#     ---------------------------------------+ thread
#
# Symbol table used for displaying incoming events:
#
# <tt>}</tt>:: call a C-language routine
# <tt>{</tt>:: return from a C-language routine
# <tt>></tt>:: call a Ruby method
# <tt>C</tt>:: start a class or module definition
# <tt>E</tt>:: finish a class or module definition
# <tt>-</tt>:: execute code on a new line
# <tt>^</tt>:: raise an exception
# <tt><</tt>:: return from a Ruby method
#
# == Copyright
#
# by Keiju ISHITSUKA(keiju@ishitsuka.com)
#
#--
# $Release Version: 0.3$
# $Revision: 1.12 $
require "thread"

#
# tracer main class
#
class Tracer
  class << self
    # display additional debug information (defaults to false)
    attr_accessor :verbose
    alias verbose? verbose

    # output stream used to output trace (defaults to STDOUT)
    attr_accessor :stdout

    # mutex lock used by tracer for displaying trace output
    attr_reader :stdout_mutex

    # display process id in trace output (defaults to false)
    attr_accessor :display_process_id
    alias display_process_id? display_process_id

    # display thread id in trace output (defaults to true)
    attr_accessor :display_thread_id
    alias display_thread_id? display_thread_id

    # display C-routine calls in trace output (defaults to false)
    attr_accessor :display_c_call
    alias display_c_call? display_c_call
  end

  Tracer::stdout = STDOUT
  Tracer::verbose = false
  Tracer::display_process_id = false
  Tracer::display_thread_id = true
  Tracer::display_c_call = false

  @stdout_mutex = Mutex.new

  # Symbol table used for displaying trace information
  EVENT_SYMBOL = {
    "line" => "-",
    "call" => ">",
    "return" => "<",
    "class" => "C",
    "end" => "E",
    "raise" => "^",
    "c-call" => "}",
    "c-return" => "{",
    "unknown" => "?"
  }

  def initialize # :nodoc:
    @threads = Hash.new
    if defined? Thread.main
      @threads[Thread.main.object_id] = 0
    else
      @threads[Thread.current.object_id] = 0
    end

    @get_line_procs = {}

    @filters = []
  end

  def stdout # :nodoc:
    Tracer.stdout
  end

  def on # :nodoc:
    if block_given?
      on
      begin
        yield
      ensure
        off
      end
    else
      set_trace_func method(:trace_func).to_proc
      stdout.print "Trace on\n" if Tracer.verbose?
    end
  end

  def off # :nodoc:
    set_trace_func nil
    stdout.print "Trace off\n" if Tracer.verbose?
  end

  def add_filter(p = proc) # :nodoc:
    @filters.push p
  end

  def set_get_line_procs(file, p = proc) # :nodoc:
    @get_line_procs[file] = p
  end

  def get_line(file, line) # :nodoc:
    if p = @get_line_procs[file]
      return p.call(line)
    end

    unless list = SCRIPT_LINES__[file]
      begin
        f = File::open(file)
        begin
          SCRIPT_LINES__[file] = list = f.readlines
        ensure
          f.close
        end
      rescue
        SCRIPT_LINES__[file] = list = []
      end
    end

    if l = list[line - 1]
      l
    else
      "-\n"
    end
  end

  def get_thread_no # :nodoc:
    if no = @threads[Thread.current.object_id]
      no
    else
      @threads[Thread.current.object_id] = @threads.size
    end
  end

  def trace_func(event, file, line, id, binding, klass, *) # :nodoc:
    return if file == __FILE__

    for p in @filters
      return unless p.call event, file, line, id, binding, klass
    end

    return unless Tracer::display_c_call? or
      event != "c-call" && event != "c-return"

    Tracer::stdout_mutex.synchronize do
      if EVENT_SYMBOL[event]
        stdout.printf("<%d>", $$) if Tracer::display_process_id?
        stdout.printf("#%d:", get_thread_no) if Tracer::display_thread_id?
        if line == 0
          source = "?\n"
        else
          source = get_line(file, line)
        end
        printf("%s:%d:%s:%s: %s",
               file,
               line,
               klass || '',
               EVENT_SYMBOL[event],
               source)
      end
    end

  end

  # Reference to singleton instance of Tracer
  Single = new

  ##
  # Start tracing
  #
  # === Example
  #
  #   Tracer.on
  #   # code to trace here
  #   Tracer.off
  #
  # You can also pass a block:
  #
  #   Tracer.on {
  #     # trace everything in this block
  #   }

  def Tracer.on
    if block_given?
      Single.on{yield}
    else
      Single.on
    end
  end

  ##
  # Disable tracing

  def Tracer.off
    Single.off
  end

  ##
  # Register an event handler <code>p</code> which is called everytime a line
  # in +file_name+ is executed.
  #
  # Example:
  #
  #   Tracer.set_get_line_procs("example.rb", lambda { |line|
  #     puts "line number executed is #{line}"
  #   })

  def Tracer.set_get_line_procs(file_name, p = proc)
    Single.set_get_line_procs(file_name, p)
  end

  ##
  # Used to filter unwanted trace output
  #
  # Example which only outputs lines of code executed within the Kernel class:
  #
  #   Tracer.add_filter do |event, file, line, id, binding, klass, *rest|
  #     "Kernel" == klass.to_s
  #   end

  def Tracer.add_filter(p = proc)
    Single.add_filter(p)
  end
end

# :stopdoc:
SCRIPT_LINES__ = {} unless defined? SCRIPT_LINES__

if $0 == __FILE__
  # direct call

  $0 = ARGV[0]
  ARGV.shift
  Tracer.on
  require $0
else
  # call Tracer.on only if required by -r command-line option
  count = caller.count {|bt| /\/rubygems\/custom_require.rb:/ !~ bt}
  if (defined?(Gem) and count == 0) or
     (!defined?(Gem) and count <= 1)
    Tracer.on
  end
end
# :startdoc:

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
March 03 2024 22:48:09
root / root
0755
cgi
--
March 03 2024 22:48:05
root / linksafe
0755
date
--
March 03 2024 22:48:05
root / linksafe
0755
digest
--
March 03 2024 22:48:05
root / linksafe
0755
dl
--
March 03 2024 22:48:05
root / linksafe
0755
drb
--
March 03 2024 22:48:05
root / linksafe
0755
fiddle
--
March 03 2024 22:48:05
root / linksafe
0755
irb
--
March 03 2024 22:48:05
root / linksafe
0755
json
--
March 03 2024 22:48:09
root / linksafe
0755
matrix
--
March 03 2024 22:48:05
root / linksafe
0755
net
--
March 03 2024 22:48:05
root / linksafe
0755
openssl
--
March 03 2024 22:48:05
root / linksafe
0755
optparse
--
March 03 2024 22:48:05
root / linksafe
0755
psych
--
March 03 2024 22:48:05
root / linksafe
0755
racc
--
March 03 2024 22:48:05
root / linksafe
0755
rake
--
March 03 2024 22:50:37
root / linksafe
0755
rbconfig
--
March 03 2024 22:48:12
root / linksafe
0755
rdoc
--
March 03 2024 22:48:11
root / linksafe
0755
rexml
--
March 03 2024 22:48:05
root / linksafe
0755
rinda
--
March 03 2024 22:48:05
root / linksafe
0755
ripper
--
March 03 2024 22:48:05
root / linksafe
0755
rss
--
March 03 2024 22:48:05
root / linksafe
0755
rubygems
--
March 03 2024 22:48:12
root / linksafe
0755
shell
--
March 03 2024 22:48:05
root / linksafe
0755
syck
--
March 03 2024 22:48:05
root / linksafe
0755
test
--
March 03 2024 22:48:05
root / linksafe
0755
uri
--
March 03 2024 22:48:05
root / linksafe
0755
webrick
--
March 03 2024 22:48:05
root / linksafe
0755
x86_64-linux
--
March 03 2024 22:48:09
root / root
0755
xmlrpc
--
March 03 2024 22:48:05
root / linksafe
0755
yaml
--
March 03 2024 22:48:05
root / linksafe
0755
English.rb
5.588 KB
October 02 2009 10:45:39
root / linksafe
0644
abbrev.rb
2.565 KB
May 18 2011 21:19:18
root / linksafe
0644
base64.rb
2.631 KB
October 02 2009 10:45:39
root / linksafe
0644
benchmark.rb
17.999 KB
June 28 2011 06:09:46
root / linksafe
0644
cgi.rb
9.296 KB
May 16 2011 21:21:35
root / linksafe
0644
cmath.rb
7.223 KB
July 30 2011 14:53:14
root / linksafe
0644
complex.rb
0.371 KB
August 16 2009 15:34:35
root / linksafe
0644
csv.rb
82.663 KB
July 21 2011 21:40:21
root / linksafe
0644
date.rb
0.924 KB
May 21 2011 12:25:03
root / linksafe
0644
debug.rb
23.228 KB
June 28 2011 11:45:50
root / linksafe
0644
delegate.rb
9.738 KB
July 27 2011 19:56:28
root / linksafe
0644
digest.rb
2.244 KB
May 16 2011 20:52:55
root / linksafe
0644
dl.rb
0.172 KB
June 12 2010 15:28:47
root / linksafe
0644
drb.rb
0.019 KB
October 02 2009 10:45:39
root / linksafe
0644
e2mmap.rb
3.805 KB
May 19 2011 00:07:25
root / linksafe
0644
erb.rb
25.717 KB
December 13 2012 05:24:26
root / linksafe
0644
expect.rb
1.332 KB
August 26 2011 23:54:49
root / linksafe
0644
fiddle.rb
0.906 KB
August 16 2011 00:51:58
root / linksafe
0644
fileutils.rb
45.323 KB
February 25 2012 08:11:07
root / linksafe
0644
find.rb
2.031 KB
May 18 2011 21:19:18
root / linksafe
0644
forwardable.rb
7.64 KB
May 22 2011 02:14:57
root / linksafe
0644
getoptlong.rb
15.38 KB
May 19 2011 00:07:25
root / linksafe
0644
gserver.rb
8.832 KB
October 31 2013 14:40:55
root / linksafe
0644
ipaddr.rb
24.922 KB
April 11 2013 02:31:05
root / linksafe
0644
irb.rb
8.338 KB
May 19 2011 00:07:25
root / linksafe
0644
json.rb
1.737 KB
August 30 2011 02:25:32
root / linksafe
0644
kconv.rb
5.737 KB
December 07 2010 11:47:39
root / linksafe
0644
logger.rb
20.846 KB
May 19 2011 00:07:25
root / linksafe
0644
mathn.rb
6.524 KB
August 26 2011 23:54:49
root / linksafe
0644
matrix.rb
47.646 KB
July 09 2011 19:11:06
root / linksafe
0644
mkmf.rb
68.899 KB
February 06 2014 05:20:52
root / linksafe
0644
monitor.rb
6.936 KB
June 17 2011 22:33:54
root / linksafe
0644
mutex_m.rb
1.611 KB
May 19 2011 00:07:25
root / linksafe
0644
observer.rb
5.687 KB
May 16 2011 21:53:12
root / linksafe
0644
open-uri.rb
25.844 KB
February 24 2014 03:43:27
root / linksafe
0644
open3.rb
20.643 KB
May 18 2011 21:19:18
root / linksafe
0644
openssl.rb
0.534 KB
July 25 2011 06:38:44
root / linksafe
0644
optparse.rb
51.129 KB
February 14 2014 04:52:03
root / linksafe
0644
ostruct.rb
6.494 KB
February 24 2012 14:49:51
root / linksafe
0644
pathname.rb
14.208 KB
August 26 2011 23:54:49
root / linksafe
0644
pp.rb
13.311 KB
August 01 2010 14:09:40
root / linksafe
0644
prettyprint.rb
9.628 KB
August 02 2011 15:25:59
root / linksafe
0644
prime.rb
13.977 KB
June 01 2011 00:21:46
root / linksafe
0644
profile.rb
0.2 KB
October 02 2009 10:45:39
root / linksafe
0644
profiler.rb
1.588 KB
October 02 2009 10:45:39
root / linksafe
0644
pstore.rb
15.808 KB
October 10 2011 23:14:17
root / linksafe
0644
psych.rb
9.819 KB
August 07 2012 20:50:05
root / linksafe
0644
rake.rb
2.018 KB
June 29 2011 03:09:34
root / linksafe
0644
rational.rb
0.301 KB
September 24 2009 00:42:23
root / linksafe
0644
rdoc.rb
4.287 KB
February 06 2013 08:00:49
root / linksafe
0644
resolv-replace.rb
1.74 KB
October 29 2010 22:02:39
root / linksafe
0644
resolv.rb
59.914 KB
February 14 2014 06:56:54
root / linksafe
0644
ripper.rb
0.089 KB
October 02 2009 10:45:39
root / linksafe
0644
rss.rb
2.841 KB
May 11 2011 10:22:16
root / linksafe
0644
rubygems.rb
34.134 KB
December 22 2013 04:38:28
root / linksafe
0644
scanf.rb
23.529 KB
May 20 2011 12:22:26
root / linksafe
0644
securerandom.rb
8.459 KB
May 07 2012 11:25:45
root / linksafe
0644
set.rb
29.907 KB
February 10 2012 08:28:48
root / linksafe
0644
shell.rb
5.904 KB
May 19 2011 00:07:25
root / linksafe
0644
shellwords.rb
3.877 KB
February 12 2012 07:51:05
root / linksafe
0644
singleton.rb
4.018 KB
May 18 2011 14:09:38
root / linksafe
0644
socket.rb
23.22 KB
January 30 2014 12:04:22
root / linksafe
0644
syck.rb
13.913 KB
July 19 2010 04:54:06
root / linksafe
0644
sync.rb
6.874 KB
June 29 2011 03:09:34
root / linksafe
0644
tempfile.rb
10.419 KB
October 31 2013 14:44:40
root / linksafe
0644
thread.rb
6.589 KB
February 14 2014 03:48:42
root / linksafe
0644
thwait.rb
3.376 KB
June 29 2011 03:09:34
root / linksafe
0644
time.rb
17.031 KB
October 31 2013 14:06:50
root / linksafe
0644
timeout.rb
3.257 KB
April 02 2013 04:09:07
root / linksafe
0644
tmpdir.rb
3.723 KB
May 18 2011 21:19:18
root / linksafe
0644
tracer.rb
6.629 KB
June 29 2011 13:19:59
root / linksafe
0644
tsort.rb
6.795 KB
March 06 2009 04:23:05
root / linksafe
0644
ubygems.rb
0.262 KB
October 02 2009 10:45:39
root / linksafe
0644
un.rb
8.323 KB
May 19 2011 00:07:25
root / linksafe
0644
uri.rb
3.07 KB
May 13 2011 20:03:21
root / linksafe
0644
weakref.rb
2.292 KB
August 26 2011 23:54:49
root / linksafe
0644
webrick.rb
6.801 KB
May 10 2011 23:37:43
root / linksafe
0644
yaml.rb
2.579 KB
May 29 2013 12:00:57
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF