forked from fluentpython/example-code-2e
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathspinner_thread.py
43 lines (36 loc) · 1.13 KB
/
spinner_thread.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
# spinner_thread.py
# credits: Adapted from Michele Simionato's
# multiprocessing example in the python-list:
# https://mail.python.org/pipermail/python-list/2009-February/675659.html
# tag::SPINNER_THREAD_TOP[]
import itertools
import time
from threading import Thread, Event
def spin(msg: str, done: Event) -> None: # <1>
for char in itertools.cycle(r'\|/-'): # <2>
status = f'\r{char} {msg}' # <3>
print(status, end='', flush=True)
if done.wait(.1): # <4>
break # <5>
blanks = ' ' * len(status)
print(f'\r{blanks}\r', end='') # <6>
def slow() -> int:
time.sleep(3) # <7>
return 42
# end::SPINNER_THREAD_TOP[]
# tag::SPINNER_THREAD_REST[]
def supervisor() -> int: # <1>
done = Event() # <2>
spinner = Thread(target=spin, args=('thinking!', done)) # <3>
print(f'spinner object: {spinner}') # <4>
spinner.start() # <5>
result = slow() # <6>
done.set() # <7>
spinner.join() # <8>
return result
def main() -> None:
result = supervisor() # <9>
print(f'Answer: {result}')
if __name__ == '__main__':
main()
# end::SPINNER_THREAD_REST[]