The SqliteStore class manages access to all object storage.
db
is a handle to the database.
dbtop
stores the highest id used in the database.
cache
is a handle to the cache
# File lib/storage/sqlite3store.rb, line 31 def initialize(dbfile) super() @dbfile = "#{dbfile}.sqlite3" # check if database exists and build it if not build_database log.info "Loading world..." # open database and sets @dbtop to highest object id @db = SQLite3::Database.open(@dbfile) @db.cache_size = 1000; # default is 2000 1.5K pages @db.synchronous = 0; # dangerous if OS crash, but fast @db.type_translation = true; @db.execute("select id from tmud;") do |i| @dbtop = i.first if i.first > @dbtop end @cache = CacheManager.new(@db) log.info "Database '#{@dbfile}' loaded...highest id = #{@dbtop}." # log.debug @db.inspect rescue log.fatal $! raise end
Check if an object is in the database by its id.
oid
is the id to use in the search.
return
true or false
# File lib/storage/sqlite3store.rb, line 99 def check(oid) @db.has_key? oid.to_s end
Close the database
return
Undefined.
# File lib/storage/sqlite3store.rb, line 64 def close @db.close end
Deletes an object from the database.
oid
is the id to to be deleted.
return
Undefined.
# File lib/storage/sqlite3store.rb, line 85 def delete(oid) @cache.delete(oid) end
Iterate through all objects This needs to have all the possible keys first. So we need to fetch them from the cache and from the database and and produce a list of unique keys.
yield
Each object in database to block of caller.
# File lib/storage/sqlite3store.rb, line 129 def each kys = @cache.keys @db.execute("select id from tmud;") do |k| kys << k.to_i end kys.uniq! kys.each {|k| yield @cache.get(k)} end
Finds an object in the database by its id.
oid
is the id to use in the search.
return
Handle to the object or nil.
# File lib/storage/sqlite3store.rb, line 92 def get(oid) @cache.get(oid) end
inspect the store cache (only for caches)
return
string
# File lib/storage/sqlite3store.rb, line 70 def inspect @cache.inspect end
Marks an object nonswappable
oid
is the object id
return
undefined
# File lib/storage/sqlite3store.rb, line 113 def makenoswap(oid) @cache.makenoswap(oid) end
Marks an object swappable
oid
is the object id
return
undefined
# File lib/storage/sqlite3store.rb, line 120 def makeswap(oid) @cache.makeswap(oid) end
Marks an object dirty
oid
is the id to use in the search.
return
undefined
# File lib/storage/sqlite3store.rb, line 106 def mark(oid) @cache.mark(oid) end
Adds a new object to the database.
obj
is a reference to object to be added
return
Undefined.
# File lib/storage/sqlite3store.rb, line 77 def put(obj) @cache.put(obj) obj # return really should not be checked end
Save the world
return
Undefined.
# File lib/storage/sqlite3store.rb, line 58 def save @cache.sync end
produces a statistical report of the database
return
a string containing the report
# File lib/storage/sqlite3store.rb, line 140 def stats stats = super stats << @cache.stats end