blob: c882e76cb0dded3ec9ae843868c36e7c4194ac57 [file] [log] [blame]
#!/usr/bin/env python
#
# Copyright 2021 - The Android Open Source Project
#
# Licensed under the Apache License, Version 2.0 (the', help='License');
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an', help='AS IS' BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import datetime
import logging
import time
class TimeFormatter(logging.Formatter):
"""A formatter used by the build system that:
- Strips whitespace.
- Formats time since start
"""
def __init__(self, fmt=None):
self.start_time = time.time()
super(TimeFormatter, self).__init__(fmt)
def formatTime(self, record, datefmt=None):
fmt = datefmt or "%H:%M:%S"
ct = self.converter(record.created)
dt = datetime.timedelta(seconds=record.created - self.start_time)
mm, ss = divmod(dt.total_seconds(), 60)
_, mm = divmod(mm, 60)
# 2 digit precision is sufficient.
dt_fmt = "%02d:%02d.%-2d" % (mm, ss, dt.microseconds % 100)
return "{}({})".format(time.strftime(fmt, ct), dt_fmt)
def format(self, record):
record.msg = str(record.msg).strip()
return super(TimeFormatter, self).format(record)