Module: MultidimensionalTable

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.0.1"

Instance Method Summary collapse

Instance Method Details

#check_duplicates(map) ⇒ Object



30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# File 'lib/multidimensional_table/multidimensional_table.rb', line 30

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



69
70
71
# File 'lib/multidimensional_table/multidimensional_table.rb', line 69

def dimensions
  @dimensions ||= {}
end

#dimensions=(map) ⇒ Object



6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# File 'lib/multidimensional_table/multidimensional_table.rb', line 6

def dimensions=(map)
  @dimensions = map
  check_duplicates(map)
  @dimensions.each do |key, value|
    value.each do |possible_value|
      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

#table_dataObject



61
62
63
64
65
66
67
# File 'lib/multidimensional_table/multidimensional_table.rb', line 61

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

#table_resultObject



57
58
59
# File 'lib/multidimensional_table/multidimensional_table.rb', line 57

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

#update_attributes(attrs) ⇒ Object



53
54
55
# File 'lib/multidimensional_table/multidimensional_table.rb', line 53

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