From 66fa9f62ef1f5e2e447cdc724b42f2e1d58b0753 Mon Sep 17 00:00:00 2001 From: Yorick Peterse Date: Mon, 23 Mar 2015 00:26:48 +0100 Subject: [PATCH] Added LRU#maximum=/maximum This allows one to change the maximum amount of keys stored in the XPath/CSS caches, for example: Oga::XPath::Parser::CACHE.maximum = 2056 --- lib/oga/lru.rb | 18 ++++++++++++++++++ spec/oga/lru_spec.rb | 28 ++++++++++++++++++++++++++++ 2 files changed, 46 insertions(+) diff --git a/lib/oga/lru.rb b/lib/oga/lru.rb index 378e414..1fe98b5 100644 --- a/lib/oga/lru.rb +++ b/lib/oga/lru.rb @@ -33,6 +33,24 @@ module Oga @owner = Thread.current end + ## + # @param [Fixnum] value + # + def maximum=(value) + synchronize do + @maximum = value + + resize + end + end + + ## + # @return [Fixnum] + # + def maximum + return synchronize { @maximum } + end + ## # Returns the value of the key. # diff --git a/spec/oga/lru_spec.rb b/spec/oga/lru_spec.rb index bba3f9f..19a3069 100644 --- a/spec/oga/lru_spec.rb +++ b/spec/oga/lru_spec.rb @@ -1,6 +1,34 @@ require 'spec_helper' describe Oga::LRU do + describe '#maximum=' do + it 'sets the maximum amount of keys' do + cache = described_class.new(10) + + cache.maximum = 20 + + cache.maximum.should == 20 + end + + it 'resizes the cache when needed' do + cache = described_class.new(2) + + cache[:a] = 10 + cache[:b] = 20 + + cache.maximum = 1 + + cache.size.should == 1 + cache.keys.should == [:b] + end + end + + describe '#maximum' do + it 'returns the maximum amount of keys' do + described_class.new(5).maximum.should == 5 + end + end + describe '#[]' do it 'returns nil for a non existing key' do described_class.new[:a].should be_nil