File: gen_yield_from_throw3.py

package info (click to toggle)
giac 1.9.0.35%2Bdfsg2-1.1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 113,448 kB
  • sloc: cpp: 394,793; ansic: 200,527; python: 30,548; javascript: 28,735; makefile: 8,328; yacc: 2,690; lex: 2,458; sh: 623; perl: 314; lisp: 216; asm: 62; java: 41; xml: 36; sed: 16; csh: 7; pascal: 6
file content (57 lines) | stat: -rw-r--r-- 1,030 bytes parent folder | download | duplicates (4)
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
# yield-from a user-defined generator with a throw() method

class Iter:
    def __iter__(self):
        return self

    def __next__(self):
        return 1

    def throw(self, x):
        print('throw', x)
        return 456

def gen():
    yield from Iter()

# calling close() should not call throw()
g = gen()
print(next(g))
g.close()

# can throw a non-exception object
g = gen()
print(next(g))
print(g.throw(123))

# throwing an exception class just injects that class
g = gen()
print(next(g))
print(g.throw(ZeroDivisionError))

# this user-defined generator doesn't have a throw() method
class Iter2:
    def __iter__(self):
        return self

    def __next__(self):
        return 1

def gen2():
    yield from Iter2()

# the thrown ValueError is not intercepted by the user class
g = gen2()
print(next(g))
try:
    g.throw(ValueError)
except:
    print('ValueError')

# the thrown 123 is not an exception so raises a TypeError
g = gen2()
print(next(g))
try:
    g.throw(123)
except TypeError:
    print('TypeError')