Commit 7f75010
committed
Force
Because type annotations in python are a "I wish people would respect my
authority" kind of feature, we cannot guarantee that a `Graph` is
actually created with frozensets as attributes. That is the case all
throughout taskgraph where we're passing sets. By forcing those
attributes to be frozensets we can ensure that `Graph` is hashable which
will allow us to use `functools.lru_cache` to cache some expensive
functions in here.
Unfortunately, there's no easy way of transforming the inputs passed
into a dataclass, since in both `__init__` and `__post_init__`, the
structure is already frozen. By using a dataclass as the parent of
`Graph` instead of `Graph` itself, we can work around the issue while
keeping the frozenness of the dataclass post init without having to
resort to working around dataclass when transforming the attributesGraph to actually use frozensets1 parent 8c8488d commit 7f75010
4 files changed
+14
-7
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | | - | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
12 | 17 | | |
13 | 18 | | |
14 | 19 | | |
| |||
23 | 28 | | |
24 | 29 | | |
25 | 30 | | |
26 | | - | |
27 | | - | |
| 31 | + | |
| 32 | + | |
28 | 33 | | |
29 | 34 | | |
30 | 35 | | |
| |||
67 | 72 | | |
68 | 73 | | |
69 | 74 | | |
70 | | - | |
| 75 | + | |
71 | 76 | | |
72 | 77 | | |
73 | 78 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
51 | 51 | | |
52 | 52 | | |
53 | 53 | | |
54 | | - | |
| 54 | + | |
55 | 55 | | |
56 | 56 | | |
57 | 57 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
451 | 451 | | |
452 | 452 | | |
453 | 453 | | |
454 | | - | |
| 454 | + | |
| 455 | + | |
| 456 | + | |
455 | 457 | | |
456 | 458 | | |
457 | 459 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
67 | 67 | | |
68 | 68 | | |
69 | 69 | | |
70 | | - | |
| 70 | + | |
71 | 71 | | |
0 commit comments