$SAFE=4 and persistent storage! That is what i want.
This commit is contained in:
parent
4d4978d3ac
commit
b82ce54d60
2 changed files with 50 additions and 21 deletions
70
bin/box.rb
70
bin/box.rb
|
@ -2,38 +2,66 @@
|
||||||
|
|
||||||
require 'thread'
|
require 'thread'
|
||||||
|
|
||||||
class Queue
|
|
||||||
attr_reader :que, :waiting
|
|
||||||
end
|
|
||||||
|
|
||||||
class Box
|
class Box
|
||||||
attr_reader :_
|
attr_reader :_, :emited
|
||||||
|
alias db emited
|
||||||
|
alias persistent emited
|
||||||
attr_accessor :emited
|
attr_accessor :emited
|
||||||
|
|
||||||
def initialize _
|
def initialize db, _
|
||||||
@_, @emited = _, []
|
@_, @emited = _, db
|
||||||
end
|
end
|
||||||
|
|
||||||
def emit k, v
|
def emit k, v
|
||||||
@emited.push [k, v]
|
@emited[k] = v
|
||||||
|
end
|
||||||
|
|
||||||
|
def do code
|
||||||
|
instance_eval code, self.class.to_s, 0
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
Thread.abort_on_exception = true
|
require 'sbdb'
|
||||||
q, o, r = Queue.new, Queue.new, nil
|
|
||||||
puts q.inspect
|
|
||||||
$stdout.print "(0)$ "
|
|
||||||
|
|
||||||
STDIN.each_with_index do |l, i|
|
class Persistent
|
||||||
r = begin
|
include Enumerable
|
||||||
Thread.new do
|
def initialize( db) @db, @cursor = db, db.cursor end
|
||||||
|
def emit( k, v) @db[k] = v end
|
||||||
|
alias push emit
|
||||||
|
alias put emit
|
||||||
|
alias []= emit
|
||||||
|
def get( k) @db[k] end
|
||||||
|
alias [] get
|
||||||
|
alias fetch get
|
||||||
|
def inspect() "#<%s:0x%016x>" % [ self.class, self.object_id ] end
|
||||||
|
def each &e
|
||||||
|
e ? @cursor.each( &e) : Enumerator.new( self, :each)
|
||||||
|
end
|
||||||
|
def to_hash
|
||||||
|
h = {}
|
||||||
|
each {|k, v| h[ k] = v }
|
||||||
|
h
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
#Persistent.freeze
|
||||||
|
|
||||||
|
r = nil
|
||||||
|
Dir.mkdir 'logs' rescue Errno::EEXIST
|
||||||
|
SBDB::Env.new 'logs', SBDB::CREATE | SBDB::Env::INIT_TRANSACTION do |logs|
|
||||||
|
db = Persistent.new logs['test', :type => SBDB::Btree, :flags => SBDB::CREATE]
|
||||||
|
$stdout.print "(0)$ "
|
||||||
|
STDIN.each_with_index do |l, i|
|
||||||
|
r = Thread.new do
|
||||||
l.untaint
|
l.untaint
|
||||||
$SAFE = 4
|
$SAFE = 4
|
||||||
b = Box.new r
|
b = Box.new db, r
|
||||||
[b.instance_eval( l, 'BOX', 0), b.emited]
|
begin
|
||||||
|
b.do( l)
|
||||||
|
rescue Object
|
||||||
|
$!
|
||||||
|
end
|
||||||
end.value
|
end.value
|
||||||
rescue Object
|
$stdout.print "=> #{r.inspect}\n(#{i+1})$ "
|
||||||
[$!.class, $!, $!.backtrace].inspect
|
end
|
||||||
end
|
|
||||||
$stdout.print "#{r.inspect}\n(#{i+1})$ "
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -44,6 +44,7 @@ end
|
||||||
SBDB::Env.new 'conf' do |conf|
|
SBDB::Env.new 'conf' do |conf|
|
||||||
SBDB::Env.new 'logs' do |logs|
|
SBDB::Env.new 'logs' do |logs|
|
||||||
SBDB::Env.new 'cache' do |cache|
|
SBDB::Env.new 'cache' do |cache|
|
||||||
|
test = cache[ 'test']
|
||||||
while line = logs[ 'newids'].get( nil, "\0\0\0\0", nil, SBDB::CONSUME_WAIT)
|
while line = logs[ 'newids'].get( nil, "\0\0\0\0", nil, SBDB::CONSUME_WAIT)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue