-
-
Notifications
You must be signed in to change notification settings - Fork 584
/
Copy pathinterrupt.py
69 lines (54 loc) · 2.71 KB
/
interrupt.py
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#
# Copyright (c) 2017 nexB Inc. and others. All rights reserved.
# http://nexb.com and https://github.com/nexB/scancode-toolkit/
# The ScanCode software is licensed under the Apache License version 2.0.
# Data generated with ScanCode require an acknowledgment.
# ScanCode is a trademark of nexB Inc.
#
# You may not use this software except in compliance with the License.
# You may obtain a copy of the License at: http://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 "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.
#
# When you publish or redistribute any data created with ScanCode or any ScanCode
# derivative work, you must accompany this data with the following acknowledgment:
#
# Generated with ScanCode and provided on an "AS IS" BASIS, WITHOUT WARRANTIES
# OR CONDITIONS OF ANY KIND, either express or implied. No content created from
# ScanCode should be considered or used as legal advice. Consult an Attorney
# for any legal advice.
# ScanCode is a free software code scanning tool from nexB Inc. and others.
# Visit https://github.com/nexB/scancode-toolkit/ for support and download.
from __future__ import print_function
from __future__ import absolute_import
from scancode.timeouts import Timeout
DEFAULT_TIMEOUT = 120 # seconds
class TimeoutError(Exception):
pass
def interruptible(func, args=(), kwargs={}, timeout=DEFAULT_TIMEOUT):
"""
Call `func` function with `args` and `kwargs` arguments and return a tuple of
(success, return value). `func` is invoked through an OS-specific wrapper and
will be interrupted if it does not return within `timeout` seconds.
`func` returned results must be pickable.
`timeout` in seconds defaults to DEFAULT_TIMEOUT.
`args` and `kwargs` are passed to `func` as *args and **kwargs.
In the returned tuple of (success, value), success is True or False.
If success is True, the call was successful and the second item in the tuple is
the returned value of `func`.
If success is False, the call did not complete within `timeout`
seconds and was interrupted. In this case, the second item in the
tuple is an error message string.
"""
runner = Timeout(timeout, TimeoutError)
def runnable():
return func(*args, **kwargs)
try:
return True, runner.execute(runnable)
except:
import traceback
traceback.print_exc()
return False, ('ERROR: Processing interrupted: timeout after '
'%(timeout)d seconds.' % locals())