Module: MultidimensionalTable

Included in:
TestClass
Defined in:
lib/multidimensional_table/version.rb,
lib/multidimensional_table/non_valid_dimension.rb,
lib/multidimensional_table/multidimensional_table.rb,
lib/multidimensional_table/non_existant_dimension_attribute.rb

Defined Under Namespace

Classes: NonExistantDimensionAttribute, NonValidDimension

Constant Summary collapse

VERSION =
"1.1.0"

Instance Method Summary collapse

Instance Method Details

#check_duplicates(map) ⇒ Object



37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# File 'lib/multidimensional_table/multidimensional_table.rb', line 37

def check_duplicates(map)
  list = {}
  combined = map.each_value.reduce([]) { |all, value| all << value }.flatten
  combined.each do |item|
    if list[item].nil? 
      list[item] = 1
    else
      list[item] = list[item] + 1
    end
  end
  duplicates = list.select { |key, value| key if value > 1 }
  if duplicates != {}
    non_valid_dimensions = {}
    duplicates.each_key do |duplicate|
      non_valid_dimensions[duplicate] = []
      map.each do |key,value|
        non_valid_dimensions[duplicate] << key if value.include?(duplicate)
      end
    end
    raise NonValidDimension, non_valid_dimensions
  end
end

#dimensionsObject



76
77
78
# File 'lib/multidimensional_table/multidimensional_table.rb', line 76

def dimensions
  @dimensions ||= {}
end

#initializeObject



6
7
8
9
# File 'lib/multidimensional_table/multidimensional_table.rb', line 6

def initialize
  set_dimensions(dimensions)
  data
end

#set_dimensions(map) ⇒ Object



11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# File 'lib/multidimensional_table/multidimensional_table.rb', line 11

def set_dimensions(map)
  @dimensions = map
  check_duplicates(map)
  @dimensions.each do |key, value|
    value.each do |possible_value|
      Kernel.class_eval do
      define_method possible_value do |value = nil,  &block|
        if value.nil? && !block.nil?
          @index_level += 1
          @context[@index_level] = "@attributes[:#{key}] == :#{possible_value}" 
          begin
            block.call
          rescue NoMethodError => e
            raise NonExistantDimensionAttribute.new(e.name)
          end
          @index_level -= 1
        elsif !value.nil?
          context = (1..@index_level).reduce([]) { |context, level| context << @context[level] }
          @table_rules[value] = context << ["@attributes[:#{key}] == :#{possible_value}"]  
        end
      end
      end
    end
  end
end

#table_dataObject



68
69
70
71
72
73
74
# File 'lib/multidimensional_table/multidimensional_table.rb', line 68

def table_data
  @context = []
  @table_rules = {}
  @attributes ||= {}
  @index_level = 0
  yield
end

#table_resultObject



64
65
66
# File 'lib/multidimensional_table/multidimensional_table.rb', line 64

def table_result
  @table_rules.each { |key, condition| return key if eval(condition.join(' && ')) == true }
end

#update_attributes(attrs) ⇒ Object



60
61
62
# File 'lib/multidimensional_table/multidimensional_table.rb', line 60

def update_attributes(attrs)
  attrs.each do |key, value| @attributes[key] = value end
end