Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Python bindings for hugr-model. #1959

Merged
merged 4 commits into from
Mar 26, 2025
Merged

feat: Python bindings for hugr-model. #1959

merged 4 commits into from
Mar 26, 2025

Conversation

zrho
Copy link
Contributor

@zrho zrho commented Mar 10, 2025

This PR introduces Python bindings to hugr-model.

  • Python representation of the hugr model AST as simple dataclasses.
  • Conversion between the Python and Rust AST.
  • Pretty printing and parsing of the AST via the Rust implementation.
  • Binary serialisation and deserialisation of the AST via the Rust implementation.
  • Export of the hugr-py data structures into the Python AST.

Until spec ambiguities about uniqueness of names are decided, the export procedure mangles the names of symbols by adding the id of the defining node.

@zrho zrho force-pushed the zrho/model-python branch from f8f574a to a9b846a Compare March 10, 2025 15:52
Copy link

codecov bot commented Mar 10, 2025

Codecov Report

Attention: Patch coverage is 24.53066% with 603 lines in your changes missing coverage. Please review.

Project coverage is 82.62%. Comparing base (41905f9) to head (d653290).
Report is 1 commits behind head on main.

Files with missing lines Patch % Lines
hugr-model/src/v0/ast/python.rs 0.00% 246 Missing ⚠️
hugr-py/src/hugr/model/export.py 9.66% 215 Missing ⚠️
hugr-model/src/v0/mod.rs 0.00% 78 Missing ⚠️
hugr-py/src/hugr/tys.py 44.26% 34 Missing ⚠️
hugr-py/src/hugr/model/__init__.py 90.44% 13 Missing ⚠️
hugr-py/src/hugr/val.py 41.17% 10 Missing ⚠️
hugr-py/src/hugr/hugr/base.py 33.33% 4 Missing ⚠️
hugr-py/src/hugr/std/collections/array.py 75.00% 1 Missing ⚠️
hugr-py/src/hugr/std/float.py 66.66% 1 Missing ⚠️
hugr-py/src/hugr/std/int.py 66.66% 1 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #1959      +/-   ##
==========================================
- Coverage   83.79%   82.62%   -1.17%     
==========================================
  Files         211      214       +3     
  Lines       39757    40552     +795     
  Branches    36435    36763     +328     
==========================================
+ Hits        33314    33506     +192     
- Misses       4567     5170     +603     
  Partials     1876     1876              
Flag Coverage Δ
python 85.82% <40.63%> (-6.41%) ⬇️
rust 82.29% <1.51%> (-0.73%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

@zrho zrho force-pushed the zrho/model-python branch 3 times, most recently from 49fd266 to f7c4ba4 Compare March 19, 2025 18:27
@zrho zrho force-pushed the zrho/model-python branch 3 times, most recently from fb1ac5f to 93ee945 Compare March 20, 2025 15:02
@zrho zrho marked this pull request as ready for review March 20, 2025 15:13
@zrho zrho requested a review from a team as a code owner March 20, 2025 15:13
@zrho zrho requested a review from croyzor March 20, 2025 15:13
@ss2165
Copy link
Member

ss2165 commented Mar 20, 2025

related #882

@@ -82,6 +91,10 @@ def resolve(self, registry: ext.ExtensionRegistry) -> Type:
"""Resolve types in the type using the given registry."""
return self

def to_model(self) -> model.Term | model.Splice:
"""Convert the type to a model Term."""
raise NotImplementedError(self)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The absence of implementations for Type, TypeParam, TypeArg seem like significant omissions! Is there a reasoning behind it?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These classes are protocols. The actual types, type params, etc inherit from the class and implement the method accordingly.

@@ -103,6 +116,10 @@ def _to_serial(self) -> stys.TypeTypeParam:
def __str__(self) -> str:
return str(self.bound)

def to_model(self) -> model.Term:
# Note that we drop the bound.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why are we dropping the bounds here and in BoundedNatParam?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

They have no representation in hugr-model. There was a big discussion on this half a year ago, resulting in the realisation that the bounds introduce subtyping and therefore make the type system unnecessarily complex. But without having a stable serialisation format, we were unable to change anything about that, leading to an in part still unresolved chicken egg problem. Bounds for type variables in some situations are emulated with constraints.

@zrho zrho force-pushed the zrho/model-python branch from aa55a75 to b7e8522 Compare March 26, 2025 09:48
@zrho zrho added this pull request to the merge queue Mar 26, 2025
Merged via the queue into main with commit 25df063 Mar 26, 2025
24 of 25 checks passed
@zrho zrho deleted the zrho/model-python branch March 26, 2025 12:52
This was referenced Mar 26, 2025
github-merge-queue bot pushed a commit that referenced this pull request Mar 28, 2025
🤖 I have created a release *beep* *boop*
---


##
[0.11.4](hugr-py-v0.11.3...hugr-py-v0.11.4)
(2025-03-28)


### Features

* Python bindings for `hugr-model`.
([#1959](#1959))
([25df063](25df063))
* Remove extension sets from `hugr-model`.
([#2031](#2031))
([5dd1f96](5dd1f96))

---
This PR was generated with [Release
Please](https://github.com/googleapis/release-please). See
[documentation](https://github.com/googleapis/release-please#release-please).
@hugrbot hugrbot mentioned this pull request Apr 1, 2025
github-merge-queue bot pushed a commit that referenced this pull request Apr 2, 2025
## 🤖 New release

* `hugr-model`: 0.18.1 -> 0.19.0 (⚠ API breaking changes)
* `hugr-core`: 0.15.2 -> 0.15.3 ~(⚠ API breaking changes)~
* `hugr-llvm`: 0.15.2 -> 0.15.3 (✓ API compatible changes)
* `hugr-passes`: 0.15.2 -> 0.15.3 (✓ API compatible changes)
* `hugr`: 0.15.2 -> 0.15.3 (✓ API compatible changes)
* `hugr-cli`: 0.15.2 -> 0.15.3 (✓ API compatible changes)

### ⚠ `hugr-model` breaking changes

```text
--- failure enum_missing: pub enum removed or renamed ---

Description:
A publicly-visible enum cannot be imported by its prior path. A `pub use` may have been removed, or the enum itself may have been renamed or removed entirely.
        ref: https://doc.rust-lang.org/cargo/reference/semver.html#item-remove
       impl: https://github.com/obi1kenobi/cargo-semver-checks/tree/v0.40.0/src/lints/enum_missing.ron

Failed in:
  enum hugr_model::v0::table::ExtSetPart, previously in file /tmp/.tmpDqJ3X7/hugr-model/src/v0/table/mod.rs:352

--- failure enum_variant_added: enum variant added on exhaustive enum ---

Description:
A publicly-visible enum without #[non_exhaustive] has a new variant.
        ref: https://doc.rust-lang.org/cargo/reference/semver.html#enum-variant-new
       impl: https://github.com/obi1kenobi/cargo-semver-checks/tree/v0.40.0/src/lints/enum_variant_added.ron

Failed in:
  variant Term:Func in /tmp/.tmpIpZPlW/hugr/hugr-model/src/v0/table/mod.rs:341

--- failure enum_variant_missing: pub enum variant removed or renamed ---

Description:
A publicly-visible enum has at least one variant that is no longer available under its prior name. It may have been renamed or removed entirely.
        ref: https://doc.rust-lang.org/cargo/reference/semver.html#item-remove
       impl: https://github.com/obi1kenobi/cargo-semver-checks/tree/v0.40.0/src/lints/enum_variant_missing.ron

Failed in:
  variant Term::ExtSet, previously in file /tmp/.tmpDqJ3X7/hugr-model/src/v0/table/mod.rs:316
  variant Term::ConstFunc, previously in file /tmp/.tmpDqJ3X7/hugr-model/src/v0/table/mod.rs:321
  variant Term::ExtSet, previously in file /tmp/.tmpDqJ3X7/hugr-model/src/v0/ast/mod.rs:237

--- failure pub_module_level_const_missing: pub module-level const is missing ---

Description:
A public const is missing or renamed
        ref: https://doc.rust-lang.org/cargo/reference/semver.html#item-remove
       impl: https://github.com/obi1kenobi/cargo-semver-checks/tree/v0.40.0/src/lints/pub_module_level_const_missing.ron

Failed in:
  CORE_EXT_SET in file /tmp/.tmpDqJ3X7/hugr-model/src/v0/mod.rs:177
```

### ⚠ `hugr-core` breaking changes (⚠️ ignored ⚠️ )

```text
--- failure enum_variant_added: enum variant added on exhaustive enum ---

Description:
A publicly-visible enum without #[non_exhaustive] has a new variant.
        ref: https://doc.rust-lang.org/cargo/reference/semver.html#enum-variant-new
       impl: https://github.com/obi1kenobi/cargo-semver-checks/tree/v0.40.0/src/lints/enum_variant_added.ron

Failed in:
  variant ImportError:OrderHint in /tmp/.tmpIpZPlW/hugr/hugr-core/src/import.rs:73
```

<details><summary><i><b>Changelog</b></i></summary><p>

## `hugr-model`

<blockquote>

##
[0.19.0](hugr-model-v0.18.1...hugr-model-v0.19.0)
- 2025-04-02

### New Features

- Python bindings for `hugr-model`.
([#1959](#1959))
- Remove extension sets from `hugr-model`.
([#2031](#2031))
- Packages in `hugr-model` and envelope support.
([#2026](#2026))
- Represent order edges in `hugr-model` as metadata.
([#2027](#2027))
</blockquote>

## `hugr-core`

<blockquote>

##
[0.16.0](hugr-core-v0.15.2...hugr-core-v0.16.0)
- 2025-04-02

### Documentation

- Provide docs for array ops, fix bad doc for HugrView::poly_func_type
([#2021](#2021))

### New Features

- Expand SimpleReplacement API
([#1920](#1920))
- Python bindings for `hugr-model`.
([#1959](#1959))
- ReplaceTypes pass allows replacing extension types and ops
([#1989](#1989))
- Remove extension sets from `hugr-model`.
([#2031](#2031))
- Packages in `hugr-model` and envelope support.
([#2026](#2026))
- Represent order edges in `hugr-model` as metadata.
([#2027](#2027))
- add `build_expect_sum` to allow specific error messages
([#2032](#2032))
</blockquote>

## `hugr-llvm`

<blockquote>

##
[0.16.0](hugr-llvm-v0.15.2...hugr-llvm-v0.16.0)
- 2025-04-02

### New Features

- *(hugr-llvm)* Add llvm codegen for `arithmetic.float.fpow`
([#2042](#2042))
- *(hugr-llvm)* Emit divmod and mod operations
([#2025](#2025))
</blockquote>

## `hugr-passes`

<blockquote>

##
[0.16.0](hugr-passes-v0.15.2...hugr-passes-v0.16.0)
- 2025-04-02

### New Features

- ReplaceTypes pass allows replacing extension types and ops
([#1989](#1989))
- MakeTuple->UnpackTuple elision pass
([#2012](#2012))
- [**breaking**] Extend LowerTypes pass to linearize by inserting
copy/discard ([#2018](#2018))
</blockquote>

## `hugr`

<blockquote>

##
[0.16.0](hugr-v0.15.2...hugr-v0.16.0)
- 2025-04-02

### Documentation

- Provide docs for array ops, fix bad doc for HugrView::poly_func_type
([#2021](#2021))

### New Features

- MakeTuple->UnpackTuple elision pass
([#2012](#2012))
- [**breaking**] Extend LowerTypes pass to linearize by inserting
copy/discard ([#2018](#2018))
- Expand SimpleReplacement API
([#1920](#1920))
- Python bindings for `hugr-model`.
([#1959](#1959))
- ReplaceTypes pass allows replacing extension types and ops
([#1989](#1989))
- Remove extension sets from `hugr-model`.
([#2031](#2031))
- Represent order edges in `hugr-model` as metadata.
([#2027](#2027))
- add `build_expect_sum` to allow specific error messages
([#2032](#2032))
- Packages in `hugr-model` and envelope support.
([#2026](#2026))
</blockquote>

## `hugr-cli`

<blockquote>

##
[0.16.0](hugr-cli-v0.15.2...hugr-cli-v0.16.0)
- 2025-04-02

### Documentation

- Add usage info to hugr-cli's rustdocs
([#2044](#2044))
</blockquote>


</p></details>

---
This PR was generated with
[release-plz](https://github.com/release-plz/release-plz/).

---------

Co-authored-by: Agustín Borgna <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants