File: pebble.rb

package info (click to toggle)
ruby-naught 2.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 180 kB
  • sloc: ruby: 658; makefile: 6
file content (37 lines) | stat: -rw-r--r-- 1,104 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
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
36
37
require "naught/null_class_builder/command"

module Naught
  class NullClassBuilder
    module Commands
      # Logs missing method calls and their call sites
      #
      # @api private
      class Pebble < Command
        # Create a pebble command with optional output stream
        #
        # @param builder [NullClassBuilder]
        # @param output [#puts] output stream for log lines
        # @api private
        def initialize(builder, output = $stdout)
          super(builder)
          @output = output
        end

        # Install the logging method_missing hook
        # @return [void]
        # @api private
        def call
          output = @output
          defer_prepend_module do
            define_method(:method_missing) do |method_name, *args|
              pretty_args = args.map(&:inspect).join(", ").tr('"', "'")
              caller_desc = Naught::CallerInfo.format_caller_for_pebble(Kernel.caller(1))
              output.puts "#{method_name}(#{pretty_args}) from #{caller_desc}"
              self
            end
          end
        end
      end
    end
  end
end