blob: 40232f1ff5696c52bb4d0074158a524f3c8c63d8 [file] [log] [blame]
# Copyright 2015 The Chromium Authors
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""Common utilites used by cygprofile scripts.
"""
import logging
class WarningCollector:
"""Collects warnings, but limits the number printed to a set value."""
def __init__(self, max_warnings, level=logging.WARNING):
self._warnings = 0
self._max_warnings = max_warnings
self._level = level
def Write(self, message):
"""Prints a warning if fewer than max_warnings have already been printed."""
if self._warnings < self._max_warnings:
logging.log(self._level, message)
self._warnings += 1
def WriteEnd(self, message):
"""Once all warnings have been printed, use this to print the number of
elided warnings."""
if self._warnings > self._max_warnings:
logging.log(self._level, '%d more warnings for: %s' % (
self._warnings - self._max_warnings, message))