Class: ExtendedLogger::Define

Inherits:
Object
  • Object
show all
Defined in:
lib/extended_logger/define.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(subclass, levels, sink_defaults) ⇒ Define

Returns a new instance of Define.



15
16
17
18
19
# File 'lib/extended_logger/define.rb', line 15

def initialize subclass, levels, sink_defaults
  @levels = levels
  @sink_defaults = sink_defaults
  @subclass = subclass
end

Instance Attribute Details

#levelsObject (readonly)

Returns the value of attribute levels.



11
12
13
# File 'lib/extended_logger/define.rb', line 11

def levels
  @levels
end

#sink_defaultsObject (readonly)

Returns the value of attribute sink_defaults.



12
13
14
# File 'lib/extended_logger/define.rb', line 12

def sink_defaults
  @sink_defaults
end

#subclassObject (readonly)

Returns the value of attribute subclass.



13
14
15
# File 'lib/extended_logger/define.rb', line 13

def subclass
  @subclass
end

Class Method Details

.call(*arguments) ⇒ Object



21
22
23
24
# File 'lib/extended_logger/define.rb', line 21

def self.call *arguments
  instance = new *arguments
  instance.()
end

Instance Method Details

#callObject



26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
# File 'lib/extended_logger/define.rb', line 26

def call
  levels = self.level_set

  subclass.define_singleton_method :levels do levels end
  subclass.send :define_method, :levels do self.class.levels end

  if sink_defaults = self.sink_defaults
    subclass.define_singleton_method :sink_defaults do
      sink_defaults
    end
  end

  levels.each do |level|
    method_name = level.name

    subclass.send :define_method, method_name do |*arguments, &block|
      add level, *arguments, &block
    end
  end
end

#level_setObject



47
48
49
50
51
52
53
# File 'lib/extended_logger/define.rb', line 47

def level_set
  if levels.is_a? Level::Set
    levels
  else
    Level::Set.build levels
  end
end