Method: Roby::Application#setup_loggers
- Defined in:
- lib/roby/app.rb
#setup_loggers(ignore_missing: false, redirections: true) ⇒ Object
Sets up all the default loggers. It creates the logger for the Robot module (accessible through Robot.logger), and sets up log levels as specified in the config/app.yml file.
1805 1806 1807 1808 1809 1810 1811 1812 1813 1814 1815 1816 1817 1818 1819 1820 1821 1822 1823 1824 1825 1826 1827 1828 1829 1830 1831 1832 1833 1834 1835 1836 1837 1838 1839 1840 1841 1842 1843 1844 1845 |
# File 'lib/roby/app.rb', line 1805 def setup_loggers(ignore_missing: false, redirections: true) Robot.logger.progname = robot_name || "Robot" return unless log["levels"] # Set up log levels log["levels"].each do |name, value| const_name = name.modulize mod = begin Kernel.constant(const_name) rescue NameError => e if ignore_missing next elsif name != const_name raise InvalidLoggerName, "cannot resolve logger #{name} (resolved as #{const_name}): #{e.message}" else raise InvalidLoggerName, "cannot resolve logger #{name}: #{e.message}" end end if value =~ /^(\w+):(.+)$/ value, file = $1, $2 file = file.gsub("ROBOT", robot_name) if robot_name end level = Logger.const_get(value) io = if redirections && file path = File.(file, log_dir) Robot.info "redirected logger for #{mod} to #{path} (level #{level})" io = File.open(path, "w") io.sync = true log_files[path] ||= io else STDOUT end new_logger = Logger.new(io) new_logger.level = level new_logger.formatter = mod.logger.formatter new_logger.progname = [name, robot_name].compact.join(" ") mod.logger = new_logger end end |