Commit 5bbe0cd
authored
feat!: Add Visibility to FuncDefn/FuncDecl. (#2143)
Note: modified to come after #2412 as I want those Schema checks in
place to check this works!
closes #2354, #1752.
Includes cherry-pick of #2343.
* Add `enum Visibility`. In fact *2 (hugr-model version is not
serde-able so cannot be used in hugr-core).
* `FuncDefn` and `FuncDecl` gain this. (A good use-case for a private
FuncDecl is building cyclic functions via builder `define_declaration`.)
* I've not added to `AliasDecl` or `AliasDefn` - I could, it would be
consistent, but we hardly use them....
* `validate` checks that the *public* children of a Module have unique
names (except multiple FuncDecls may alias).
* `FuncDefn::new` defaults to private (also builder `define_function` /
`FunctionBuilder::new`, and json-deserialize in both python and rust).
There is a `_vis` taking an explicit Visibility parameter.
* `FuncDecl::new` defaults to public (also builder `declare_function`,
and json-deserialize*2). Again there is `_vis`.
* hugr-model import/export + roundtrip + AST printing via new keyword
`pub`. Note since `hugr-core` does not have visibility on aliases or
extension operations I've defaulted these to private to avoid any change
to textual output.
* add field to hugr-py, using "string"-enum (`Literal["Public",
"Private"]`)
* I've attempted to add hugr-model hugr-py bindings, but there are no
tests of these yet.
Note all changes to hugr-passes delayed until a follow-up PR.
BREAKING CHANGE: hugr-model: Symbol has an extra field1 parent f557008 commit 5bbe0cd
41 files changed
Lines changed: 950 additions & 422 deletions
File tree
- hugr-core
- src
- builder
- hugr
- serialize
- upgrade/testcases
- validate
- views/root_checked
- ops
- tests/snapshots
- hugr-model
- capnp
- src
- capnp
- v0
- ast
- binary
- table
- hugr-persistent/src
- persistent_hugr/snapshots
- state_space/snapshots
- hugr-py
- src/hugr
- _serialization
- model
- tests
- __snapshots__
- resources/test
- specification/schema
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | | - | |
12 | | - | |
13 | | - | |
14 | | - | |
| 11 | + | |
15 | 12 | | |
16 | | - | |
17 | | - | |
18 | | - | |
| 13 | + | |
19 | 14 | | |
20 | 15 | | |
21 | 16 | | |
| |||
152 | 147 | | |
153 | 148 | | |
154 | 149 | | |
155 | | - | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
156 | 153 | | |
157 | 154 | | |
158 | 155 | | |
159 | 156 | | |
160 | 157 | | |
161 | 158 | | |
162 | 159 | | |
163 | | - | |
164 | | - | |
165 | | - | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
166 | 179 | | |
167 | 180 | | |
168 | 181 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
7 | | - | |
8 | 7 | | |
9 | 8 | | |
10 | 9 | | |
11 | | - | |
12 | | - | |
13 | 10 | | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
14 | 14 | | |
15 | | - | |
16 | 15 | | |
17 | 16 | | |
18 | 17 | | |
| |||
69 | 68 | | |
70 | 69 | | |
71 | 70 | | |
72 | | - | |
73 | | - | |
74 | | - | |
75 | | - | |
76 | | - | |
77 | | - | |
78 | | - | |
79 | | - | |
80 | | - | |
81 | | - | |
82 | | - | |
83 | | - | |
84 | | - | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
85 | 120 | | |
86 | 121 | | |
87 | 122 | | |
88 | 123 | | |
89 | 124 | | |
90 | | - | |
| 125 | + | |
91 | 126 | | |
92 | 127 | | |
93 | 128 | | |
| |||
97 | 132 | | |
98 | 133 | | |
99 | 134 | | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
100 | 151 | | |
101 | 152 | | |
102 | 153 | | |
103 | | - | |
| 154 | + | |
104 | 155 | | |
105 | 156 | | |
106 | 157 | | |
| |||
112 | 163 | | |
113 | 164 | | |
114 | 165 | | |
115 | | - | |
116 | | - | |
| 166 | + | |
| 167 | + | |
117 | 168 | | |
118 | 169 | | |
119 | 170 | | |
| |||
124 | 175 | | |
125 | 176 | | |
126 | 177 | | |
127 | | - | |
128 | | - | |
129 | | - | |
130 | | - | |
131 | | - | |
132 | | - | |
133 | | - | |
134 | | - | |
135 | | - | |
136 | | - | |
137 | | - | |
138 | | - | |
139 | | - | |
| 178 | + | |
140 | 179 | | |
141 | 180 | | |
142 | 181 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
276 | 276 | | |
277 | 277 | | |
278 | 278 | | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
279 | 319 | | |
280 | 320 | | |
281 | 321 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
20 | 20 | | |
21 | 21 | | |
22 | 22 | | |
| 23 | + | |
23 | 24 | | |
24 | 25 | | |
25 | 26 | | |
| |||
230 | 231 | | |
231 | 232 | | |
232 | 233 | | |
233 | | - | |
234 | | - | |
235 | | - | |
236 | | - | |
237 | | - | |
238 | | - | |
239 | | - | |
240 | | - | |
241 | | - | |
242 | | - | |
243 | 234 | | |
244 | 235 | | |
245 | 236 | | |
| |||
338 | 329 | | |
339 | 330 | | |
340 | 331 | | |
341 | | - | |
342 | | - | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
343 | 337 | | |
344 | 338 | | |
345 | 339 | | |
| |||
349 | 343 | | |
350 | 344 | | |
351 | 345 | | |
352 | | - | |
353 | | - | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
354 | 351 | | |
355 | 352 | | |
356 | 353 | | |
357 | 354 | | |
358 | 355 | | |
359 | 356 | | |
| 357 | + | |
| 358 | + | |
360 | 359 | | |
| 360 | + | |
361 | 361 | | |
362 | 362 | | |
363 | 363 | | |
| |||
370 | 370 | | |
371 | 371 | | |
372 | 372 | | |
| 373 | + | |
| 374 | + | |
373 | 375 | | |
| 376 | + | |
374 | 377 | | |
375 | 378 | | |
376 | 379 | | |
| |||
545 | 548 | | |
546 | 549 | | |
547 | 550 | | |
548 | | - | |
| 551 | + | |
| 552 | + | |
549 | 553 | | |
550 | 554 | | |
551 | 555 | | |
| |||
796 | 800 | | |
797 | 801 | | |
798 | 802 | | |
| 803 | + | |
799 | 804 | | |
800 | 805 | | |
801 | 806 | | |
802 | 807 | | |
803 | 808 | | |
804 | 809 | | |
805 | | - | |
| 810 | + | |
806 | 811 | | |
807 | 812 | | |
808 | 813 | | |
| |||
814 | 819 | | |
815 | 820 | | |
816 | 821 | | |
| 822 | + | |
817 | 823 | | |
818 | 824 | | |
819 | 825 | | |
| |||
0 commit comments