1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
# -*- coding: utf-8 -*-
# -----------------------------------------------------------------------------
# Liblarch - a library to handle directed acyclic graphs
# Copyright (c) 2011-2012 - Lionel Dricot & Izidor MatuĊĦov
#
# This program is free software: you can redistribute it and/or modify it under
# the terms of the GNU Lesser General Public License as published by the Free
# Software Foundation, either version 3 of the License, or (at your option) any
# later version.
#
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
# details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# -----------------------------------------------------------------------------
import threading
class Watchdog(object):
'''
a simple thread-safe watchdog.
usage:
with Watchdod(timeout, error_function):
#do something
'''
def __init__(self, timeout, error_function):
'''
Just sets the timeout and the function to execute when an error occours
@param timeout: timeout in seconds
@param error_function: what to execute in case the watchdog timer
triggers
'''
self.timeout = timeout
self.error_function = error_function
def __enter__(self):
'''Starts the countdown'''
self.timer = threading.Timer(self.timeout, self.error_function)
self.timer.start()
def __exit__(self, type, value, traceback):
'''Aborts the countdown'''
try:
self.timer.cancel()
except:
pass
if value is None:
return True
return False
|