Sha256: 8483c1a58f956f99952e645f7c02cec433d64833af8403f530f42633d61668f8
Contents?: true
Size: 1.96 KB
Versions: 2
Compression:
Stored size: 1.96 KB
Contents
# frozen_string_literal: true module MiniSql module Postgres class DeserializerCache DEFAULT_MAX_SIZE = 500 def initialize(max_size = nil) @cache = {} @max_size = max_size || DEFAULT_MAX_SIZE end def materializer(result) key = result.fields materializer = @cache.delete(key) if materializer @cache[key] = materializer else materializer = @cache[key] = new_row_matrializer(result) @cache.shift if @cache.length > @max_size end materializer end def materialize(result, decorator_module = nil) return [] if result.ntuples == 0 key = result.fields # trivial fast LRU implementation materializer = @cache.delete(key) if materializer @cache[key] = materializer else materializer = @cache[key] = new_row_matrializer(result) @cache.shift if @cache.length > @max_size end if decorator_module materializer = materializer.decorated(decorator_module) end i = 0 r = [] # quicker loop while i < result.ntuples r << materializer.materialize(result, i) i += 1 end r end private def new_row_matrializer(result) fields = result.fields i = 0 while i < fields.length # special handling for unamed column if fields[i] == "?column?" fields[i] = "column#{i}" end i += 1 end Class.new do extend MiniSql::Decoratable include MiniSql::Result attr_accessor(*fields) instance_eval <<~RUBY def materialize(pg_result, index) r = self.new #{col = -1; fields.map { |f| "r.#{f} = pg_result.getvalue(index, #{col += 1})" }.join("; ")} r end RUBY end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
mini_sql-1.0.1 | lib/mini_sql/postgres/deserializer_cache.rb |
mini_sql-1.0 | lib/mini_sql/postgres/deserializer_cache.rb |