summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-11-11 10:17:36 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-11-11 10:17:36 +0000
commitc354e4fc8ddcfe7d861af745c8e5d70d3a687c26 (patch)
tree6b4a67f1378696aac5604da427847b64e554c193
parent3edcc4bbc67f1534a0423b82d8d82b41a7a3b1a4 (diff)
downloadruby-c354e4fc8ddcfe7d861af745c8e5d70d3a687c26.tar.gz
ruby-c354e4fc8ddcfe7d861af745c8e5d70d3a687c26.tar.xz
ruby-c354e4fc8ddcfe7d861af745c8e5d70d3a687c26.zip
* lib/tempfile.rb (Tempfile#initialize): merge mode option.
* lib/tmpdir.rb (Dir::Tmpname#create): splat options. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@25720 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog6
-rwxr-xr-xlib/tempfile.rb4
-rw-r--r--lib/tmpdir.rb2
3 files changed, 10 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 33d01613c..061352aca 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Wed Nov 11 19:17:35 2009 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * lib/tempfile.rb (Tempfile#initialize): merge mode option.
+
+ * lib/tmpdir.rb (Dir::Tmpname#create): splat options.
+
Wed Nov 11 12:54:02 2009 Nobuyoshi Nakada <nobu@ruby-lang.org>
* hash.c (ruby_setenv): use ruby_strdup().
diff --git a/lib/tempfile.rb b/lib/tempfile.rb
index 4ebeea28a..7024bd9bd 100755
--- a/lib/tempfile.rb
+++ b/lib/tempfile.rb
@@ -133,9 +133,11 @@ class Tempfile < DelegateClass(File)
create(basename, *rest) do |tmpname, n, opts|
lock = tmpname + '.lock'
+ mode = opts.delete(:mode) || 0
+ mode = File::RDWR|File::CREAT|File::EXCL|mode
self.class.mkdir(lock)
begin
- @data[1] = @tmpfile = File.open(tmpname, File::RDWR|File::CREAT|File::EXCL, 0600, *opts)
+ @data[1] = @tmpfile = File.open(tmpname, mode, 0600, *opts)
@data[0] = @tmpname = tmpname
ensure
self.class.rmdir(lock)
diff --git a/lib/tmpdir.rb b/lib/tmpdir.rb
index fafe120b3..32befa3e8 100644
--- a/lib/tmpdir.rb
+++ b/lib/tmpdir.rb
@@ -152,7 +152,7 @@ class Dir
n = nil
begin
path = File.expand_path(make_tmpname(basename, n), tmpdir)
- yield(path, n, opts)
+ yield(path, n, *opts)
rescue Errno::EEXIST
n ||= 0
n += 1