cleaner code in Redistat::Finder

This commit is contained in:
2010-10-18 00:58:11 +01:00
parent 5299b64fbc
commit 44ea115ca7
4 changed files with 41 additions and 39 deletions

View File

@@ -14,6 +14,7 @@ require 'redistat/date'
require 'redistat/event'
require 'redistat/finder'
require 'redistat/finder/date_set'
require 'redistat/hash'
require 'redistat/key'
require 'redistat/label'
require 'redistat/model'

View File

@@ -18,44 +18,31 @@ module Redistat
return nil if !valid_options?
sets = Finder::DateSet.new(@options[:from], @options[:till], @options[:depth], @options[:interval])
key = Key.new(@options[:scope], @options[:label])
sum = {}
total_sum = Hash.new
sets.each do |set|
set_sum = summarize_add_keys(set[:add], key, {})
set_sum = summarize_sub_keys(set[:sub], key, set_sum)
set_sum.each do |k, v|
if sum.has_key?(k)
sum[k] += v.to_i
else
sum[k] = v.to_i
end
sum = Hash.new
sum = summarize_add_keys(set[:add], key, sum)
sum = summarize_rem_keys(set[:rem], key, sum)
sum.each do |k, v|
total_sum.set_or_incr(k, v.to_i)
end
end
total_sum
end
def summarize_add_keys(sets, key, sum)
sets.each do |date|
db.hgetall("#{key.prefix}#{date}").each do |k, v|
sum.set_or_incr(k, v.to_i)
end
end
sum
end
def summarize_add_keys(the_sets, key, sum)
the_sets.each do |date|
stat = db.hgetall("#{key.prefix}#{date}")
stat.each do |k, v|
if sum.has_key?(k)
sum[k] += v.to_i
else
sum[k] = v.to_i
end
end
end
sum
end
def summarize_sub_keys(the_sets, key, sum)
the_sets.each do |date|
stat = db.hgetall("#{key.prefix}#{date}")
stat.each do |k, v|
if sum.has_key?(k)
sum[k] -= v.to_i
else
sum[k] = -v.to_i
end
def summarize_rem_keys(sets, key, sum)
sets.each do |date|
db.hgetall("#{key.prefix}#{date}").each do |k, v|
sum.set_or_incr(k, -v.to_i)
end
end
sum

11
lib/redistat/hash.rb Normal file
View File

@@ -0,0 +1,11 @@
module Redistat
class Hash < ::Hash
def set_or_incr(key, value)
self[key] = 0 if !self.has_key?(key)
self[key] += value
self
end
end
end