Class: ReeRoda::BuildRoutingTree::RoutingTree

Inherits:
Object
  • Object
show all
Defined in:
lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(values, depth, type, parent = nil, routes = []) ⇒ RoutingTree

Returns a new instance of RoutingTree.



12
13
14
15
16
17
18
19
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 12

def initialize(values, depth, type, parent = nil, routes = [])
  @values = values
  @depth = depth
  @parent = parent
  @type = type
  @routes = []
  @children = []
end

Instance Attribute Details

#childrenObject

Returns the value of attribute children.



9
10
11
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 9

def children
  @children
end

#depthObject

Returns the value of attribute depth.



9
10
11
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 9

def depth
  @depth
end

#parentObject

Returns the value of attribute parent.



9
10
11
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 9

def parent
  @parent
end

#routesObject

Returns the value of attribute routes.



9
10
11
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 9

def routes
  @routes
end

#typeObject

Returns the value of attribute type.



9
10
11
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 9

def type
  @type
end

#valuesObject

Returns the value of attribute values.



9
10
11
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 9

def values
  @values
end

Instance Method Details

#add_child(value, depth, type) ⇒ Object



47
48
49
50
51
52
53
54
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 47

def add_child(value, depth, type)
  new_child = self.class.new([value], depth, type, self)

  self.children << new_child
  self.children = self.children.sort { _1.values[0].match?(/\:/) ? 1 : 0 }

  return new_child
end

#add_route(route) ⇒ Object



57
58
59
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 57

def add_route(route)
  self.routes << route; nil
end

#any_child_has_value?(value) ⇒ Boolean

Returns:

  • (Boolean)


42
43
44
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 42

def any_child_has_value?(value)
  !!self.children.find { |c| c.values.include?(value) }
end

#find_by_value(tree: self, value: nil, type: :param, depth: 0) ⇒ Object



27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 27

def find_by_value(tree: self, value: nil, type: :param, depth: 0)
  return tree if tree.depth == depth && tree.values.include?(value)

  if tree.depth < depth
    res = tree
      .children
      .map { find_by_value(tree: _1, value: value, type: type, depth: depth) }
      .flatten
      .compact

    res.size > 1 ? res : res.first
  end
end


73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 73

def print_proc_tree(tree = self)
  param_value = tree.values[0].start_with?(":") ? String : "\"#{tree.values[0]}\""

  if tree.routes.length == 0
    if tree.children.length > 0
      puts "#{get_offset(tree.depth)}r.on #{param_value} do"

      tree.children.each do |child|
        print_proc_tree(child)
      end

      puts "#{get_offset(tree.depth)}end"
    end

    nil
  else
    if tree.children.length > 0
      puts "#{get_offset(tree.depth)}r.on #{param_value} do"

      tree.children.each do |child|
        print_proc_tree(child)
      end

      puts "#{get_offset(tree.depth + 1)}r.is do"
      tree.routes.each do |route|
        puts "#{get_offset(tree.depth + 2)}r.#{route.request_method} do"
        puts "#{get_offset(tree.depth + 2)}end"
      end
      puts "#{get_offset(tree.depth + 1)}end"

      puts "#{get_offset(tree.depth)}end"
    else
      puts "#{get_offset(tree.depth)}r.is #{param_value} do"

      puts "#{get_offset(tree.depth + 1)}r.is do"
      tree.routes.each do |route|
        puts "#{get_offset(tree.depth + 2)}r.#{route.request_method} do"
        puts "#{get_offset(tree.depth + 2)}end"
      end
      puts "#{get_offset(tree.depth + 1)}end"

      puts "#{get_offset(tree.depth)}end"
    end
  end

  nil
end


61
62
63
64
65
66
67
68
69
70
71
# File 'lib/ree_lib/packages/ree_roda/package/ree_roda/services/build_routing_tree.rb', line 61

def print_tree(tree = self)
  puts "#{get_offset(tree.depth)}#{tree.values.inspect} - #{tree.depth}"

  if tree.children.length > 0
    tree.children.each do |child|
      print_tree(child)
    end
  end

  nil
end