From c4d6f4c01e44aa48070d091649795c586f3583e6 Mon Sep 17 00:00:00 2001 From: akr Date: Tue, 21 Aug 2007 12:15:34 +0000 Subject: [PATCH] * lib/tmpdir.rb (Dir.mktmpdir): make directory suffix specifiable. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@13129 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 4 ++++ lib/tmpdir.rb | 33 ++++++++++++++++++++++++++++----- 2 files changed, 32 insertions(+), 5 deletions(-) diff --git a/ChangeLog b/ChangeLog index 84aa170c7c..6e5be1c1ca 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Tue Aug 21 21:09:48 2007 Tanaka Akira + + * lib/tmpdir.rb (Dir.mktmpdir): make directory suffix specifiable. + Tue Aug 21 15:00:23 2007 Koichi Sasada * st.c (st_clear): reset num_entries too. diff --git a/lib/tmpdir.rb b/lib/tmpdir.rb index 485054746f..76656a589e 100644 --- a/lib/tmpdir.rb +++ b/lib/tmpdir.rb @@ -48,14 +48,23 @@ class Dir # Dir.mktmpdir creates a temporary directory. # # The directory is created with 0700 permission. - # The name of the directory is prefixed - # with prefix argument. - # If prefix is not given, - # the prefix "d" is used. + # + # The prefix and suffix of the name of the directory is specified by + # the optional first argument, prefix_suffix. + # - If it is not specified or nil, "d" is used as the prefix and no suffix is used. + # - If it is a string, it is used as the prefix and no suffix is used. + # - If it is an array, first element is used as the prefix and second element is used as a suffix. + # + # Dir.mktmpdir {|dir| dir is ".../d..." } + # Dir.mktmpdir("foo") {|dir| dir is ".../foo..." } + # Dir.mktmpdir(["foo", "bar"]) {|dir| path is ".../foo...bar" } # # The directory is created under Dir.tmpdir or # the optional second argument tmpdir if non-nil value is given. # + # Dir.mktmpdir {|dir| dir is "#{Dir.tmpdir}/d..." } + # Dir.mktmpdir(nil, "/var/tmp") {|dir| dir is "/var/tmp/d..." } + # # If a block is given, # it is yielded with the path of the directory. # The directory and its contents are removed @@ -80,13 +89,27 @@ class Dir # FileUtils.remove_entry_secure dir # end # - def Dir.mktmpdir(prefix="d", tmpdir=nil) + def Dir.mktmpdir(prefix_suffix=nil, tmpdir=nil) + case prefix_suffix + when nil + prefix = "d" + suffix = "" + when String + prefix = prefix_suffix + suffix = "" + when Array + prefix = prefix_suffix[0] + suffix = prefix_suffix[1] + else + raise ArgumentError, "unexpected prefix_suffix: #{prefix_suffix.inspect}" + end tmpdir ||= Dir.tmpdir t = Time.now.strftime("%Y%m%d") n = nil begin path = "#{tmpdir}/#{prefix}#{t}-#{$$}-#{rand(0x100000000).to_s(36)}" path << "-#{n}" if n + path << suffix Dir.mkdir(path, 0700) rescue Errno::EEXIST n ||= 0