summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/pstore.rb13
-rw-r--r--lib/singleton.rb12
2 files changed, 17 insertions, 8 deletions
diff --git a/lib/pstore.rb b/lib/pstore.rb
index d74d712a5..43a0530dc 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
diff --git a/lib/singleton.rb b/lib/singleton.rb
index f5c2d8346..1945c4446 100644
--- a/lib/singleton.rb
+++ b/lib/singleton.rb
@@ -16,12 +16,18 @@ module Singleton
klass.instance_eval %{
@__instance__ = nil
def instance
- unless @__instance__
+ if defined? @__allocating__
+ until @__instance__
+ sleep 0.5
+ end
+ elsif ! @__instance__
Thread.critical = true
+ @__allocating__ = true
+ Thread.critical = false
begin
- @__instance__ ||= new
+ @__instance__ = new
ensure
- Thread.critical = false
+ remove_instance_variable(:@__allocating__)
end
end
return @__instance__