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 |