Sha256: b827d3a279e1bad4cab96b7f6efc19c9e482669a8f547cb8c7f49ff086738dac

Contents?: true

Size: 1.79 KB

Versions: 1

Compression:

Stored size: 1.79 KB

Contents

require 'date'
require 'logger'

require_relative 'vedeu/repository/command_repository'
require_relative 'vedeu/repository/interface_repository'
require_relative 'vedeu/repository/event_repository'
require_relative 'vedeu/support/exit'
require_relative 'vedeu/launcher'

module Vedeu
  # :nocov:
  module ClassMethods
    def command(name, options = {})
      CommandRepository.create({ name: stringify_symbols(name) }
                       .merge!(options))
    end

    def interface(name, options = {})
      InterfaceRepository.create({ name: stringify_symbols(name) }
                         .merge!(options))
    end

    def event(name, &block)
      EventRepository.register(name, &block)
    end

    def run(name, *args)
      EventRepository.trigger(name, *args)
    end

    private

    def stringify_symbols(value)
      value.is_a?(::Symbol) ? value.to_s : value
    end
  end

  def self.logger
    @logger ||= Logger.new(root_path + '/logs/vedeu.log').tap do |log|
      log.formatter = proc do |_, time, _, msg|
        "\n#{time.iso8601}: #{msg}\n"
      end
    end
  end

  def self.error(exception)
    logger.debug "\e[38;5;196mError:\e[38;2;39m\e[48;2;49m " +
                 "#{exception.message}\n\n" +
                 exception.backtrace.join("\n")
  end

  def self.debug(filename = 'profile.html', &block)
    require 'ruby-prof'

    RubyProf.start

    yield

    result = RubyProf.stop
    result.eliminate_methods!([/^Array/, /^Hash/])

    File.open(Vedeu.root_path + '/tmp/' + filename, 'w') do |file|
      RubyProf::CallStackPrinter.new(result).print(file)
      # RubyProf::GraphPrinter.new(result).print(file)
    end
  end

  def self.included(receiver)
    receiver.extend(ClassMethods)
  end

  private

  def self.root_path
    File.expand_path('../..', __FILE__)
  end
  # :nocov:
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
vedeu-0.0.31 lib/vedeu.rb