Sha256: b71068b1bcc87f514931fa78dc6767190caa32246e3f717c94b7060d7e8cba15

Contents?: true

Size: 810 Bytes

Versions: 10

Compression:

Stored size: 810 Bytes

Contents

module Apimaster::Generators
  class SimpleLogger # :nodoc:
    attr_reader :out
    attr_accessor :quiet

    def initialize(out = $stdout)
      @out = out
      @quiet = false
      @level = 0
    end

    def log(status, message, &block)
      @out.print("%12s  %s%s\n" % [status, '  ' * @level, message]) unless quiet
      indent(&block) if block_given?
    end

    def indent(&block)
      @level += 1
      if block_given?
        begin
          block.call
        ensure
          outdent
        end
      end
    end

    def outdent
      @level -= 1
      if block_given?
        begin
          block.call
        ensure
          indent
        end
      end
    end

    private
      def method_missing(method, *args, &block)
        log(method.to_s, args.first, &block)
      end
  end
end

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
apimaster-0.1.4 lib/apimaster/generators/simple_logger.rb
apimaster-0.1.3 lib/apimaster/generators/simple_logger.rb
apimaster-0.1.2 lib/apimaster/generators/simple_logger.rb
apimaster-0.1.1 lib/apimaster/generators/simple_logger.rb
apimaster-0.0.7 lib/apimaster/generators/simple_logger.rb
apimaster-0.0.6 lib/apimaster/generators/simple_logger.rb
apimaster-0.0.5 lib/apimaster/generators/simple_logger.rb
apimaster-0.0.4 lib/apimaster/generators/simple_logger.rb
apimaster-0.0.3 lib/apimaster/generators/simple_logger.rb
apimaster-0.0.2 lib/apimaster/generators/simple_logger.rb