aboutsummaryrefslogtreecommitdiffstats
path: root/lib/pstore.rb
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2001-07-31 06:24:45 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2001-07-31 06:24:45 +0000
commitc8a7361e45e3a149b970ae9cd74cbbcfbfd1d501 (patch)
treea5a31be3a7d007d806afa07b04e7c9d9d5662b8d /lib/pstore.rb
parent645170199ca8d9f7eaa8f928519897d2d1ed709d (diff)
downloadruby-c8a7361e45e3a149b970ae9cd74cbbcfbfd1d501.tar.gz
* marshal.c (Init_marshal): new constant Marshal::MAJOR_VERSION
and Marshal::MINOR_VERSION. * marshal.c (marshal_load): ruby_verbose test should be wrapped by RTEST(). * hash.c (rb_hash_index): should return nil (not the default value) if value is not in the hash. * numeric.c (num_div): new method added. alias to '/' which should be preserved even if '/' is redefined (e.g. by mathn). [new] * bignum.c (rb_cstr2inum): "0 ff".hex should return 0, not 255. * file.c (rb_file_s_expand_path): fixed using CharNext(). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@1658 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/pstore.rb')
-rw-r--r--lib/pstore.rb13
1 files changed, 8 insertions, 5 deletions
diff --git a/lib/pstore.rb b/lib/pstore.rb
index d74d712a56..43a0530dc8 100644
--- a/lib/pstore.rb
+++ b/lib/pstore.rb
@@ -79,7 +79,7 @@ class PStore
throw :pstore_abort_transaction
end
- def transaction
+ def transaction(read_only=false)
raise PStore::Error, "nested transaction" if @transaction
begin
@transaction = true
@@ -89,10 +89,13 @@ class PStore
file = File::open(@filename, "r+")
orig = true
rescue Errno::ENOENT
+ raise if read_only
file = File::open(@filename, "w+")
end
- file.flock(File::LOCK_EX)
- if orig
+ file.flock(read_only ? File::LOCK_SH : File::LOCK_EX)
+ if read_only
+ @table = Marshal::load(file)
+ elsif orig
content = file.read
@table = Marshal::load(content)
size = content.size
@@ -109,7 +112,7 @@ class PStore
@abort = true
raise
ensure
- unless @abort
+ if !read_only && !@abort
file.rewind
content = Marshal::dump(@table)
if !md5 || size != content.size || md5 != MD5.new(content).digest
@@ -150,7 +153,7 @@ if __FILE__ == $0
end
end
- db.transaction do
+ db.transaction(true) do
p db["root"]
end
end