GRAYBYTE WORDPRESS FILE MANAGER6721

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//tempfile.rb
#
# tempfile - manipulates temporary files
#
# $Id: tempfile.rb 43490 2013-10-31 14:44:40Z usa $
#

require 'delegate'
require 'tmpdir'
require 'thread'

# A utility class for managing temporary files. When you create a Tempfile
# object, it will create a temporary file with a unique filename. A Tempfile
# objects behaves just like a File object, and you can perform all the usual
# file operations on it: reading data, writing data, changing its permissions,
# etc. So although this class does not explicitly document all instance methods
# supported by File, you can in fact call any File instance method on a
# Tempfile object.
#
# == Synopsis
#
#   require 'tempfile'
#
#   file = Tempfile.new('foo')
#   file.path      # => A unique filename in the OS's temp directory,
#                  #    e.g.: "/tmp/foo.24722.0"
#                  #    This filename contains 'foo' in its basename.
#   file.write("hello world")
#   file.rewind
#   file.read      # => "hello world"
#   file.close
#   file.unlink    # deletes the temp file
#
# == Good practices
#
# === Explicit close
#
# When a Tempfile object is garbage collected, or when the Ruby interpreter
# exits, its associated temporary file is automatically deleted. This means
# that's it's unnecessary to explicitly delete a Tempfile after use, though
# it's good practice to do so: not explicitly deleting unused Tempfiles can
# potentially leave behind large amounts of tempfiles on the filesystem
# until they're garbage collected. The existence of these temp files can make
# it harder to determine a new Tempfile filename.
#
# Therefore, one should always call #unlink or close in an ensure block, like
# this:
#
#   file = Tempfile.new('foo')
#   begin
#      ...do something with file...
#   ensure
#      file.close
#      file.unlink   # deletes the temp file
#   end
#
# === Unlink after creation
#
# On POSIX systems, it's possible to unlink a file right after creating it,
# and before closing it. This removes the filesystem entry without closing
# the file handle, so it ensures that only the processes that already had
# the file handle open can access the file's contents. It's strongly
# recommended that you do this if you do not want any other processes to
# be able to read from or write to the Tempfile, and you do not need to
# know the Tempfile's filename either.
#
# For example, a practical use case for unlink-after-creation would be this:
# you need a large byte buffer that's too large to comfortably fit in RAM,
# e.g. when you're writing a web server and you want to buffer the client's
# file upload data.
#
# Please refer to #unlink for more information and a code example.
#
# == Minor notes
#
# Tempfile's filename picking method is both thread-safe and inter-process-safe:
# it guarantees that no other threads or processes will pick the same filename.
#
# Tempfile itself however may not be entirely thread-safe. If you access the
# same Tempfile object from multiple threads then you should protect it with a
# mutex.
class Tempfile < DelegateClass(File)
  MAX_TRY = 10  # :nodoc:
  include Dir::Tmpname

  # call-seq:
  #    new(basename, [tmpdir = Dir.tmpdir], [options])
  #
  # Creates a temporary file with permissions 0600 (= only readable and
  # writable by the owner) and opens it with mode "w+".
  #
  # The +basename+ parameter is used to determine the name of the
  # temporary file. You can either pass a String or an Array with
  # 2 String elements. In the former form, the temporary file's base
  # name will begin with the given string. In the latter form,
  # the temporary file's base name will begin with the array's first
  # element, and end with the second element. For example:
  #
  #   file = Tempfile.new('hello')
  #   file.path  # => something like: "/tmp/hello2843-8392-92849382--0"
  #
  #   # Use the Array form to enforce an extension in the filename:
  #   file = Tempfile.new(['hello', '.jpg'])
  #   file.path  # => something like: "/tmp/hello2843-8392-92849382--0.jpg"
  #
  # The temporary file will be placed in the directory as specified
  # by the +tmpdir+ parameter. By default, this is +Dir.tmpdir+.
  # When $SAFE > 0 and the given +tmpdir+ is tainted, it uses
  # '/tmp' as the temporary directory. Please note that ENV values
  # are tainted by default, and +Dir.tmpdir+'s return value might
  # come from environment variables (e.g. <tt>$TMPDIR</tt>).
  #
  #   file = Tempfile.new('hello', '/home/aisaka')
  #   file.path  # => something like: "/home/aisaka/hello2843-8392-92849382--0"
  #
  # You can also pass an options hash. Under the hood, Tempfile creates
  # the temporary file using +File.open+. These options will be passed to
  # +File.open+. This is mostly useful for specifying encoding
  # options, e.g.:
  #
  #   Tempfile.new('hello', '/home/aisaka', :encoding => 'ascii-8bit')
  #
  #   # You can also omit the 'tmpdir' parameter:
  #   Tempfile.new('hello', :encoding => 'ascii-8bit')
  #
  # === Exceptions
  #
  # If Tempfile.new cannot find a unique filename within a limited
  # number of tries, then it will raise an exception.
  def initialize(basename, *rest)
    @data = []
    @clean_proc = Remover.new(@data)
    ObjectSpace.define_finalizer(self, @clean_proc)

    create(basename, *rest) do |tmpname, n, opts|
      mode = File::RDWR|File::CREAT|File::EXCL
      perm = 0600
      if opts
        mode |= opts.delete(:mode) || 0
        opts[:perm] = perm
        perm = nil
      else
        opts = perm
      end
      self.class.locking(tmpname) do
        @data[1] = @tmpfile = File.open(tmpname, mode, opts)
        @data[0] = @tmpname = tmpname
      end
      @mode = mode & ~(File::CREAT|File::EXCL)
      perm or opts.freeze
      @opts = opts
    end

    super(@tmpfile)
  end

  # Opens or reopens the file with mode "r+".
  def open
    @tmpfile.close if @tmpfile
    @tmpfile = File.open(@tmpname, @mode, @opts)
    @data[1] = @tmpfile
    __setobj__(@tmpfile)
  end

  def _close    # :nodoc:
    begin
      @tmpfile.close if @tmpfile
    ensure
      @tmpfile = nil
      @data[1] = nil if @data
    end
  end
  protected :_close

  # Closes the file. If +unlink_now+ is true, then the file will be unlinked
  # (deleted) after closing. Of course, you can choose to later call #unlink
  # if you do not unlink it now.
  #
  # If you don't explicitly unlink the temporary file, the removal
  # will be delayed until the object is finalized.
  def close(unlink_now=false)
    if unlink_now
      close!
    else
      _close
    end
  end

  # Closes and unlinks (deletes) the file. Has the same effect as called
  # <tt>close(true)</tt>.
  def close!
    _close
    unlink
  end

  # Unlinks (deletes) the file from the filesystem. One should always unlink
  # the file after using it, as is explained in the "Explicit close" good
  # practice section in the Tempfile overview:
  #
  #   file = Tempfile.new('foo')
  #   begin
  #      ...do something with file...
  #   ensure
  #      file.close
  #      file.unlink   # deletes the temp file
  #   end
  #
  # === Unlink-before-close
  #
  # On POSIX systems it's possible to unlink a file before closing it. This
  # practice is explained in detail in the Tempfile overview (section
  # "Unlink after creation"); please refer there for more information.
  #
  # However, unlink-before-close may not be supported on non-POSIX operating
  # systems. Microsoft Windows is the most notable case: unlinking a non-closed
  # file will result in an error, which this method will silently ignore. If
  # you want to practice unlink-before-close whenever possible, then you should
  # write code like this:
  #
  #   file = Tempfile.new('foo')
  #   file.unlink   # On Windows this silently fails.
  #   begin
  #      ... do something with file ...
  #   ensure
  #      file.close!   # Closes the file handle. If the file wasn't unlinked
  #                    # because #unlink failed, then this method will attempt
  #                    # to do so again.
  #   end
  def unlink
    return unless @tmpname
    begin
      File.unlink(@tmpname)
    rescue Errno::ENOENT
    rescue Errno::EACCES
      # may not be able to unlink on Windows; just ignore
      return
    end
    # remove tmpname from remover
    @data[0] = @data[1] = nil
    @tmpname = nil
    ObjectSpace.undefine_finalizer(self)
  end
  alias delete unlink

  # Returns the full path name of the temporary file.
  # This will be nil if #unlink has been called.
  def path
    @tmpname
  end

  # Returns the size of the temporary file.  As a side effect, the IO
  # buffer is flushed before determining the size.
  def size
    if @tmpfile
      @tmpfile.flush
      @tmpfile.stat.size
    elsif @tmpname
      File.size(@tmpname)
    else
      0
    end
  end
  alias length size

  # :stopdoc:
  class Remover
    def initialize(data)
      @pid = $$
      @data = data
    end

    def call(*args)
      return if @pid != $$

      path, tmpfile = *@data

      STDERR.print "removing ", path, "..." if $DEBUG

      tmpfile.close if tmpfile

      if path
        begin
          File.unlink(path)
        rescue Errno::ENOENT
        end
      end

      STDERR.print "done\n" if $DEBUG
    end
  end
  # :startdoc:

  class << self
    # Creates a new Tempfile.
    #
    # If no block is given, this is a synonym for Tempfile.new.
    #
    # If a block is given, then a Tempfile object will be constructed,
    # and the block is run with said object as argument. The Tempfile
    # oject will be automatically closed after the block terminates.
    # The call returns the value of the block.
    #
    # In any case, all arguments (+*args+) will be passed to Tempfile.new.
    #
    #   Tempfile.open('foo', '/home/temp') do |f|
    #      ... do something with f ...
    #   end
    #
    #   # Equivalent:
    #   f = Tempfile.open('foo', '/home/temp')
    #   begin
    #      ... do something with f ...
    #   ensure
    #      f.close
    #   end
    def open(*args)
      tempfile = new(*args)

      if block_given?
        begin
          yield(tempfile)
        ensure
          tempfile.close
        end
      else
        tempfile
      end
    end

    # :stopdoc:

    # yields with locking for +tmpname+ and returns the result of the
    # block.
    def locking(tmpname)
      lock = tmpname + '.lock'
      mkdir(lock)
      yield
    ensure
      rmdir(lock) if lock
    end

    def mkdir(*args)
      Dir.mkdir(*args)
    end

    def rmdir(*args)
      Dir.rmdir(*args)
    end
  end
end

if __FILE__ == $0
#  $DEBUG = true
  f = Tempfile.new("foo")
  f.print("foo\n")
  f.close
  f.open
  p f.gets # => "foo\n"
  f.close!
end

[ 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