from __future__ import print_function import sys import logging from logging import handlers import common from infra_libs import ts_mon def RunMatchers(stream, matchers): """Parses lines of |stream| using patterns and emitters from |matchers| @param stream: A file object to read from. @param matchers: A list of pairs of (matcher, emitter), where matcher is a regex and emitter is a function called when the regex matches. """ # The input might terminate if the log gets rotated. Make sure that Monarch # flushes any pending metrics before quitting. try: for line in iter(stream.readline, ''): for matcher, emitter in matchers: m = matcher.match(line) if m: emitter(m) finally: ts_mon.close() ts_mon.flush() def SetupLogging(args): """Sets up logging based on the parsed arguments.""" # Set up logging. root = logging.getLogger() if args.output_logfile: handler = handlers.RotatingFileHandler( args.output_logfile, maxBytes=10**6, backupCount=5) root.addHandler(handler) else: root.addHandler(logging.StreamHandler(sys.stdout)) root.setLevel(logging.DEBUG)