This is an ongoing series of commits that are reformatting our Python code. This catches the last of the python files to reformat. Since they where so few I bunched them together. Reformatting is done with `black`. If you end up having problems merging this commit because you have made changes to a python file, the best way to handle that is to run git checkout --ours <yourfile> and then reformat it with black. If you run into any problems, post to discourse about it and we will try to help. RFC Thread below: https://discourse.llvm.org/t/rfc-document-and-standardize-python-code-style Reviewed By: jhenderson, #libc, Mordante, sivachandra Differential Revision: https://reviews.llvm.org/D150784
32 lines
939 B
Python
32 lines
939 B
Python
# DExTer : Debugging Experience Tester
|
|
# ~~~~~~ ~ ~~ ~ ~~
|
|
#
|
|
# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
# See https://llvm.org/LICENSE.txt for license information.
|
|
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
"""Utility class to check for timeouts. Timer starts when the object is initialized,
|
|
and can be checked by calling timed_out(). Passing a timeout value of 0.0 or less
|
|
means a timeout will never be triggered, i.e. timed_out() will always return False.
|
|
"""
|
|
|
|
import time
|
|
|
|
|
|
class Timeout(object):
|
|
def __init__(self, duration: float):
|
|
self.start = self.now
|
|
self.duration = duration
|
|
|
|
def timed_out(self):
|
|
if self.duration <= 0.0:
|
|
return False
|
|
return self.elapsed > self.duration
|
|
|
|
@property
|
|
def elapsed(self):
|
|
return self.now - self.start
|
|
|
|
@property
|
|
def now(self):
|
|
return time.time()
|