1from __future__ import print_function
2
3import sys
4import logging
5from logging import handlers
6
7import common
8
9from infra_libs import ts_mon
10
11
12def RunMatchers(stream, matchers):
13    """Parses lines of |stream| using patterns and emitters from |matchers|
14
15    @param stream: A file object to read from.
16    @param matchers: A list of pairs of (matcher, emitter), where matcher is a
17        regex and emitter is a function called when the regex matches.
18    """
19    # The input might terminate if the log gets rotated. Make sure that Monarch
20    # flushes any pending metrics before quitting.
21    try:
22        for line in iter(stream.readline, ''):
23            for matcher, emitter in matchers:
24                m = matcher.match(line)
25                if m:
26                    emitter(m)
27    finally:
28        ts_mon.close()
29        ts_mon.flush()
30
31
32def SetupLogging(args):
33    """Sets up logging based on the parsed arguments."""
34    # Set up logging.
35    root = logging.getLogger()
36    if args.output_logfile:
37        handler = handlers.RotatingFileHandler(
38            args.output_logfile, maxBytes=10**6, backupCount=5)
39        root.addHandler(handler)
40    else:
41        root.addHandler(logging.StreamHandler(sys.stdout))
42    root.setLevel(logging.DEBUG)
43