|
3 | 3 | [`typing.Final`] is a type qualifier that is used to indicate that a symbol may not be reassigned in
|
4 | 4 | any scope. Final names declared in class scopes cannot be overridden in subclasses.
|
5 | 5 |
|
6 |
| -## Basic |
| 6 | +## Basic type inference |
7 | 7 |
|
8 | 8 | `mod.py`:
|
9 | 9 |
|
10 | 10 | ```py
|
11 | 11 | from typing import Final, Annotated
|
12 | 12 |
|
13 |
| -FINAL_A: int = 1 |
| 13 | +FINAL_A: Final[int] = 1 |
14 | 14 | FINAL_B: Annotated[Final[int], "the annotation for FINAL_B"] = 1
|
15 | 15 | FINAL_C: Final[Annotated[int, "the annotation for FINAL_C"]] = 1
|
16 | 16 | FINAL_D: Final = 1
|
17 | 17 | FINAL_E: "Final[int]" = 1
|
| 18 | +FINAL_F: Final[int] |
| 19 | +FINAL_F = 1 |
18 | 20 |
|
19 | 21 | reveal_type(FINAL_A) # revealed: Literal[1]
|
20 | 22 | reveal_type(FINAL_B) # revealed: Literal[1]
|
21 | 23 | reveal_type(FINAL_C) # revealed: Literal[1]
|
22 | 24 | reveal_type(FINAL_D) # revealed: Literal[1]
|
23 | 25 | reveal_type(FINAL_E) # revealed: Literal[1]
|
24 | 26 |
|
25 |
| -# TODO: All of these should be errors: |
| 27 | +def nonlocal_uses(): |
| 28 | + reveal_type(FINAL_A) # revealed: Literal[1] |
| 29 | + reveal_type(FINAL_B) # revealed: Literal[1] |
| 30 | + reveal_type(FINAL_C) # revealed: Literal[1] |
| 31 | + reveal_type(FINAL_D) # revealed: Literal[1] |
| 32 | + reveal_type(FINAL_E) # revealed: Literal[1] |
| 33 | +``` |
| 34 | + |
| 35 | +Imported types: |
| 36 | + |
| 37 | +```py |
| 38 | +from mod import FINAL_A, FINAL_B, FINAL_C, FINAL_D, FINAL_E, FINAL_F |
| 39 | + |
| 40 | +reveal_type(FINAL_A) # revealed: Literal[1] |
| 41 | +reveal_type(FINAL_B) # revealed: Literal[1] |
| 42 | +reveal_type(FINAL_C) # revealed: Literal[1] |
| 43 | +reveal_type(FINAL_D) # revealed: Literal[1] |
| 44 | +reveal_type(FINAL_E) # revealed: Literal[1] |
| 45 | +reveal_type(FINAL_F) # revealed: Literal[1] |
| 46 | +``` |
| 47 | + |
| 48 | +## Not modifiable |
| 49 | + |
| 50 | +```py |
| 51 | +from typing import Final, Annotated |
| 52 | + |
| 53 | +FINAL_A: Final[int] = 1 |
| 54 | +FINAL_B: Annotated[Final[int], "the annotation for FINAL_B"] = 1 |
| 55 | +FINAL_C: Final[Annotated[int, "the annotation for FINAL_C"]] = 1 |
| 56 | +FINAL_D: Final = 1 |
| 57 | +FINAL_E: "Final[int]" = 1 |
| 58 | +FINAL_F: Final[int] |
| 59 | +FINAL_F = 1 |
| 60 | + |
| 61 | +# TODO: all of these should be errors |
26 | 62 | FINAL_A = 2
|
27 | 63 | FINAL_B = 2
|
28 | 64 | FINAL_C = 2
|
29 | 65 | FINAL_D = 2
|
30 | 66 | FINAL_E = 2
|
31 |
| -``` |
32 |
| - |
33 |
| -Public types: |
34 |
| - |
35 |
| -```py |
36 |
| -from mod import FINAL_A, FINAL_B, FINAL_C, FINAL_D, FINAL_E |
37 |
| - |
38 |
| -# TODO: All of these should be Literal[1] |
39 |
| -reveal_type(FINAL_A) # revealed: int |
40 |
| -reveal_type(FINAL_B) # revealed: int |
41 |
| -reveal_type(FINAL_C) # revealed: int |
42 |
| -reveal_type(FINAL_D) # revealed: Unknown |
43 |
| -reveal_type(FINAL_E) # revealed: int |
| 67 | +FINAL_F = 2 |
44 | 68 | ```
|
45 | 69 |
|
46 | 70 | ## Too many arguments
|
|
0 commit comments